个人案例
- 为什么最近小程序用户量中出现大量的微信爬虫访问?
爬虫访问小程序内页面时,是否有携带特定的 user-agent:mpcrawler 及场景值:1129。 若有,那是微信的收录设置功能,具体请参考:https://mp.weixin.qq.com/wxopen/readtemplate?t=config/collection_agreement_tmpl 文档说明:https://developers.weixin.qq.com/miniprogram/dev/framework/sitemap.html
2019-12-30 - 小帅一点资讯
调用百度AI 腾讯AI 腾讯优图做的一个图像识别。文字识别小工具。 线上功能有人脸识别(颜值分析、魅力值分析)、图像识别(车型,菜品,LOGO,动物,植物,食材识别)、文字识别(通用OCR,银行识别,手写文字识别等)、人体分析(手势识别) 使用微信小程序实现图片上传。数据解析渲染显示。 源代码开源在码云(添加链接不能是码云只能是github):https://gitee.com/xshuai/weixinxiaochengxu 使用到的小程序功能: 复制文本内容功能。 在线客服功能。 网络请求功能 图片上传功能 进度条功能等一系列的友好提示功能
2018-07-03 - 【Java后台】校验一张图片是否含有违法违规内容
更新时间:2020年9月29日 具体介绍可查看 https://blog.csdn.net/u010651369/article/details/101697940 修改了提供的接口地址。可以直接调用了。 https://apis.ydxiaoshuai.cn/xai/rest/check/general_url 传递图片URL地址 https://apis.ydxiaoshuai.cn/xai/rest/check/general_file 传递图片FILE文件 接口文档地址:http://api.ydxiaoshuai.cn/1961525 近期应该部分个人开发者小程序会收到如下通知 [图片] 为了快速解决问题,就直接使用官方提供的接口 imgSecCheck校验一张图片是否含有违法违规内容 个人小程序只是图片的一些处理识别。固只拿imgSecCheck接口进行代码示例了。 1.在自己的Java后台服务增加接口调用(api.weixin.qq.com不能直接加入小程序安全域名中) 2.在小程序选择图片后优先走违法违规校验。校验通过再走自己的业务代码。 Java实现获取小程序的图片文件并进行违法违规校验 wx.uploadFile 传递图片文件到后台 [代码] wx.uploadFile({ url: 图片违法违规校验接口地址, filePath: res.tempFilePaths[0], header: { 'content-type': 'multipart/form-data' }, name: 'file', success: function(checkres) { var checkResult = JSON.parse(checkres.data); console.info(checkResult); if (checkResult.errcode == '0') { //校验没有违法违规进行自己业务代码处理 } else { if (checkResult.errcode == '87014') { wx.hideLoading(); wx.showModal({ content: '存在敏感内容,请更换图片', showCancel: false, confirmText: '明白了' }) } else { wx.hideLoading(); wx.showModal({ content: '其他错误,稍后再试', showCancel: false, confirmText: '明白了' }) } } } [代码] 后台代码 [代码]/** * 图片过滤检测 * @param file 图片文件 * @return */ @RequestMapping(value = "/imgcheck", method = {RequestMethod.POST}) @ResponseBody public AccessTokenWX checkPic(@RequestParam(value = "file") MultipartFile file, HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) { String token = ""; //自己写一个定时任务或其他方式 获取AccessToken AccessTokenWX accessTokenWX = new AccessTokenWX(); try { token = getAccessTokenJob.getAccessToken(); String url = "https://api.weixin.qq.com/wxa/img_sec_check?access_token=" + token; String result = uploadFile(url, file); accessTokenWX = JSON.parseObject(result, AccessTokenWX.class); System.out.println("图片检测结果 = " + result); return accessTokenWX; } catch (Exception e) { System.out.println("----------------调用腾讯内容过滤系统出错------------------" + e.getMessage()); 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; } [代码] 为了方便大家。我这里直接封装了一个接口供大家使用 接口地址:https://www.ydxiaoshuai.cn/xai/rest/token/imgcheck/general 请求方式: POST Body参数: [代码]access_token 接口调用凭证 file 图片文件 [代码] POSTMAN截图示意 [图片] 实现Controller代码如下 [代码]/** * 图片过滤检测 * @param file 要校验的图片 * @param access_token 接口调用凭证 * @return */ @RequestMapping(value = "/imgcheck/general", method = {RequestMethod.POST}) @ResponseBody public AccessTokenWX checkPicgeneral(@RequestParam(value = "file") MultipartFile file, String access_token,HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) { logger.info("获取access_token======" + access_token + "访问的ip" + httpServletRequest.getRemoteAddr()); AccessTokenWX accessTokenWX = new AccessTokenWX(); try { String url = "https://api.weixin.qq.com/wxa/img_sec_check?access_token=" + access_token; String result = uploadFile(url, file); accessTokenWX = JSON.parseObject(result, AccessTokenWX.class); System.out.println("图片检测结果 = " + result); return accessTokenWX; } catch (Exception e) { System.out.println("----------------调用腾讯内容过滤系统出错------------------" + e.getMessage()); accessTokenWX.setErrcode("500"); accessTokenWX.setErrmsg("system错误"); return accessTokenWX; } } [代码]
2020-09-29