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 相关文章推荐
JavaScript NaN和Infinity特殊值 [译]
Sep 20 Javascript
js+css实现增加表单可用性之提示文字
Jun 03 Javascript
JavaScript中的Math 使用介绍
Apr 21 Javascript
js获取当前日期时间及其它日期操作汇总
Mar 08 Javascript
Bootstrap教程JS插件滚动监听学习笔记分享
May 18 Javascript
Highcharts入门之简介
Aug 02 Javascript
简单实现jquery焦点图
Dec 12 Javascript
4个顶级开源JavaScript图表库
Sep 29 Javascript
vue 中 elment-ui table合并上下两行相同数据单元格
Dec 26 Javascript
使用Element的InfiniteScroll 无限滚动组件报错的解决
Jul 27 Javascript
JavaScript canvas实现跟随鼠标移动小球
Feb 09 Javascript
实现AJAX异步调用和局部刷新的基本步骤
Mar 17 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和ACCESS写聊天室(五)
2006/10/09 PHP
简单解决新浪SAE无法上传文件的问题
2015/05/13 PHP
利用PHP自动生成印有用户信息的名片
2016/08/01 PHP
PHP实现负载均衡下的session共用功能
2018/04/17 PHP
页面只能打开一次Cooike如何实现
2012/12/04 Javascript
js操作iframe兼容各种主流浏览器示例代码
2013/07/22 Javascript
原生js实现改变随意改变div属性style的名称和值的结果
2013/09/26 Javascript
用javascript对一个json数组深度赋值示例
2014/07/27 Javascript
JS实现鼠标滑过折叠与展开菜单效果代码
2015/09/06 Javascript
JavaScript学习笔记之检测客户端类型是(引擎、浏览器、平台、操作系统、移动设备)
2015/12/03 Javascript
javascript从定义到执行 你不知道的那些事
2016/01/04 Javascript
javascript 实现动态侧边栏实例详解
2016/11/11 Javascript
Angular.js实现动态加载组件详解
2017/05/28 Javascript
详解nodeJS之路径PATH模块
2017/05/31 NodeJs
原生js jquery ajax请求以及jsonp的调用方法
2017/08/04 jQuery
javascript 通过键名获取键盘的keyCode方法
2017/12/31 Javascript
使用vue官方提供的模板vue-cli搭建一个helloWorld案例分析
2018/01/16 Javascript
puppeteer实现html截图的示例代码
2019/01/10 Javascript
jquery实现动态创建form并提交的方法示例
2019/05/27 jQuery
ES6 Promise对象的应用实例分析
2019/06/27 Javascript
微信小程序实现点击卡片 翻转效果
2019/09/04 Javascript
vue 使用localstorage实现面包屑的操作
2020/11/16 Javascript
vue element和nuxt的使用技巧分享
2021/01/14 Vue.js
用Python的Flask框架结合MySQL写一个内存监控程序
2015/11/07 Python
python-web根据元素属性进行定位的方法
2019/12/13 Python
python线性插值解析
2020/07/05 Python
巧用CSS3 border实现图片遮罩效果代码
2012/04/09 HTML / CSS
CSS3动画:5种预载动画效果实例
2017/04/05 HTML / CSS
介绍一下grep命令的使用
2012/06/28 面试题
高级护理专业大学生求职信
2013/10/24 职场文书
经销商培训邀请函
2014/01/21 职场文书
法人授权委托书
2014/09/16 职场文书
师德标兵事迹材料
2014/12/19 职场文书
学习心理学心得体会
2016/01/22 职场文书
导游词之襄阳古城
2019/09/27 职场文书
如何用PHP websocket实现网页实时聊天
2021/05/26 PHP