uni-app使用微信小程序云函数的步骤示例


Posted in Javascript onMay 22, 2020

创建云函数目录

首先,我们需要在uni-app项目文件夹下,创建一个云函数目录,路径随意,我这里是functions。然后先随便在里面放一些文件,这里以new_file.css为例。(放文件的原因是:确保编译成小程序后cloudfunctions文件夹存在。如果该文件夹下没有文件,默认是不会在微信小程序开发平台中显示该文件夹的。)

uni-app使用微信小程序云函数的步骤示例

修改manifest.json

在uni-app根目录下,修改manifest.json中的微信小程序项,结构如下

"mp-weixin" : {
    /* 小程序特有相关 */
    "appid" : "wxd7de467f6e6cf741",
    "cloudfunctionRoot": "./functions/", // 这一行就是标记云函数目录的字段
    "setting" : {
      "urlCheck" : false
    },
    "usingComponents" : true
  }

编写vue.config.js

  • 我们在项目根目录创建vue.config.js文件
  • 写入以下内容(如路径不一样请做相应适配)
const path = require('path')
const CopyWebpackPlugin = require('copy-webpack-plugin')

module.exports = {
  configureWebpack: {
    plugins: [
      new CopyWebpackPlugin([
        {
          from: path.join(__dirname, 'functions'),
          to: path.join(__dirname, 'unpackage/dist', process.env.NODE_ENV === 'production' ? 'build' : 'dev', process.env.UNI_PLATFORM, 'functions')
        }
      ])
    ]
  }
}

编译运行

发现提示如下内容

uni-app使用微信小程序云函数的步骤示例

说明未安装copy-webpack-plugin插件,我们手动安装一下。

uni-app使用微信小程序云函数的步骤示例

然后编译运行,发现微信开发者工具里面出现以下内容。

uni-app使用微信小程序云函数的步骤示例

截止目前,已打通Hbuilder X到微信开发者工具的自动复制,即已解决本文的核心内容。以下为进一步测试。

创建云函数

(在微信开发者工具操作)我们在云函数根目录上右键,在右键菜单中,可以选择创建一个新的 Node.js 云函数,我们将该云函数命名为check。开发者工具在本地创建出云函数目录和入口 index.js 文件,同时在线上环境中创建出对应的云函数。创建成功后,工具会提示是否立即本地安装依赖,确定后工具会自动安装 wx-server-sdk。我们会看到以下内容。

创建好后将其同步复制到uni-app项目,即可为以后自动同步行方便,又可避免在输出文件夹中云函数的意外丢失。至此,相关文件编写工作转至Hbuilder X,云函数上传部署依旧在微信开发者工具。

uni-app使用微信小程序云函数的步骤示例

编写云函数

默认的云函数只是一个返回用户基本数据的内容,我们将其修改至满足我们的业务需求,以内容安全云调用为例。

在云函数文件中写入以下内容

// 云函数入口文件
const cloud = require('wx-server-sdk')

cloud.init()

// 云函数入口函数
exports.main = async(event, context) => {
 try {
  console.log('待检测文本:' + event.content);
  let result = await cloud.openapi.security.msgSecCheck({
   content: event.content
  })
  console.log('result:' + JSON.stringify(result));

  if (result && result.errCode.toString() === '87014') {
   return {
    code: 300,
    msg: '内容含有违法违规内容',
    data: result
   }
  } else {
   return {
    code: 200,
    msg: 'ok',
    data: result
   }
  }

 } catch (err) {
  if (err.errCode.toString() === '87014') {
   return {
    code: 300,
    msg: '内容含有违法违规内容',
    data: err
   }
  }
  return {
   code: 400,
   msg: '调用security接口异常',
   data: err
  }
 }
}

权限申明

在函数目录下,创建一个config.json,文档说会自动创建,但是实际操作时可能不会自动创建。config.json内容如下。

uni-app使用微信小程序云函数的步骤示例

{
  "permissions": {
    "openapi": [
      "security.msgSecCheck"       //接口名
    ]
  }
}

uni-app使用微信小程序云函数的步骤示例

小程序调用云函数

wx.cloud.init()               //调用前需先调用init
        wx.cloud.callFunction({
          name: 'check',
          data: {
            "content": this.contents.join()
          }
        }).then(res => {
          console.log(res.result)
          if (res.result.code == 300) {
            uni.showModal({
              title: "温馨提示",
              content: "你所输入的内容可能含有违法违规内容,不支持进行下一步操作"
            })
            return
          } else {
            ... // 你要进行的操作
          }
        })

效果展示

uni-app使用微信小程序云函数的步骤示例

如果第一次出现错误:invalid scope 没有权限,请先开通云服务

这是因为 小程序开发选择了云服务开发,但是没有开通云服务导致,点击微信开发工具上方的 云开发按钮,开通云开发。

uni-app使用微信小程序云函数的步骤示例

新建云函数(上床并部署后会自动出现)

uni-app使用微信小程序云函数的步骤示例

到此这篇关于uni-app使用微信小程序云函数的步骤示例的文章就介绍到这了,更多相关uni-app使用微信小程序云函数内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
HTML,CSS,JavaScript速查表推荐
Dec 02 Javascript
js实现鼠标滚轮控制图片缩放效果的方法
Feb 20 Javascript
javascript实现检验的各种规则
Jul 31 Javascript
javascript获取网页各种高宽及位置的方法总结
Jul 27 Javascript
JS正则匹配中文的方法示例
Jan 06 Javascript
js获取隐藏元素的宽高
Feb 24 Javascript
Vue的实例、生命周期与Vue脚手架(vue-cli)实例详解
Dec 27 Javascript
angularJs利用$scope处理升降序的方法
Oct 08 Javascript
vue项目中仿element-ui弹框效果的实例代码
Apr 22 Javascript
jQuery实现弹出层效果
Dec 10 jQuery
vue使用Sass时报错问题的解决方法
Oct 14 Javascript
ES6学习教程之Promise用法详解
Nov 22 Javascript
AutoJs实现刷宝短视频的思路详解
May 22 #Javascript
jquery更改元素属性attr()方法操作示例
May 22 #jQuery
微信小程序转化为uni-app项目的方法示例
May 22 #Javascript
小程序分享链接onShareAppMessage的具体用法
May 22 #Javascript
jquery绑定事件 bind和on的用法与区别分析
May 22 #jQuery
JS变量提升原理与用法实例浅析
May 22 #Javascript
JavaScript直接调用函数与call调用的区别实例分析
May 22 #Javascript
You might like
php while循环得到循环次数
2013/10/26 PHP
JQuery 确定css方框模型(盒模型Box Model)
2010/01/22 Javascript
JavaScript接口实现代码 (Interfaces In JavaScript)
2010/06/11 Javascript
Javascript下判断是否为闰年的Datetime包
2010/10/26 Javascript
Android中资源文件(非代码部分)的使用概览
2012/12/18 Javascript
JS实现图片横向滚动效果示例代码
2013/09/04 Javascript
Jquery getJSON方法详细分析
2013/12/26 Javascript
详解Node.js模块间共享数据库连接的方法
2016/05/24 Javascript
input file上传 图片预览功能实例代码
2016/10/25 Javascript
node中Express 动态设置端口的方法
2017/08/04 Javascript
了解JavaScript表单操作和表单域
2019/05/27 Javascript
jQuery pager.js 插件动态分页功能实例分析
2019/08/02 jQuery
利用Python-iGraph如何绘制贴吧/微博的好友关系图详解
2017/11/02 Python
Python爬虫信息输入及页面的切换方法
2018/05/11 Python
Python调用C++,通过Pybind11制作Python接口
2018/10/16 Python
Python字典循环添加一键多值的用法实例
2019/01/20 Python
python实现雪花飘落效果实例讲解
2019/06/18 Python
解决python xx.py文件点击完之后一闪而过的问题
2019/06/24 Python
python 比较2张图片的相似度的方法示例
2019/12/18 Python
python实现贪吃蛇双人大战
2020/04/18 Python
django 解决自定义序列化返回处理数据为null的问题
2020/05/20 Python
查看keras各种网络结构各层的名字方式
2020/06/11 Python
PyTorch中Tensor的数据类型和运算的使用
2020/09/03 Python
Python+OpenCV图像处理——实现直线检测
2020/10/23 Python
英国豪华真皮和布艺沙发销售网站:Darlings of Chelsea
2018/01/05 全球购物
C#如何允许一个类被继承但是避免这个类的方法被重载?
2015/02/24 面试题
工程业务员工作职责
2013/12/07 职场文书
园林毕业生自我鉴定范文
2013/12/29 职场文书
农民入党思想汇报
2014/01/03 职场文书
优秀班集体获奖感言
2014/02/03 职场文书
团日活动总结书格式
2014/05/08 职场文书
文秘应届生求职信
2014/07/05 职场文书
教师听课评语大全
2014/12/31 职场文书
在redisCluster中模糊获取key方式
2021/07/09 Redis
Lombok的详细使用及优缺点总结
2021/07/15 Java/Android
在HTML中引入CSS的几种方式介绍
2021/12/06 HTML / CSS