欢迎光临
感谢一路有你

小程序接入内容内容审查接口(图片.文字)

如果你对该文章中的内容有疑问/不解,可以点击此处链接提问
要注明问题和此文章链接地址 点击此处跳转
 

今天不知咋回事使用easywechat的内容安全api,不知咋回事.之前还可以使用的这些天突然报这个错,也不知道是不是因为升级还是与其他的冲突,

那怎么办呢,还是用下原生的接口,在这里我获取的token方法还是easywechat的方式


<code class="">$miniProgram = ZFac::miniProgram($this-&gt;config);
$token = $miniProgram-&gt;access_token-&gt;getToken()['access_token'];
</code>

具体的代码如下

image-20200723180946823


<code class="">use EasyWeChat\Factory as ZFac;

public function __construct ( Request $request = null ){
        $this-&gt;config = [
            'app_id' =&gt; 'wx412****d45a65',
            'secret' =&gt; '082dec1*****985b93d286c093e01',
            // 下面为可选项
            // 指定 API 调用返回结果的类型:array(default)/collection/object/raw/自定义类名
            'response_type' =&gt; 'array',
            'log' =&gt; [
                'level' =&gt; 'debug',
                'file' =&gt; __DIR__.'/log/wechat.log',
            ],
        ];
}

  //文字验证
  $miniProgram = ZFac::miniProgram($this-&gt;config);
  $token = $miniProgram-&gt;access_token-&gt;getToken()['access_token'];
  // $result = $miniProgram-&gt;content_security-&gt;checkText($data['content']);
  $result = $this-&gt;z_msgSecCheck($token,$data['content']);
  if($result['errcode']!='0'){
  return jserror('内容含有非法关键词');die;
  }


//图片验证
 public function upload_pic(){
        $file = request()-&gt;file('file');
        $info = $file-&gt;validate(['ext'=&gt;config()['web']['file_ext']])-&gt;move('./public/upload/admin/file');
        $getSaveName = str_replace('\\', '/', $info-&gt;getSaveName());//win下反斜杠替换成斜杠
        $msg = 'http://'.$_SERVER['SERVER_NAME'].'/public/upload/admin/file/'.$getSaveName;
         if(is_file('./public/upload/admin/file/'.$getSaveName)){
          //验证图片
            $miniProgram = ZFac::miniProgram($this-&gt;config);
            $token = $miniProgram-&gt;access_token-&gt;getToken()['access_token'];
            $result = $this-&gt;z_imgSecCheck($token,'./public/upload/admin/file/'.$getSaveName);
            // $miniProgram = ZFac::miniProgram($this-&gt;config);
            // $result = $miniProgram-&gt;content_security-&gt;checkImage('./public/upload/admin/file/'.$getSaveName);
            if($result['errcode']!='0'){
              return '非法图片';
            }else{
              return $msg;
            }
        }else{
            return '0';
        }
    }



</code>

核心


<code class="">/*微信文字敏感内容检测*/
    public function z_msgSecCheck($token,$msg)
    {
        $checkContent = $msg;
        $url = 'https://api.weixin.qq.com/wxa/msg_sec_check?access_token='. $token;
        $data = json_encode(array('content'=&gt;$checkContent),JSON_UNESCAPED_UNICODE);
        $ch = curl_init();
        curl_setopt($ch, CURLOPT_HEADER, FALSE);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
        curl_setopt($ch, CURLOPT_URL,$url); // url
        curl_setopt($ch, CURLOPT_POST, TRUE);
        curl_setopt($ch, CURLOPT_POSTFIELDS, $data); // json数据
        $res = curl_exec($ch); // 返回值
        curl_close($ch);
        $result = json_decode($res,true);
        return $result;
    }
  /*微信图片敏感内容检测*/
    public function z_imgSecCheck($token,$path)
    {
        // $path = './public/upload/admin/file/'.$getSaveName;
        $url = "https://api.weixin.qq.com/wxa/img_sec_check?access_token=$token";
        $curl = curl_init();
        curl_setopt($curl, CURLOPT_SAFE_UPLOAD, true);
        $data = array('media' =&gt; new \CURLFile(realpath($path)));
        curl_setopt($curl, CURLOPT_URL, $url);
        curl_setopt($curl, CURLOPT_POST, 1 );
        curl_setopt($curl, CURLOPT_POSTFIELDS, $data);
        curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
        curl_setopt($curl, CURLOPT_USERAGENT,"TEST");
        $result = curl_exec($curl);
        $error = curl_error($curl);
        return json_decode($result,true);
    }
</code>
赞(0) 打赏
未经允许不得转载:王明昌博客 » 小程序接入内容内容审查接口(图片.文字)
分享到: 更多 (0)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏