微信小程序使用npm包的问题和解决方法

使用 sha256

  • 安装:npm i sha256 --production

构建使用后会报错:原因crypto包是node环境的,在小程序不可用;

sha256有自己的实现文件,我的做法就是修改package.json的main入口更改为./lib/sha256.js

重新构建,就可以使用sha256了

使用 bs58

  • 安装:npm i bs58 --production

构建后报错:safe-buffer不存在

解决:

  1. 安装 npm i buffer --production

  2. 修改 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。

使用:

  1. 开启小程序的云服务;

  2. project.config.json写上云函数所在目录"cloudfunctionRoot": "cloudfunctions/"

  3. app.json写上"cloud":true

  4. app.js的onLaunch中写上(这步是将用户访问记录到用户管理中,在控制台中可见);

    if (!wx.cloud) {
     console.error('请使用 2.2.3 或以上的基础库以使用云能力')
    } else {
     wx.cloud.init({
         traceUser: true,
     })
    }
    
  5. 云函数目录右键新建node.js云函数,填写名字,并确认部署;

  6. 进入函数编写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
      }
    }
    
  7. 右键云函数——上传并部署:云端安装依赖(不上传node_modules)

  8. 调用云函数;

    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)
    

你可能感兴趣的:(微信小程序使用npm包的问题和解决方法)