uniapp云函数使用——内容审核

背景

小程序计划开通自定义头像功能,经过团队讨论,决定使用微信免费内容审核服务对用户自定义头像进行鉴黄和鉴政审核。

技术实现

技术选型

由于小程序采用 uniapp 开发,优先考虑 uniapp 云平台。参考以下资料:

实施步骤

1. 创建云函数文件

在 HBuilderX 中创建新的云函数文件。

2. 关联服务空间

右键点击云函数目录,选择「关联服务空间」,完成服务空间配置。

3. 安装公共库

从插件市场安装所需公共库:

uni-sec-check 依赖 uni-open-bridge 配置,需同时安装 uni-open-bridge

4. 配置小程序信息

uni-open-bridge 配置文件中设置小程序 ID 和密钥:

json

json 复制代码
{
  "dcloudAppid": "__UNI_6E118A6",
  "mp-weixin": {
    "oauth": {
      "weixin": {
        "appid": "你的小程序ID",
        "appsecret": "你的小程序密钥"
      }
    }
  }
}

5. 创建云函数

每个云函数需要包含以下文件:

  • index.js - 主逻辑文件
  • package.json - 依赖配置文件

文本内容审核云函数

javascript

javascript 复制代码
const UniSecCheck = require('uni-sec-check');

exports.main = async (event, context) => {
  try {
    const { content, openid = "", scene = 2, version = 2 } = event;
    
    // 参数校验
    if (!content) {
      return {
        code: 400,
        success: false,
        errMsg: '检测内容不能为空'
      };
    }

    const uniSecCheck = new UniSecCheck({
      provider: 'mp-weixin',
      requestId: context.requestId,
    });

    const checkRes = await uniSecCheck.textSecCheck({
      content,
      openid,
      scene,
      version
    });

    // 处理检测结果
    if (checkRes.errCode === 'uni-sec-check-risk-content') {
      return {
        code: 400,
        success: false,
        errMsg: '内容不合规',
        result: checkRes.result
      };
    } else if (checkRes.errCode) {
      return {
        code: 500,
        success: false,
        errMsg: `检测服务异常: ${checkRes.errMsg}`
      };
    }

    // 检测通过
    return {
      code: 200,
      success: true,
      errMsg: '内容合规'
    };

  } catch (error) {
    console.error('文本检测异常:', error);
    return {
      code: 500,
      success: false,
      errMsg: `服务器内部错误: ${error.message}`
    };
  }
};

头像审核云函数

javascript

javascript 复制代码
const UniSecCheck = require('uni-sec-check')

exports.main = async function(event, context) {
    // 参数校验
    const { url, openid = "", scene = 2, version = 2 } = event
    if (!url) {
      return {
        code: 400,
        success: false,
        errMsg: '缺少图片URL参数'
      }
    }

    // 创建内容安全检测实例
    const uniSecCheck = new UniSecCheck({
      provider: 'mp-weixin',
      requestId: context.requestId
    })

    // 进行图片安全检测
    console.log('开始图片安全检测:', url)
    const imgSecCheckRes = await uniSecCheck.imgSecCheck({
      image: url,
      openid: openid,
      scene: scene,
      version: version
    })

    console.log('图片检测结果:', imgSecCheckRes)

    // 处理检测结果
    if (imgSecCheckRes.errCode) {
      // 图片违规
      return {
        code: 400,
        success: false,
        errMsg: '图片内容违规',
        result: {
          label: imgSecCheckRes.result?.label,
          suggest: imgSecCheckRes.result?.suggest
        }
      }
    }
    
    // 检测通过
    return {
      code: 200,
      success: true,
      errMsg: '图片检测通过',
      data: imgSecCheckRes
    }
}

6. 客户端调用

javascript

php 复制代码
const openid = uni.getStorageSync('user_openid');
if (!openid) {
  uni.hideLoading();
  uni.showToast({
    title: '用户信息获取失败',
    icon: 'none'
  });
  return false;
}

const result = await uniCloud.callFunction({
  name: 'avatarCheck',
  data: {
    url: imageUrl,
    openid: openid,
    scene: 1, // 资料场景(用户头像)
    version: 2
  }
});

注意事项

  1. 用户 openid 需要在用户登录时获取并存储
  2. v2 异步头像审核模式在不配置异步通知的情况下仍可正常使用
  3. 根据返回结果进行相应的业务逻辑处理

如有问题或建议,欢迎在评论区讨论交流

相关推荐
hh随便起个名9 小时前
力扣二叉树的三种遍历
javascript·数据结构·算法·leetcode
我是小路路呀9 小时前
element级联选择器:已选中一个二级节点,随后又点击了一个一级节点(仅浏览,未确认选择),此时下拉框失去焦点并关闭
javascript·vue.js·elementui
程序员爱钓鱼9 小时前
Node.js 编程实战:文件读写操作
前端·后端·node.js
PineappleCoder10 小时前
工程化必备!SVG 雪碧图的最佳实践:ID 引用 + 缓存友好,无需手动算坐标
前端·性能优化
JIngJaneIL10 小时前
基于springboot + vue古城景区管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
敲敲了个代码10 小时前
隐式类型转换:哈基米 == 猫 ? true :false
开发语言·前端·javascript·学习·面试·web
澄江静如练_10 小时前
列表渲染(v-for)
前端·javascript·vue.js
JustHappy11 小时前
「chrome extensions🛠️」我写了一个超级简单的浏览器插件Vue开发模板
前端·javascript·github
Loo国昌11 小时前
Vue 3 前端工程化:架构、核心原理与生产实践
前端·vue.js·架构