微信公眾號網(wǎng)頁授權(quán)失敗


點(diǎn)擊訪問原文
您還可以加入全棧技術(shù)交流群(QQ群號:254842154)


問題

今天同事在調(diào)試微信公眾號網(wǎng)頁授權(quán)時(shí)号阿,發(fā)現(xiàn)一個(gè)非常詭異的問題迁沫。當(dāng)scope為snsapi_base時(shí)芦瘾,可以正常授權(quán),當(dāng)scope為snsapi_userinfo時(shí)集畅,無法授權(quán)近弟,出現(xiàn)空白頁面。

解決過程

首先可以排除接口權(quán)限的問題挺智,因?yàn)?code>snsapi_base和snsapi_userinfo需要的權(quán)限是一樣的祷愉。也可以排除是微信sdk的問題,所以還是從自身找問題。通過后臺(tái)調(diào)試二鳄,把授權(quán)頁面的地址打印出來是這樣子的:

//把下面url中的scope=snsapi_userinfo 改為 scope=snsapi_base可以正常授權(quán)

https://open.weixin.qq.com/connect/oauth2/authorize?appId=wx87cf9295e2eeba97&redirect_uri=http%3A%2F%2Fapi.fellowplus.com%2Fexam%2F&response_type=code&scope=snsapi_userinfo&state=STATE&connect_redirect=1#wechat_redirect

對比官網(wǎng)wiki文章迫摔,同事肉眼對比鏈接沒有發(fā)現(xiàn)任何問題。后來我表示不服泥从,決定肉眼再觀察一遍句占,終于發(fā)現(xiàn) appId 中的字母I應(yīng)該是小寫的。改成小寫后測試通過躯嫉。OMG纱烘,又是linux的大小寫問題。

非常簡單的一個(gè)低級錯(cuò)誤祈餐,一方面暴露了我們自己的不嚴(yán)謹(jǐn)擂啥,沒有嚴(yán)格按照微信官方的wiki來做,忽略了url參數(shù)中的大小寫問題帆阳;另外一方面哺壶,也反映出微信的不厚道,同樣都是大寫的字母I蜒谤,為什么snsapi_base的授權(quán)模式是可以的山宾,而snsapi_userinfo不行呢,我猜可能是前者在獲取appid這個(gè)參數(shù)時(shí)鳍徽,會(huì)統(tǒng)一轉(zhuǎn)換成小寫资锰,而snsapi_userinfo時(shí)沒有做這個(gè)操作。導(dǎo)致微信授權(quán)服務(wù)接收不到appid這個(gè)參數(shù)阶祭。此時(shí)绷杜,微信應(yīng)該報(bào)一個(gè)類似于獲取appid失敗這樣的錯(cuò)誤的,可是并沒有濒募,而是停留在授權(quán)頁面無法跳轉(zhuǎn)到用戶的redirect_uri鞭盟,用戶看到的表現(xiàn)就是空白頁面。微信這樣做可能是出于安全考慮吧瑰剃。

假如在網(wǎng)頁授權(quán)時(shí)有類似的空白頁出現(xiàn)齿诉,可以從我剛剛提供的思路去查看,是否有類似的大小寫問題培他。

其他問題

在做網(wǎng)頁授權(quán)時(shí)鹃两,經(jīng)常會(huì)遇到的一個(gè)其他問題是提示:redirect_uri參數(shù)錯(cuò)誤。出現(xiàn)這個(gè)問題的原因通常都是沒有在接口權(quán)限表中修改OAuth2.0網(wǎng)頁授權(quán)的授權(quán)回調(diào)頁面域名舀凛,或者填寫在域名前面多加了http或者https

工具

在開發(fā)微信公眾號時(shí)俊扳,可以申請測試號來體驗(yàn),它擁有大部分高級權(quán)限(除微信支付之外)猛遍。在公眾號處于申請階段馋记,用這個(gè)測試號來開發(fā)是非常棒的号坡!
http://mp.weixin.qq.com/debug/cgi-bin/sandboxinfo?action=showinfo&t=sandbox/index

另外,給大家推薦一個(gè)github上非常實(shí)用的微信公眾號開發(fā)sdk梯醒,它對微信公眾號的sdk做了二次封裝宽堆,包括緩存access_token等處理,目前有php版本的茸习。https://github.com/dodgepudding/wechat-php-sdk

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末畜隶,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子号胚,更是在濱河造成了極大的恐慌籽慢,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,723評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件猫胁,死亡現(xiàn)場離奇詭異箱亿,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)弃秆,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評論 2 382
  • 文/潘曉璐 我一進(jìn)店門届惋,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人菠赚,你說我怎么就攤上這事脑豹。” “怎么了锈至?”我有些...
    開封第一講書人閱讀 152,998評論 0 344
  • 文/不壞的土叔 我叫張陵晨缴,是天一觀的道長。 經(jīng)常有香客問我峡捡,道長,這世上最難降的妖魔是什么筑悴? 我笑而不...
    開封第一講書人閱讀 55,323評論 1 279
  • 正文 為了忘掉前任们拙,我火速辦了婚禮,結(jié)果婚禮上阁吝,老公的妹妹穿的比我還像新娘砚婆。我一直安慰自己,他們只是感情好突勇,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,355評論 5 374
  • 文/花漫 我一把揭開白布装盯。 她就那樣靜靜地躺著,像睡著了一般甲馋。 火紅的嫁衣襯著肌膚如雪埂奈。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,079評論 1 285
  • 那天定躏,我揣著相機(jī)與錄音账磺,去河邊找鬼芹敌。 笑死,一個(gè)胖子當(dāng)著我的面吹牛垮抗,可吹牛的內(nèi)容都是我干的氏捞。 我是一名探鬼主播,決...
    沈念sama閱讀 38,389評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼冒版,長吁一口氣:“原來是場噩夢啊……” “哼液茎!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起辞嗡,我...
    開封第一講書人閱讀 37,019評論 0 259
  • 序言:老撾萬榮一對情侶失蹤捆等,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后欲间,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體楚里,經(jīng)...
    沈念sama閱讀 43,519評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,971評論 2 325
  • 正文 我和宋清朗相戀三年猎贴,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了班缎。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,100評論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡她渴,死狀恐怖达址,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情趁耗,我是刑警寧澤沉唠,帶...
    沈念sama閱讀 33,738評論 4 324
  • 正文 年R本政府宣布,位于F島的核電站苛败,受9級特大地震影響满葛,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜罢屈,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,293評論 3 307
  • 文/蒙蒙 一嘀韧、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧缠捌,春花似錦锄贷、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,289評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至哑芹,卻和暖如春炎辨,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背绩衷。 一陣腳步聲響...
    開封第一講書人閱讀 31,517評論 1 262
  • 我被黑心中介騙來泰國打工蹦魔, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留激率,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,547評論 2 354
  • 正文 我出身青樓勿决,卻偏偏與公主長得像乒躺,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子低缩,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,834評論 2 345

推薦閱讀更多精彩內(nèi)容