微信小程序实现文本安全监测
发表时间:2020-10-11
发布人:葵宇科技
浏览次数:54
对于微信小程序云开发中的文本安全监测,我真的很是无语,虽然经历了许多BUG,但是好在最后自己也终于解决这个问题了,下面我将介绍两种文本安全监测方法。
 调用云函数文本index.js
onSubmitEvent:function(event){
    const content = event.detail.value.content;
    const location = this.data.location;
    const author = app.globalData.userInfo;
    wx.cloud.callFunction({
      name:"#云函数名",
      data:{
        content:content,
        location:location,
        author:author
      },
      success:res=>{
        // if(res.result.errCode === 0){
        //   db.collection("#数据库名").add({
        //     data:{
        //       content:content,
        //       location:location,
        //       author:author
        //     }
        //   }).then(res=>{
        //     console.log(res)
        //   })
        // }
        console.log(res)
        
      },
      fail:err=>{
        console.error(err)
      }
第一种,HTTPS监测方法
云函数index.js
const cloud = require('wx-server-sdk')
const got  = require("got")  //got包---这个位置要在cloud.init()上面,否则可能会报错!
cloud.init()
const db = cloud.database() //数据库---位置要在cloud.init()下面
const APPID = "#自己的APPID";  
const APPSECRET = "#自己的密钥"; 
const tokenUrl = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid="+APPID+"&secret="+APPSECRET;
const checkUrl = "https://api.weixin.qq.com/wxa/msg_sec_check?access_token=";
// 云函数入口函数
exports.main = async (event, context) => {
 
  const content = event.content;
  const location = event.location;
  const author = event.author;
  const tokenResponse = await got(tokenUrl);
  const access_token = JSON.parse(tokenResponse.body).access_token;
  const CheckUrl = checkUrl + access_token;
  const checkResponse = await got.post(CheckUrl,{
    body:JSON.stringify({
      content:content
    })
  })
  const checkBody = JSON.parse(checkResponse.body)
  const errcode = checkBody.errcode;
  //存储到数据库中
  if(errcode == 0){
    return await db.collection("#数据库名").add({
      data:{
        content:content,
        location:location,
        author:author
      }
    })
  }else{
    return {"errcode":1,"errmsg":"你的发布的内容有风险,请修改后再发布"}
  }
}
第二种,云调用方法
云函数index.js
// 云函数入口文件
const cloud = require('wx-server-sdk')
cloud.init()
const db = cloud.database()
// 云函数入口函数
exports.main = async (event, context) => {
  try{
    
    const e = await cloud.openapi.security.msgSecCheck({
     
        content:event.content
       
    })
    
   
    const res = e.errCode;
  
    // console.log(res)
    // return res
    if(res == 0){
     return await db.collection("#数据库名").add({
        data:{
          content:event.content,
          location:event.location,
          author:event.author
        }
      })
    }else{
      
      return {"errCode":1,"errMsg":"你提交的内容有风险,请修改后在提交!"}
     }
    
  } catch(err){
    return err
  }
}
发了一天的时间终于将这个问题解决了,期间遇到许多BUG,但是通过网上查阅资料终于解决,如果有小伙伴在运行我的程序出现问题,欢迎在评论区下方留言!








