我们使用微信官方提供的接口getwxacode
获取了微信小程序二维码,但是,获取的二进制图片无论如何都没法展示出来。
调用微信官方接口的方法为:使用Nodejs包request,调用方法为;
// 获取小程序二维码
async queryQRCode(access_token: string) {
try {
return new Promise(async (resolve, reject) => {
const params = {
path: 'pages/card/index',
}
const url = `https://api.weixin.qq.com/wxa/getwxacode?access_token=${access_token}`
request({
url: `https://api.weixin.qq.com/wxa/getwxacode?access_token=${access_token}`,
method: 'post',
body: JSON.stringify(params),
// encoding: null,
}, async function(error, response, body) {
let data = body
var base64Img = "data:image/png;base64," + data.toString('base64'); // base64图片编码字符串
resolve(base64Img)
})
})
} catch(e) {
console.log(e)
}
}
刚开始,我们转base64的方式进行展示,图片展示不了。使用的如下方式:
let data = body
let base64Img = "data:image/png;base64," + data.toString('base64'); // base64图片编码字符串
后面,我们又将二进制保存成为图片,同样是展示不了。使用的方式如下:
fs.writeFile('test_wx.png', data, function(err) {
console.log('err', err)
}) // 保存成图片
发现还是展示不了。
最后,发现是因为request会自动对返回的结果进行encoding。所以,我们只需要在request时,添加encoding: null
即可。最终的实现方式如下:
// 获取小程序二维码
async queryQRCode(access_token: string) {
try {
return new Promise(async (resolve, reject) => {
const params = {
path: 'pages/card/index',
}
const url = `https://api.weixin.qq.com/wxa/getwxacode?access_token=${access_token}`
request({
url: `https://api.weixin.qq.com/wxa/getwxacode?access_token=${access_token}`,
method: 'post',
body: JSON.stringify(params),
// encoding: null,
}, async function(error, response, body) {
let data = body
var base64Img = "data:image/png;base64," + data.toString('base64'); // base64图片编码字符串
resolve(base64Img)
})
})
} catch(e) {
console.log(e)
}
}
完美解决。