【微信小程序】图片违法违规内容鉴别(云函数)

微信小程序通过云调用校验一张图片是否含有违法违规内容。

选择图片:

js 复制代码
  wx.chooseImage({
        count: 6,
        sizeType: ['compressed'], // 可以指定是原图还是压缩图,默认二者都有
        sourceType: ['album', 'camera'], // 可以指定来源是相册还是相机,默认二者都有
        success: function(res) {
          var tempFiles = res.tempFiles
          tempFiles.forEach((ele,index)=>{
            if (ele && ele.size > 1024 * 1024) {
              toast('图片不能大于1M')
              return;
            }
           // 图片转化buffer后,调用云函数
            wx.getFileSystemManager().readFile({
              filePath: ele.path,
              success: res => {
                let check_img = check_img_Func(res.data)
                check_img.then(res => {
                  //图片是否违规
                  if (res.result.errCode && res.result.errCode == 87014){
                    toast('图片含有违法违规内容')
                  }
                }).catch(console.error)
              },
              fail: err => {
                reject(err);
              }
            });
          })
        }
      })

引用云函数:

js 复制代码
const check_img_Func = function(img) {
     return wx.cloud.callFunction({
       // 云函数名称
       name: 'check_img',
       // 传给云函数的参数
       data: ({
         img: img
       }),
     })
   }

check_img/index.js:

js 复制代码
// 云函数入口文件
const cloud = require('wx-server-sdk')  
cloud.init()
// 云函数入口函数
exports.main = async (event, context) => {
  try {
    var result = await cloud.openapi.security.imgSecCheck({
      media: {
        contentType: 'image/png',
        value: Buffer.from(event.img) 
      }
    })
    return result
  } catch (err) {
    return err
  }
}

check_img/config.json和package.json中加入配置一下代码:

js 复制代码
{
  "permissions": {
    "openapi": [
      "security.imgSecCheck"
    ]
  }
}

本篇博客旨在记录了自己在小程序编程过程中碰到的一部分问题,如有错误的地方欢迎指正

相关推荐
文慧的科技江湖2 分钟前
OCPP 1.6 与 2.0.1 核心消息差异对照表 - 慧知开源充电桩平台
小程序·开源·ocpp协议·慧知开源充电桩平台
Greg_Zhong19 分钟前
微信小程序中便捷实现自定义底部tab栏
微信小程序·自定义底部tab
LXXgalaxy1 小时前
微信小程序“记住密码”功能的实现与落地 vue3+ts的细致解析
微信小程序·小程序·notepad++
Greg_Zhong1 小时前
微信小程序中使用【免费商用】字体的下载和初步认识和使用
微信小程序·阿里巴巴、站酷·腾讯云对象存储(cos)
克里斯蒂亚诺更新1 小时前
微信小程序 腾讯地图 点聚合 简单示例
微信小程序·小程序·notepad++
Geek_Vision2 小时前
鸿蒙原生APP接入小程序运行能力:数字园区场景实战复盘
微信小程序·harmonyos
CRMEB系统商城3 小时前
国内开源电商系统的格局与演变——一个务实的技术视角
java·大数据·开发语言·小程序·开源·php
2501_916007473 小时前
iOS逆向工程:详细解析ptrace反调试机制的破解方法与实战步骤
android·macos·ios·小程序·uni-app·cocoa·iphone
00后程序员张4 小时前
前端可视化大屏制作全指南:需求分析、技术选型与性能优化
前端·ios·性能优化·小程序·uni-app·iphone·需求分析
January12077 小时前
Taro3 + Vue3 小程序文件上传组件,支持 PDF/PPTX 跨端使用
小程序