赞
踩
POST https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=ACCESS_TOKEN
scene 必传 // 这个就是你需要通过页面传的参数
page 非必传 // 默认就是主页 例如 pages/index/index,
//根路径前不要填加 /,不能携带参数
//(参数请放在scene字段里),如果不填写这个字段,默认跳主页面
还有别的参数可以看文档根据实际需求添加
GET https://api.weixin.qq.com/cgi-bin/token
三个必填参数
// 获取 access_token
getAccessToken(){
uni.request({
method: "GET",
url: `https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=${appid}&secret=${secret}`,
success:(result) =>{
let access_token = result.data.access_token
// 获取到 access_token 后 获取二维码
this.getQrCode(access_token)
}
})
}
// 获取二维码
getQrCode(token){
// 注意 access_token 参数是必须放在url后面 其余参数 要在data里面
let path = 'pages/index/index'
uni.request({
method: "POST",
responseType: 'arraybuffer', // 注意一定要加 不然返回的Buffer流会乱码 导致无法转base64
url: `https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=${token}`,
data: {
page: path, // 需要打开的页面路径
scene: this.userid // 这个是需要传递的参数
},
success:(result) =>{
// 拿到buffer流 通过wx.arrayBufferToBase64 转成base64 在页面展示
// 如果不加请求时 responseType: 'arraybuffer' 则会转码失败
this.bufferImg = "data:image/png;base64," + wx.arrayBufferToBase64(result.data);
},
})
}
// template 部分
<image :src="bufferImg" style="width: 200px;height: 200px"></image>
saveAlbum() { //获取权限保存相册
uni.getSetting({ //获取用户的当前设置
success: (res) => {
// console.log("获取权限",res);
if (res.authSetting['scope.writePhotosAlbum']) { //验证用户是否授权可以访问相册
this.saveImageToPhotosAlbum();
} else {
uni.authorize({ //如果没有授权,向用户发起请求
scope: 'scope.writePhotosAlbum',
success: () => {
this.saveImageToPhotosAlbum();
},
fail: () => {
uni.showToast({
title: "请打开保存相册权限,再点击保存相册分享",
icon: "none",
duration: 3000
});
setTimeout(() => {
uni.openSetting({ //调起客户端小程序设置界面,让用户开启访问相册
success: (res2) => {
// console.log(res2.authSetting)
}
});
}, 3000);
}
})
}
}
})
},
saveImageToPhotosAlbum() {
// 下面注释掉的是把base64 去掉头部,我们可以直接使用没有添加头的数据 所以就可以不用再去转
// this.maskData=this.bufferImg.replace(/^data:image\/\w+;BASE64,/, "");//去掉data:image/png;base64,
// 保存图片的名字 可以写死 也可以写成动态的
let filePath = wx.env.USER_DATA_PATH + `/qrcode.png`;
uni.getFileSystemManager().writeFile({
filePath: filePath, //创建一个临时文件名
data: this.maskData, //写入的文本或二进制数据
encoding: 'base64', //写入当前文件的字符编码
success: res => {
uni.saveImageToPhotosAlbum({
filePath: filePath,
success: function(res2) {
uni.showToast({
title: '保存成功,请从相册选择再分享',
icon: "none",
duration: 5000
})
},
fail: function(err) {
// console.log(err.errMsg);
}
})
},
fail: err => {
//console.log(err)
}
})
},
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。