首页 > 编程 > JavaScript > 正文

node实现生成带参数的小程序二维码并保存到本地功能示例

2019-11-19 12:24:22
字体:
来源:转载
供稿:网友

本文实例讲述了node实现生成带参数的小程序二维码并保存到本地功能。分享给大家供大家参考,具体如下:

注意:小程序必须要上线才能获取到小程序二维码,否则会报错。。

使用node koa2框架,生成小程序二维码,需要引入两个模块

var requestp = require('request-promise');var fs = require('fs'); // 载入fs模块

通过微信接口,获取小程序二维码,并保存到本地。返回图片名称。

var wxapi = {};module.exports = wxapi;//获取二维码wxapi.qrcode = async (ctx, next) => {  //获取access_token  var access_token = global.access_token  var qrcodeurl = 'https://api.weixin.qq.com/wxa/getwxacode?access_token='+access_token  let options = {    method: 'POST',    uri: qrcodeurl,    encoding:null,    body: {      "path": 'pages/index/index?openid='+ctx.query.openid,//带参数的path      "width":280,      "is_hyaline":false    },    json: true  }  var imgname='./public/images/'+ ctx.query.openid+'.jpg'  var imgnameback=ctx.query.openid+'.jpg'  fs.exists(imgname, function (exists) {    //判断图片是否存在    if(!exists){      //通过微信接口获取小程序码      requestp(options)      .then(function (body) {         var base64Img = body.toString('base64'); // base64图片编码字符串        var dataBuffer = new Buffer(base64Img, 'base64');        //保存到本地        fs.writeFile(imgname, dataBuffer, function(err) {          if(err){            console.log(err);          }else{            console.log("保存成功!");          }        });      })      .catch(function (err) {        console.log(err)      });    }  })  //返回图片名  ctx.body = {    code: 1,    img: imgnameback  }};

PS:这里再为大家推荐两款二维码相关在线工具供大家参考使用:

在线生成二维码工具(加强版)
http://tools.VeVB.COm/transcoding/jb51qrcode

在线二维码解码识别工具
http://tools.VeVB.COm/transcoding/trans_qrcode

希望本文所述对大家nodejs程序设计有所帮助。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表