解決一個(gè)微信號同時(shí)支持多個(gè)環(huán)境網(wǎng)頁授權(quán)問題
項(xiàng)目進(jìn)行微信開發(fā), 認(rèn)證了一個(gè)微信服務(wù)號專門用于內(nèi)部測試,但是內(nèi)部可能存在多套不同環(huán)境(開發(fā)dev、測試sit、預(yù)發(fā)布uat)等,由于微信限制一個(gè)服務(wù)號只能配置一個(gè)網(wǎng)頁授權(quán)域名, 又不可能給每個(gè)環(huán)境單獨(dú)配一個(gè)服務(wù)號,這樣不僅需要成本而且很浪費(fèi)資源, 所以重點(diǎn)需要解決下面這個(gè)問題:
1、可以自動(dòng)區(qū)分環(huán)境。比方部署開發(fā)環(huán)境。url可能是http://dev.xxx.com/api/,而在測試環(huán)境的時(shí)候應(yīng)該是http://sit.xxx.com/api/。而并且不能寫死,否則開發(fā)和測試就要換來換去。非常麻煩
本文總結(jié)分享一下思路:
主要是通過中間頁面代理獲取微信授權(quán)CODE,然后跳轉(zhuǎn)到對應(yīng)需要使用的環(huán)境URL下;
比如原來開發(fā)環(huán)境, 微信中授權(quán)域名配置的是dev.xxx.com,那么現(xiàn)在配置的是一個(gè)代理域名proxy.xxx.com,通過代理域名拿到code后在跳回dev.xxx.com,如下圖所示
代碼片段 getCode.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>微信授權(quán)登錄</title> </head> <body> </body> <script> var code = getPara("code"); if(!code) { var redirect = getPara("url"); var appid = getPara("appid"); var _from = getPara("from"); var redirect_url = encodeURIComponent('https://proxy.xxx.com/getCode.html?url='+redirect); var url = "https://open.weixin.qq.com/connect/oauth2/authorize?appid="+appid+"&redirect_uri=" + redirect_url + "&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect"; location.href = url; }else{ var redirect = getPara("url"); var code = getPara("code"); if(redirect.split('?').length > 1){ location.href = redirect + "&code=" + code; }else{ location.href = redirect + "?code=" + code; } } function getPara(name){ var url = location.href; eval("var reg = /("+name+"=[A-Za-z0-9_,-@!#\.\:\/]*)/i") var match = url.match(reg); if(match && match.length > 1){ var arr = match[0].split("="); arr.shift(); return arr.join('='); }else{ return ""; } } </script> </html>
使用方法https://proxy.xxx.com/getCode.html?url=http://dev.xxx.com/uinfo&appid=wx6d421c188956xx95
總結(jié)
以上所述是小編給大家介紹的解決一個(gè)微信號同時(shí)支持多個(gè)環(huán)境網(wǎng)頁授權(quán)問題呢,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
- 微信公眾號-獲取用戶信息(網(wǎng)頁授權(quán)獲?。?shí)現(xiàn)步驟
- C#實(shí)現(xiàn)的微信網(wǎng)頁授權(quán)操作邏輯封裝示例
- php版微信公眾平臺之微信網(wǎng)頁登陸授權(quán)示例
- MVC微信網(wǎng)頁授權(quán)獲取用戶OpenId
- 微信開發(fā) 網(wǎng)頁授權(quán)獲取用戶基本信息
- VueJs單頁應(yīng)用實(shí)現(xiàn)微信網(wǎng)頁授權(quán)及微信分享功能示例
- PHP實(shí)現(xiàn)微信網(wǎng)頁授權(quán)開發(fā)教程
- 微信公眾平臺網(wǎng)頁授權(quán)獲取用戶基本信息中授權(quán)回調(diào)域名設(shè)置的變動(dòng)
相關(guān)文章
JavaScript中數(shù)組slice和splice的對比小結(jié)
相信對很多學(xué)習(xí)JavaScript語言的人來說,都會經(jīng)常搞不清slice和splice這兩個(gè)方法。它們雖然名稱相似,但是功能卻完全不同。所以這篇文章就給大家詳細(xì)整理了關(guān)于JavaScript中數(shù)組slice和splice的對比,有需要的可以參考學(xué)習(xí)。2016-09-09javascript用DIV模擬彈出窗口_窗體滾動(dòng)跟隨
可滾動(dòng)跟隨彈出框效果代碼,非常實(shí)用的應(yīng)用于網(wǎng)絡(luò)廣告2008-09-09js實(shí)現(xiàn)base64文件的處理以及下載方法
Base64是一種將二進(jìn)制數(shù)據(jù)編碼為ASCII字符的編碼方式,這篇文章主要給大家介紹了關(guān)于js實(shí)現(xiàn)base64文件的處理以及下載的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-07-07JS函數(shù)動(dòng)態(tài)傳遞參數(shù)的方法分析【基于arguments對象】
這篇文章主要介紹了JS函數(shù)動(dòng)態(tài)傳遞參數(shù)的方法,結(jié)合實(shí)例形式分析了javascript通過arguments對象獲取傳遞參數(shù)的相關(guān)操作技巧,需要的朋友可以參考下2019-06-06原生js實(shí)現(xiàn)trigger方法示例代碼
這篇文章主要給大家介紹了關(guān)于利用原生js實(shí)現(xiàn)trigger方法的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用js具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05firefox中用javascript實(shí)現(xiàn)鼠標(biāo)位置的定位
firefox中用javascript實(shí)現(xiàn)鼠標(biāo)位置的定位...2007-06-06