微信小程序实现文本安全监测 - 新闻资讯 - 云南小程序开发|云南软件开发|云南网站建设-昆明葵宇信息科技有限公司

159-8711-8523

云南网建设/小程序开发/软件开发

知识

不管是网站,软件还是小程序,都要直接或间接能为您产生价值,我们在追求其视觉表现的同时,更侧重于功能的便捷,营销的便利,运营的高效,让网站成为营销工具,让软件能切实提升企业内部管理水平和效率。优秀的程序为后期升级提供便捷的支持!

您当前位置>首页 » 新闻资讯 » 小程序相关 >

微信小程序实现文本安全监测

发表时间:2020-10-11

发布人:葵宇科技

浏览次数:39

对于微信小程序云开发中的文本安全监测,我真的很是无语,虽然经历了许多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,但是通过网上查阅资料终于解决,如果有小伙伴在运行我的程序出现问题,欢迎在评论区下方留言!

相关案例查看更多