首先吐槽下小程序的api写的si一样
下面是正题:
公司小程序审核多次不过,沟通后确认是用户ugc没有做内容安全检测;
小程序的内容安全
1.imgSecCheck 图片检测
a.图片智能鉴黄:涉及拍照的工具类应用(如美拍,识图类应用)用户拍照上传检测;电商类商品上架图片检测;媒体类用户文章里的图片检测等;
b.敏感人脸识别:用户头像;媒体类用户文章里的图片检测;社交类用户上传的图片检测等。 频率限制:单个 appId 调用上限为 2000 次/分钟,200,000 次/天*(图片大小限制:1M)
请求地址:
POST https://api.weixin.qq.com/wxa/img_sec_check?access_token=ACCESS_TOKEN
请求参数
属性 | 类型 | 默认值 | 必填 | 说明 |
---|---|---|---|---|
access_token | string | 是 | 接口调用凭证 | |
media | FormData | 是 | 要检测的图片文件,格式支持PNG、JPEG、JPG、GIF,图片尺寸不超过 750px x 1334px |
返回值 Object
返回的 JSON 数据包
属性 | 类型 | 说明 |
---|---|---|
errcode | number | 错误码(0, 47001, 87014) |
errMsg | string | 错误信息(ok, data wrong, 内容含有违法违规内容) |
Java代码
public ResultEntity checkImgByInputStream(InputStream inputStream) throws HttpException {
if(inputStream == null){
return null;
}
//获取access_token
String accessToken = getAccessToken();
String url = String.format(imgSecCheckUrl, accessToken);
HttpClient httpclient = HttpClients.createDefault();
HttpPost request = new HttpPost(url);
request.addHeader("Content-Type", "application/octet-stream");
try {
byte[] byt = new byte[inputStream.available()];
inputStream.read(byt);
request.setEntity(new ByteArrayEntity(byt, ContentType.create("image/jpg")));
HttpResponse response = httpclient.execute(request);
HttpEntity entity = response.getEntity();
String result = EntityUtils.toString(entity, "UTF-8");// 转成string
logger.info("response: " + result);
ResultEntity resultEntity = JsonKit.parseObject(result, ResultEntity.class);
return resultEntity;
} catch (IOException e) {
e.printStackTrace();
} finally {
if(inputStream != null){
try {
inputStream.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
return null;
}
当图片大于给1M时,采用图片压缩,应用goodle开源的Thumbnails,现在是0.4.8版本
<dependency>
<groupId>net.coobird</groupId>
<artifactId>thumbnailator</artifactId>
<version>0.4.8</version>
</dependency>
压缩图片(支持多种格式的书输入)
//num 文件长度
public InputStream compressImage(URLConnection connection, long num) throws IOException {
if(num == 0 || connection == null){
return null;
}
double multiple = 1.0 / (num / (1024 * 1024) + 1.0);
BufferedImage image = Thumbnails.of(connection.getInputStream()).scale(multiple).asBufferedImage();
ByteArrayOutputStream os = new ByteArrayOutputStream();
ImageIO.write(image, "jpg", os);
InputStream is = new ByteArrayInputStream(os.toByteArray());
return is;
}
2.msgSecCheck 文字检测
1.用户个人资料违规文字检测;
2.媒体新闻类用户发表文章,评论内容检测;
3.游戏类用户编辑上传的素材(如答题类小游戏用户上传的问题及答案)检测等。 频率限制:单个 appId 调用上限为 4000 次/分钟,2,000,000 次/天*
请求地址
POST https://api.weixin.qq.com/wxa/msg_sec_check?access_token=ACCESS_TOKEN
请求参数
属性 | 类型 | 默认值 | 必填 | 说明 |
---|---|---|---|---|
access_token | string | 是 | 接口调用凭证 | |
content | string | 是 | 要检测的文本内容,长度不超过 500KB |
返回值
返回的 JSON 数据包
属性 | 类型 | 说明 |
---|---|---|
errcode | number | 错误码 |
errMsg | string | 错误信息 |
java代码
public ResultEntity checkMsg(String content) throws HttpException {
String accessToken = getAccessToken();
String url = String.format(msgSecCheckUrl, accessToken);
Map<String, String> map = new HashMap<>();
map.put("content", content);
String result = HttpClientKit.postJson(url, JsonKit.toJson(map), 60 * 1000);
if (StringUtils.isNotBlank(result)) {
return JsonKit.parseObject(result, ResultEntity.class);
}
return null;
}
网友评论