您当前的位置:首页 > 电脑百科 > 安全防护 > 服务器/网站

利用百度ai实现文本和图片审核

时间:2019-09-16 11:04:16  来源:  作者:

之前做平台内容发布审核都是自己构建一套违禁词库,在代码中利用词库判断用户发布的内容,现在可以使用百度ai api完成这个功能。接下来就简单说下怎么做吧:

首先打开百度ai 开发平台 注册一个账号

利用百度ai实现文本和图片审核

 


利用百度ai实现文本和图片审核

 

进入控制台

利用百度ai实现文本和图片审核

 

创建自己的应用,获取apikey 和秘钥

利用百度ai实现文本和图片审核

 

进入文档页 文本审核:

利用百度ai实现文本和图片审核

 

图像审核:

利用百度ai实现文本和图片审核

 

文档很详细,实现用户发布内容审核 图片审核还是很方便简单的。

我没有使用官方的sdk,简单的整合了一下作为练手,以下是我简单使用php实现的代码demo:

use NntControllerApplication;
class Sentive
{
 protected $accessTokenUrl = 'https://aip.baidubce.com/oauth/2.0/token';//获取token url
 protected $textUrl = 'https://aip.baidubce.com/rest/2.0/antispam/v2/spam';//文本审核url
 protected $imgUrl = 'https://aip.baidubce.com/api/v1/solution/direct/img_censor';//图片审核url
 protected $avatarUrl = 'https://aip.baidubce.com/rest/2.0/solution/v1/face_audit';//头像审核url
 protected $grant_type;
 protected $client_id;
 protected $client_secret;
 function __construct()
{
 $this->grant_type = 'client_credentials';
 $this->client_id = 'xxx';//API Key
 $this->client_secret = 'xxx';//Secret Key
 }
 static function request($url = '', $param = '')
{
 if (empty($url) || empty($param)) {
 return false;
 }
 $postUrl = $url;
 $curlPost = $param;
 $curl = curl_init();//初始化curl
 curl_setopt($curl, CURLOPT_URL, $postUrl);//抓取指定网页
 curl_setopt($curl, CURLOPT_HEADER, 0);//设置header
 curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);//要求结果为字符串且输出到屏幕上
 curl_setopt($curl, CURLOPT_POST, 1);//post提交方式
 curl_setopt($curl, CURLOPT_POSTFIELDS, $curlPost);
 $data = curl_exec($curl);//运行curl
 curl_close($curl);
 return $data;
 }
 static function request_post($url = '', $param = array(), $type)
{
 if (empty($url) || empty($param)) {
 return false;
 }
 $postUrl = $url;
 $curlPost = $param;
 $curl = curl_init();
 curl_setopt($curl, CURLOPT_URL, $postUrl);
 curl_setopt($curl, CURLOPT_HEADER, 0);
 // 要求结果为字符串
 curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
 // post方式
 curl_setopt($curl, CURLOPT_POST, 1);
 curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
 curl_setopt($curl, CURLOPT_POSTFIELDS, $curlPost);
 if ($type == "text") {
 curl_setopt($curl, CURLOPT_HTTPHEADER, array('Content-Type: application/x-www-form-urlencoded'));
 } else {
 curl_setopt($curl, CURLOPT_HTTPHEADER, array('Content-Type: application/json;charset=utf-8'));
 }
 curl_setopt($curl, CURLINFO_HEADER_OUT, true);
 $data = curl_exec($curl);
 $code = curl_getinfo($curl, CURLINFO_HTTP_CODE);
 if ($code === 0) {
 throw new Exception(curl_error($curl));
 }
 curl_close($curl);
 return $data;
 }
 //获取token
 public function getToken()
{
 $redis = Application::$shared->di->getRedis();
 $post_data['grant_type'] = $this->grant_type;
 $post_data['client_id'] = $this->client_id;
 $post_data['client_secret'] = $this->client_secret;
 $o = "";
 foreach ($post_data as $k => $v) {
 $o .= "$k=" . urlencode($v) . "&";
 }
 $post_data = substr($o, 0, -1);
 $res = self::request($this->accessTokenUrl, $post_data);
 $redis->setkey("filterToken", json_decode($res, true)['access_token']);
 return json_decode($res, true)['access_token'];
 }
 //文本审核
 public function textVerify($data)
{
 $redis = Application::$shared->di->getRedis();
 $token = $redis->get("filterToken");
 if (empty($token)) {
 $token = $this->getToken();
 }
 $curl = $this->textUrl . "?access_token=" . $token;
 $result = self::request_post($curl, $data, "text");
 return json_decode($result, true);
 }
 //图片审核
 public function imgVerify($img)
{
 $redis = Application::$shared->di->getRedis();
 $token = $redis->get("filterToken");
 if (empty($token)) {
 $token = $this->getToken();
 }
 $curl = $this->imgUrl . "?access_token=" . $token;
 $bodys = array(
 'image' => $img,
 'scenes' => array("ocr",
 "face", "public", "politician", "antiporn", "terror", "webimage", "disgust",
 'watermark')
 );
 $bodys = json_encode($bodys);
 $result = self::request_post($curl, $bodys, "img");
 return json_decode($result, true);
 }
 //头像审核
 public function avatarVerify($img)
{
 $redis = Application::$shared->di->getRedis();
 $token = $redis->get("filterToken");
 if (empty($token)) {
 $token = $this->getToken();
 }
 $curl = $this->avatarUrl . "?access_token=" . $token;
 $bodys = array(
 "configId" => "1",
 "images" => $img
 );
 $result = self::request_post($curl, $bodys, "text");
 return json_decode($result, true);
 }
}


Tags:百度ai   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
之前做平台内容发布审核都是自己构建一套违禁词库,在代码中利用词库判断用户发布的内容,现在可以使用百度ai api完成这个功能。接下来就简单说下怎么做吧:首先打开百度ai 开发...【详细内容】
2019-09-16  Tags: 百度ai  点击:(196)  评论:(0)  加入收藏
▌简易百科推荐
在最近的一波攻击中,黑客利用多个插件中未修补的漏洞攻击了 160 万个 WordPress 网站。 易受攻击的插件对 WordPress 网站产生了的巨大攻击数据。 Wordfence 最近发现 WordPr...【详细内容】
2021-12-16  蚁安    Tags:WordPress   点击:(9)  评论:(0)  加入收藏
事件起因从安全分析系统里面发现一条带有病毒的下载,然后针对这条记录展开了一系列的分析分析过程1.登录到被感染服务器,查看系统状况,hadoop 这个用户在 2020/6/18 20:32 从这...【详细内容】
2021-11-23  Z2990Lig    Tags:SSH   点击:(32)  评论:(0)  加入收藏
1、除了服务器需要用的一些正规软件,其它都不要安装。2、在用户中把administrator改名,这样做的目的是即使对方暴破了我们的密码用户名也不容易猜住,相当于又加了一道关卡。...【详细内容】
2021-11-01  IT小哥吧    Tags:服务器   点击:(37)  评论:(0)  加入收藏
账户安全(1)更名administrator本地用户并禁用guest账户步骤:点击“开始”,找到“管理工具”,点击里面的“计算机管理”,找到“本地用户和组” (2)设定账户锁定策略尝试5次失败...【详细内容】
2021-10-12  Kali与编程  今日头条  Tags:Windows主机   点击:(62)  评论:(0)  加入收藏
本文主要介绍以Microsoft的Windows Server 2019 ,版本:Datacenter(Domain Controller)安全加固保护.企业随着规模不断扩大,业务增多,信息安全建设是企业里一条只有重点没有终点...【详细内容】
2021-09-17  Vireshark    Tags:服务器安全   点击:(64)  评论:(0)  加入收藏
目录常见共享命令IPC$IPC$的利用条件1:开启了139、445端口2:目标主机开启了IPC$共享3:IPC连接报错IPC空连接空连接可以做什么?(毫无作用)IPC$非空连接IPC$非空连接可以做什么?di...【详细内容】
2021-09-16  网络说安全    Tags:系统安全   点击:(86)  评论:(0)  加入收藏
昨天一个老哥找到我,说他的服务器这几天一直被CC攻击,问我这边有没有什么解决的方法? 近年来,网络攻击事件越来越频繁,最常见的就是CC攻击和DDOS攻击,主要的区别就是针对的对象不...【详细内容】
2021-09-10  小蚁GDRAGON    Tags:cc攻击   点击:(58)  评论:(0)  加入收藏
网站页面上的登录操作,通常都是输入帐号密码,传输至网站后台验证。在网站页面、数据传输中,通过技术手段,都可以得到用户输入的信息,并可以修改,从而发起网络攻击。典型的如:使用自...【详细内容】
2021-08-30  修丹道的程序猿    Tags:登录方式   点击:(62)  评论:(0)  加入收藏
网络安全研究人员披露了一类影响主要 DNS 即服务 (DNSaaS) 提供商的新漏洞,这些漏洞可能允许攻击者从企业网络中窃取敏感信息。基础设施安全公司 Wiz 的研究人员 Shir Tamar...【详细内容】
2021-08-12  零日时代    Tags:漏洞   点击:(66)  评论:(0)  加入收藏
001暴力破解1. 指定用户名爆破密码传统型爆破思路,用户名可以通过猜测或者信息收集获得。猜测:admin、网站域名等信息收集:新闻发布人、whoami等2. 指定密码爆破用户名如果是后...【详细内容】
2021-07-23  KaliMa  今日头条  Tags:登陆框   点击:(85)  评论:(0)  加入收藏
相关文章
    无相关信息
最新更新
栏目热门
栏目头条