使用 sha256
- 安装:
npm i sha256 --production
构建使用后会报错:原因crypto包是node环境的,在小程序不可用;
sha256有自己的实现文件,我的做法就是修改package.json的main入口更改为
./lib/sha256.js
;重新构建,就可以使用sha256了
使用 bs58
- 安装:
npm i bs58 --production
构建后报错:safe-buffer不存在
解决:
安装
npm i buffer --production
修改 base-x文件夹中的index.js,
var _Buffer = require('safe-buffer').Buffer
替换为var _Buffer = require('buffer').Buffer
重新构建,就可以使用bs58了
使用 rsa-key
- 安装:
npm i rsa-key-es5 --production
直接使用es5版本
tips:
构建出来的js可以拿到相应的分包中,不占据主包的大小;甚至构建完成后你拿完相应的js,可以干掉整个node_modules和构建出来的包。
对于有些在微信小程序不能使用的npm包,可以使用云函数来调用;云函数代码运行在云端 Node.js 中;所以不用怕依赖于node环境的。
云函数
微信小程序官方介绍:云函数
云函数即在云端(服务器端)运行的函数。在物理设计上,一个云函数可由多个文件组成,占用一定量的 CPU 内存等计算资源;各云函数完全独立;可分别部署在不同的地区。开发者无需购买、搭建服务器,只需编写函数代码并部署到云端即可在小程序端调用,同时云函数之间也可互相调用。
一个云函数的写法与一个在本地定义的 JavaScript 方法无异,代码运行在云端 Node.js 中。当云函数被小程序端调用时,定义的代码会被放在 Node.js 运行环境中执行。我们可以如在 Node.js 环境中使用 JavaScript 一样在云函数中进行网络请求等操作,而且我们还可以通过云函数后端 SDK 搭配使用多种服务,比如使用云函数 SDK 中提供的数据库和存储 API 进行数据库和存储的操作,这部分可参考数据库和存储后端 API 文档。
云开发的云函数的独特优势在于与微信登录鉴权的无缝整合。当小程序端调用云函数时,云函数的传入参数中会被注入小程序端用户的 openid,开发者无需校验 openid 的正确性因为微信已经完成了这部分鉴权,开发者可以直接使用该 openid。
使用:
开启小程序的云服务;
project.config.json写上云函数所在目录
"cloudfunctionRoot": "cloudfunctions/"
;app.json写上
"cloud":true
;-
app.js的onLaunch中写上(这步是将用户访问记录到用户管理中,在控制台中可见);
if (!wx.cloud) { console.error('请使用 2.2.3 或以上的基础库以使用云能力') } else { wx.cloud.init({ traceUser: true, }) }
云函数目录右键新建node.js云函数,填写名字,并确认部署;
-
进入函数编写index.js;
// 如果要使用npm包,先在相应的云函数文件夹中 `npm i xxx --production` const cloud = require('wx-server-sdk') exports.main = async (event, context) => { let { userInfo, a, b} = event let { OPENID, APPID } = cloud.getWXContext() // 这里获取到的 openId 和 appId 是可信的 let sum = a + b return { OPENID, APPID, sum } }
右键云函数——上传并部署:云端安装依赖(不上传node_modules)
-
调用云函数;
wx.cloud.callFunction({ // 需调用的云函数名 name: 'add', // 传给云函数的参数 data: { a: 12, b: 19, }, // 成功回调 complete: console.log }) // 当然 promise 方式也是支持的 wx.cloud.callFunction({ name: 'add', data: { a: 12, b: 19 } }).then(console.log)