如何利用unicloud生成微信小程序分享碼
一,方案
看了官方的文檔,獲取小程序碼有三種,我采用的是第二種:生成數(shù)量不受限制的分享碼。
對(duì)應(yīng)的官方文檔:https://developers.weixin.qq.com/miniprogram/dev/OpenApiDoc/qrcode-link/qr-code/getUnlimitedQRCode.html
其中又分為https調(diào)用和云開發(fā)調(diào)用。
因?yàn)槲矣玫氖莡nicloud云開發(fā),如果采用微信的云開發(fā),還需要引入wx-server-sdk,然后要配置一堆東西,文檔又不全,嘗試了兩次未果,就放棄了這種方案。
最后是采用的https調(diào)用的方式。
二,實(shí)現(xiàn)思路
【第一步】需要獲取ACCESS_TOKEN值。
這種微信的接口,必須服務(wù)端調(diào)用,不能前端直接https進(jìn)行調(diào)用。雖然在開發(fā)階段能夠調(diào)用成功,那是因?yàn)槲⑿砰_發(fā)者工具-項(xiàng)目信息-本地設(shè)置中勾選了不校驗(yàn)合法域名導(dǎo)致的成功。當(dāng)你發(fā)布體驗(yàn)版和正式版時(shí)是調(diào)用不通的。
所以,獲取ACCESS_TOKEN必須在服務(wù)端直接調(diào)用微信接口獲取。
實(shí)現(xiàn)的云對(duì)象代碼:
// 云對(duì)象教程: https://uniapp.dcloud.net.cn/uniCloud/cloud-obj // jsdoc語(yǔ)法提示教程:https://ask.dcloud.net.cn/docs/#//ask.dcloud.net.cn/article/129 module.exports = { _before: function () { // 通用預(yù)處理器 }, async addCodeInfo(infoObj){ //獲取access_token const APPID='xxx' const APPSECRET='xxx' const URL = `https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=${APPID}&secret=${APPSECRET}` const requestOptions = { method: 'GET', dataType: 'json' } const res1 = await uniCloud.httpclient.request(URL,requestOptions) const access_token=res1.data.access_token return access_token } }
【第二步】需要利用ACCESS_TOKEN再調(diào)用微信的生成分享碼的接口
這個(gè)接口依舊是微信的接口,所以依舊是需要在服務(wù)端發(fā)起。
于是,在上一步獲取到access_token的基礎(chǔ)上,繼續(xù)調(diào)用獲取分享碼的接口:
// 云對(duì)象教程: https://uniapp.dcloud.net.cn/uniCloud/cloud-obj // jsdoc語(yǔ)法提示教程:https://ask.dcloud.net.cn/docs/#//ask.dcloud.net.cn/article/129 module.exports = { _before: function () { // 通用預(yù)處理器 }, //數(shù)據(jù)庫(kù)中增加wifi信息,增加完畢后返回分享二維碼 async addCodeInfo(infoObj){ //獲取access_token const APPID='wxe0bc57edf31dad80' const APPSECRET='7e5f676a5fad20d044434792360c28d4' const URL = `https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=${APPID}&secret=${APPSECRET}` const requestOptions = { method: 'GET', dataType: 'json' } const res1 = await uniCloud.httpclient.request(URL,requestOptions) const access_token=res1.data.access_token //由此id生成分享碼 const codeUrl=`https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=${access_token}` const codeOptions={ method:'POST', data: JSON.stringify({ "scene":'id', "page":'pages/index/index', "check_path":false, "width":500, "env_version":'trial'//trial:體驗(yàn)版 }), } const res3 = await uniCloud.httpclient.request(codeUrl,codeOptions) return res3 } }
【第三步】獲取到的分享碼結(jié)果類型是buffer的二進(jìn)制格式,需要轉(zhuǎn)圖片
如下圖:
也就是,res.data是個(gè)buffer類型的數(shù)據(jù),它有兩個(gè)字段:data字段存儲(chǔ)內(nèi)容,type字段顯示類型。
于是需要在服務(wù)端轉(zhuǎn)成base64后再傳給前端:
const buffer=res3.data const result=buffer.toString('base64')
三,完整的代碼實(shí)現(xiàn)
前端
<img :src="shareCode" alt="" > <script> export default { data() { return { shareCode:'', } }, onLoad(options) { this.getWeixinCode() }, methods: { //調(diào)用后端接口,生成小程序分享碼 async getWeixinCode() { // 注意異步 const _this=this const wifiCode = uniCloud.importObject('wifiCode') // 導(dǎo)入云對(duì)象 try { const params={} const res=await wifiCode.addCodeInfo(params) console.log("++++",res) this.shareCode="data:image/png;base64," + res } catch (e) { console.log(e) } } } } </script>
后端:
主要就是wifiCode這個(gè)云對(duì)象:
// 云對(duì)象教程: https://uniapp.dcloud.net.cn/uniCloud/cloud-obj // jsdoc語(yǔ)法提示教程:https://ask.dcloud.net.cn/docs/#//ask.dcloud.net.cn/article/129 module.exports = { _before: function () { // 通用預(yù)處理器 }, //數(shù)據(jù)庫(kù)中增加wifi信息,增加完畢后返回分享二維碼 async addCodeInfo(infoObj){ //獲取access_token const APPID='xxx' const APPSECRET='xxx' const URL = `https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=${APPID}&secret=${APPSECRET}` const requestOptions = { method: 'GET', dataType: 'json' } const res1 = await uniCloud.httpclient.request(URL,requestOptions) const access_token=res1.data.access_token //由此id生成分享碼 const codeUrl=`https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=${access_token}` const codeOptions={ method:'POST', data: JSON.stringify({ "scene":"23", "page":'pages/index/index', "check_path":false, "width":500, "env_version":'trial'//trial:體驗(yàn)版 }), } const res3 = await uniCloud.httpclient.request(codeUrl,codeOptions) const buffer=res3.data console.log("---響應(yīng)--",buffer) // const buf = new Buffer (buffer) console.log("buffer轉(zhuǎn)化",buffer.toString('base64')) const result=buffer.toString('base64') return result } }
四,坑點(diǎn)
1,微信的接口需要服務(wù)端調(diào)用
2,獲取分享碼的接口的post接口參數(shù)需要JSON.stringify處理一次
3,scenez只支持32位,一些特殊字符還不支持。
4,獲取分享碼的接口的access_token參數(shù),必須放在url上,也就是和我代碼中一樣的寫法。
5,本地開發(fā)完成后,云對(duì)象啥的需要上傳部署后,體驗(yàn)版和真機(jī)調(diào)試才能用。并且,需要配置小程序的接口白名單。https://tcb-api.tencentcloudapi.com和
https://tcb-wbk382fznzzwna3-8chuc14d8e99.service.tcloudbase.com
6,獲取分享碼的接口,返回的是buffer二進(jìn)制流,所以獲取二維碼的接口,我沒有配置datatype這個(gè)參數(shù),而是讓它采用默認(rèn)的值。獲取到結(jié)果后還需要轉(zhuǎn)化成base64才可以渲染在頁(yè)面上。
總而言之,比較坑,但是我沒哭。
吶,就這樣吧~
總結(jié)
到此這篇關(guān)于如何利用unicloud生成微信小程序分享碼的文章就介紹到這了,更多相關(guān)unicloud生成微信小程序分享碼內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
javascript中new Array()和var arr=[]用法區(qū)別
給大家分析一下在javascript中數(shù)組函數(shù)new Array()和var arr=[]用法區(qū)別,一起跟著學(xué)習(xí)一下吧。2017-12-12數(shù)組Array進(jìn)行原型prototype擴(kuò)展后帶來(lái)的for in遍歷問題
不同的程序語(yǔ)言都有多種循環(huán)語(yǔ)句,而且功能是差不多的,當(dāng)然使用場(chǎng)合還是有些區(qū)別的,比如for與for in,for in比較好用,它不需要預(yù)先知道對(duì)象屬性的長(zhǎng)度。2010-02-02JS實(shí)現(xiàn)的簡(jiǎn)潔二級(jí)導(dǎo)航菜單雛形效果
這篇文章主要介紹了JS實(shí)現(xiàn)的簡(jiǎn)潔二級(jí)導(dǎo)航菜單雛形效果,通過簡(jiǎn)單的JavaScript響應(yīng)鼠標(biāo)事件遍歷頁(yè)面元素實(shí)現(xiàn)二級(jí)導(dǎo)航菜單切換的效果,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2015-10-10ionic開發(fā)中點(diǎn)擊input時(shí)鍵盤自動(dòng)彈出
ionic開發(fā)移動(dòng)端界面時(shí),在輸入用戶名和密碼的時(shí)候,輸入法不要擋住我的輸入框,并且輸入框往上滾動(dòng)的時(shí)候,頂部標(biāo)題不要上移,下面給大家分享實(shí)現(xiàn)代碼,一起看看吧2016-12-12Javascript 事件捕獲的備忘(setCapture,captureEvents)
Javascript 事件捕獲的備忘(setCapture,captureEvents)...2006-09-09