node實現生成帶參數的小程序二維碼并保存到本地功能示例
更新時間:2018年12月05日 10:13:42 作者:包子源
這篇文章主要介紹了node實現生成帶參數的小程序二維碼并保存到本地功能,涉及nodejs模塊引用、接口調用、編碼轉換、圖片生成等相關操作技巧,需要的朋友可以參考下
本文實例講述了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.jb51.net/transcoding/jb51qrcode
在線二維碼解碼識別工具
http://tools.jb51.net/transcoding/trans_qrcode
希望本文所述對大家nodejs程序設計有所幫助。
相關文章
nodejs 圖解express+supervisor+ejs的用法(推薦)
下面小編就為大家?guī)硪黄猲odejs 圖解express+supervisor+ejs的用法(推薦)。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09

