微信小程序监测文本内容,图片内容是否包含违法违规内容

发布小程序正式版时,审核不通过,官方审核回复说两条违规:
1、小程序涉及提供用户自行生成内容的发布/分享/交流服务
解决方法:
登录小程序公众平台——》设置——》基本信息——》服务类目

2、进行内容安全验证时,仍然存在信息安全风险,包括但不限于发现敏感内容、无法对新发布的敏感内容识别过滤等
解决方法:
官方文档:https://developers.weixin.qq.com/miniprogram/dev/framework/msg_security.html
需要后台完成,本人一个小前端,唉

 //获取access_token
	public static Map<String, Object> getAccessToken() {
		Map<String, Object> map = null;
		StringBuffer url = new StringBuffer("https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential");
		url.append("&appid=");//appid设置
		url.append(APPID);
		url.append("&secret=");//secret设置
		url.append(APPSecret);
		try {
	        HttpClient client =HttpClientBuilder.create().build();//构建一个Client
	        HttpGet get = new HttpGet(url.toString());    //构建一个GET请求
	        HttpResponse response = client.execute(get);//提交GET请求
	        HttpEntity result = response.getEntity();//拿到返回的HttpResponse的"实体"
	        String content = EntityUtils.toString(result);   
	        JSONObject res = JSONObject.fromObject(content);//把信息封装为json
		    //把信息封装到map
		    map = parseJSON2Map(res);
		} catch (Exception e) {
		    e.printStackTrace();
		}
		return map;
	}
	//json转map
	public static Map<String, Object> parseJSON2Map(JSONObject json) {
	        Map<String, Object> map = new HashMap<String, Object>();
	        // 最外层解析
	        for (Object k : json.keySet()) {
	            Object v = json.get(k);
	            // 如果内层还是数组的话,继续解析
	            if (v instanceof JSONArray) {
	                List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();
	                @SuppressWarnings("unchecked")
					Iterator<JSONObject> it = ((JSONArray) v).iterator();
	                while (it.hasNext()) {
	                    JSONObject json2 = it.next();
	                    list.add(parseJSON2Map(json2));
	                }
	                map.put(k.toString(), list);
	            } else {
	                map.put(k.toString(), v);
	            }
	        }
	        return map;
	}
//校验文本内容是否有违法违规内容
 public static Boolean checkText(String accessToken,String textConetnt) {

	        try {
	            CloseableHttpClient httpclient = HttpClients.createDefault();

	            CloseableHttpResponse response = null;
	            HttpPost request = new HttpPost("https://api.weixin.qq.com/wxa/msg_sec_check?access_token=" + accessToken);
	            request.addHeader("Content-Type", "application/json;charset=UTF-8");

	            Map<String, String> paramMap = new HashMap<String, String>();
	            paramMap.put("content", textConetnt);
	            request.setEntity(new StringEntity(com.alibaba.fastjson.JSONObject.toJSONString(paramMap), ContentType.create("application/json", "utf-8")));
	            

	            response = httpclient.execute(request);
	            HttpEntity httpEntity = response.getEntity();
	            String result = EntityUtils.toString(httpEntity, "UTF-8");// 转成string
	            com.alibaba.fastjson.JSONObject jso = com.alibaba.fastjson.JSONObject.parseObject(result);
	            System.out.println(jso);
	            Object errcode = jso.get("errcode");
	            int errCode = (int) errcode;
	            if (errCode == 0) {
	                return true;
	            } else if (errCode == 87014) {
	                System.out.println("内容违规-----------" + textConetnt);
	                return false;
	            }

	            return true;
	        } catch (Exception e) {
	            e.printStackTrace();
	            System.out.println("----------------调用腾讯内容过滤系统出错------------------");
	            return true;
	        }
	  }	 
/**
     * 图片过滤检测
     * @param file 图片文件
     * @return
     */
    @RequestMapping(value = "/imgcheck", method = {RequestMethod.POST})
    @ResponseBody
    public AccessTokenWX checkPic(@RequestParam(value = "file") MultipartFile file, HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) {
       
        //自己写一个定时任务或其他方式 获取AccessToken
        AccessTokenWX accessTokenWX = new AccessTokenWX();
        try {
                String  token = WxApiUtil.getAccessToken().get("access_token")+"";
                String url = "https://api.weixin.qq.com/wxa/img_sec_check?access_token=" + token;
                String result = WxApiUtil.uploadFile(url, file);
                accessTokenWX = JSON.parseObject(result, AccessTokenWX.class);
                System.out.println("图片检测结果 = " + result);
                return accessTokenWX;
        } catch (Exception e) {
            accessTokenWX.setErrcode("500");
            accessTokenWX.setErrmsg("system错误");
            return accessTokenWX;
        }
    }

/**
	     * 上传二进制文件
	     * @param graphurl 接口地址
	     * @param file 图片文件
	     * @return
	     */
	 public static String uploadFile(String graphurl,MultipartFile file) {
	        String line = null;//接口返回的结果
	        try {
	            // 换行符
	            final String newLine = "\r\n";
	            final String boundaryPrefix = "--";
	            // 定义数据分隔线
	            String BOUNDARY = "========7d4a6d158c9";
	            // 服务器的域名
	            URL url = new URL(graphurl);
	            HttpURLConnection conn = (HttpURLConnection) url.openConnection();
	            // 设置为POST情
	            conn.setRequestMethod("POST");
	            // 发送POST请求必须设置如下两行
	            conn.setDoOutput(true);
	            conn.setDoInput(true);
	            conn.setUseCaches(false);
	            // 设置请求头参数
	            conn.setRequestProperty("connection", "Keep-Alive");
	            conn.setRequestProperty("Charsert", "UTF-8");
	            conn.setRequestProperty("Content-Type","multipart/form-data; boundary=" + BOUNDARY);
	            conn.setRequestProperty("User-Agent","Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/11.0 Mobile/15A372 Safari/604.1");
	            OutputStream out = new DataOutputStream(conn.getOutputStream());

	            // 上传文件
	            StringBuilder sb = new StringBuilder();
	            sb.append(boundaryPrefix);
	            sb.append(BOUNDARY);
	            sb.append(newLine);
	            // 文件参数,photo参数名可以随意修改
	            sb.append("Content-Disposition: form-data;name=\"image\";filename=\""
	                    + "https://api.weixin.qq.com" + "\"" + newLine);
	            sb.append("Content-Type:application/octet-stream");
	            // 参数头设置完以后需要两个换行,然后才是参数内容
	            sb.append(newLine);
	            sb.append(newLine);

	            // 将参数头的数据写入到输出流中
	            out.write(sb.toString().getBytes());

	            // 读取文件数据
	            out.write(file.getBytes());
	            // 最后添加换行
	            out.write(newLine.getBytes());

	            // 定义最后数据分隔线,即--加上BOUNDARY再加上--。
	            byte[] end_data = (newLine + boundaryPrefix + BOUNDARY
	                    + boundaryPrefix + newLine).getBytes();
	            // 写上结尾标识
	            out.write(end_data);
	            out.flush();
	            out.close();
	            // 定义BufferedReader输入流来读取URL的响应
	            BufferedReader reader = new BufferedReader(new InputStreamReader(
	                    conn.getInputStream()));
	            while ((line = reader.readLine()) != null) {
	                return line;
	            }
	        } catch (Exception e) {
	            System.out.println("发送POST请求出现异常!" + e);
	        }
	        return line;
	    }

@JsonInclude(JsonInclude.Include.NON_NULL)
public class AccessTokenWX {
		private String access_token;
	    private Integer expires_in;
	    private String errcode;
	    private String errmsg;
		public String getAccess_token() {
			return access_token;
		}
		public void setAccess_token(String access_token) {
			this.access_token = access_token;
		}
		public Integer getExpires_in() {
			return expires_in;
		}
		public void setExpires_in(Integer expires_in) {
			this.expires_in = expires_in;
		}
		public String getErrcode() {
			return errcode;
		}
		public void setErrcode(String errcode) {
			this.errcode = errcode;
		}
		public String getErrmsg() {
			return errmsg;
		}
		public void setErrmsg(String errmsg) {
			this.errmsg = errmsg;
		} 
}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值