做過好幾次微信開發(fā)了;每一次都會(huì)遇到不同的坑,這一次只是總結(jié)一下教訓(xùn),寫給自己的,希望如果對(duì)你們有幫助的話,希望給個(gè)贊;
項(xiàng)目需求
項(xiàng)目原來是有php進(jìn)行開發(fā)的,php內(nèi)嵌html,這樣是快速的開發(fā)了,但是,
對(duì)內(nèi)部文件的保密性太差;這是改造項(xiàng)目的根本原因;
1:將后臺(tái)改為java進(jìn)行處理;但是因?yàn)榍捌谇昂笕藛T進(jìn)行任務(wù)劃分的不明確
導(dǎo)致后期開發(fā),遇到各種"坑";我們認(rèn)為java可以處理用戶的登陸問題;但是這一次,
確實(shí)沒有成功;
2:對(duì)微信訂閱號(hào)和微信服務(wù)號(hào)接口功能的認(rèn)識(shí)不足,導(dǎo)致時(shí)間浪費(fèi);
1:微信公眾號(hào)登陸和網(wǎng)頁授權(quán)問題
首先,大家應(yīng)該清楚,在進(jìn)行微信公眾號(hào)的時(shí)候,有的會(huì)提醒大家進(jìn)行確認(rèn)登錄,但是有的公眾號(hào)沒有提醒,但是確實(shí)能夠保存,大家之間進(jìn)行操作的信息; 這是微信服務(wù)號(hào)給大家提供的兩種網(wǎng)頁授權(quán)方式; a:靜默授權(quán);當(dāng)你進(jìn)入公眾號(hào),但是沒有提醒你確認(rèn)等咯的時(shí)候,該服務(wù)號(hào)進(jìn)行了靜默授權(quán); b:如果彈出了"確認(rèn)登陸"的操作框的時(shí)候;是使用了微信的第二種授權(quán)方式; 個(gè)人總結(jié):這兩種的授權(quán)方式;是存在用戶信息完整度的區(qū)別;不用說,大家也能知道;肯定是第二種授權(quán)方式,獲取的用戶信息更詳細(xì);這個(gè)需要根據(jù)不同的需求進(jìn)行選擇;
- 1:接下來我要說的進(jìn)行網(wǎng)頁授權(quán)的過程;詳細(xì)過程大家請(qǐng)參照微信開發(fā)文檔;我在這里要寫的就是我自己遇到的一些問題
如果用戶在微信客戶端中訪問第三方網(wǎng)頁脑溢,公眾號(hào)可以通過微信網(wǎng)頁授權(quán)機(jī)制饮醇,來獲取用戶基本信息澎粟,進(jìn)而實(shí)現(xiàn)業(yè)務(wù)邏輯筐赔。
第一步:用戶同意授權(quán),獲取code 在確保微信公眾賬號(hào)擁有授權(quán)作用域(scope參數(shù))的權(quán)限的前提下(服務(wù)號(hào)獲得高級(jí)接口后,默認(rèn)擁有scope參數(shù)中的snsapi_base和snsapi_userinfo),引導(dǎo)關(guān)注者打開如下頁面:https://open.weixin.qq.com/connect/oauth2/authorize?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect
我想在這說的就是redirect_uri參數(shù)的問題;先說一下這個(gè)鏈接吧,這個(gè)鏈接的根本目是獲取code,要注意的問題就是appID,一定是服務(wù)號(hào)的appid,如果報(bào)scope沒有權(quán)限,或者關(guān)于scope問題;就很有可能就是這個(gè)id的問題;這個(gè)id沒有必需是這個(gè)功能要上的id,可以是另外一個(gè)服務(wù)號(hào)的ID;但是id和對(duì)應(yīng)的應(yīng)用秘鑰還有安全域名接口對(duì)應(yīng)的秘鑰txt,文件一定要相對(duì)應(yīng),不能再不同的公眾對(duì)應(yīng)的項(xiàng);
這個(gè)鏈接可以解釋為;經(jīng)過用戶點(diǎn)擊相應(yīng)這個(gè)鏈接之后,微信會(huì)進(jìn)行redirect_uri回調(diào),并且會(huì)在攜帶code在回調(diào)鏈接的后面;所以相應(yīng)的redirect_uri后面的鏈接地址就是我們要讓微信指向的連接地址;其中,我處理的是對(duì)我們自己的連接地址進(jìn)行encodeURIComponent("這里面放我們自己鏈接地址");函數(shù)處理;接下來按照衛(wèi)星給的方式進(jìn)行拼接;當(dāng)成功進(jìn)行連接回調(diào)的時(shí)候;這個(gè)時(shí)候盡可以進(jìn)入第二步了;
- 2:第二步:獲取openid;
通過code換取網(wǎng)頁授權(quán)access_token 首先請(qǐng)注意,這里通過code換取的是一個(gè)特殊的網(wǎng)頁授權(quán)access_token,與基礎(chǔ)支持中的access_token(該access_token用于調(diào)用其他接口)不同柳爽。公眾號(hào)可通過下述接口來獲取網(wǎng)頁授權(quán)access_token。如果網(wǎng)頁授權(quán)的作用域?yàn)閟nsapi_base碱屁,則本步驟中獲取到網(wǎng)頁授權(quán)access_token的同時(shí)磷脯,<em>也獲取到了openid</em>,snsapi_base式的網(wǎng)頁授權(quán)流程即到此為止娩脾。
這個(gè)功能我們最后協(xié)商的結(jié)果是使用php進(jìn)行openid的獲取.java具體可不可以還真不知道,這個(gè)我會(huì)繼續(xù)驗(yàn)證;
接下來只需要運(yùn)行下面的代碼進(jìn)行了;當(dāng)然相應(yīng)的php依賴文件還是要引入的;這個(gè)在微信開發(fā)文檔中,JS-SDK;中有關(guān)于php還有node的demo;直接拿來用就行;
php代碼如下:
$code = $_GET['code'];//獲取code $weixin= file_get_contents("[https://api.weixin.qq.com/sns/oauth2/access_token?appid=](https://api.weixin.qq.com/sns/oauth2/access_token?appid=)這里是你的APPID&secret=這里是你的SECRET&code=".$code."&grant_type=authorization_code");//通過code換取網(wǎng)頁授權(quán)access_token $jsondecode = json_decode($weixin); //對(duì)JSON格式的字符串進(jìn)行編碼 $array = get_object_vars($jsondecode);//轉(zhuǎn)換成數(shù)組 $openid = $array['openid'];//輸出openid
然后接下來前端人員,要做的就是通過ajax,將openid傳給后臺(tái);'<? php echo $openid;?>'