微信小程序实现文本安全监测
发表时间:2020-10-11
发布人:葵宇科技
浏览次数:47
对于微信小程序云开发中的文本安全监测,我真的很是无语,虽然经历了许多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,但是通过网上查阅资料终于解决,如果有小伙伴在运行我的程序出现问题,欢迎在评论区下方留言!