webview收不到服務(wù)端的cookie

昨天項(xiàng)目中碰到了一個(gè)bug,我們的客戶(hù)端webview加載了我們的一個(gè)新聞詳情頁(yè)些膨,在詳情頁(yè)里面發(fā)表一條評(píng)論,但是刷新頁(yè)面后钦铺,剛才發(fā)表的評(píng)論卻沒(méi)有顯示在評(píng)論列表里订雾。

第一直覺(jué),用其他的瀏覽器試試這一流程矛洞,發(fā)現(xiàn)沒(méi)有問(wèn)題洼哎。

這就奇怪了,難道是webview的設(shè)置有問(wèn)題嗎?但是因?yàn)椴恢佬侣勗u(píng)論這個(gè)功能的前端后端邏輯,隨便修改webview的設(shè)置只能是盲人摸象噩峦,亂改一通锭沟,就算改好了可能也不知道為什么這樣改就可以了。

本著科(zhuang)學(xué)(bi)的精(yu)神(wang)识补,我先仔細(xì)想了想幾個(gè)可能導(dǎo)致bug的疑點(diǎn):

  1. 使用了網(wǎng)頁(yè)緩存族淮,所以導(dǎo)致沒(méi)有看到新的評(píng)論
  2. 發(fā)表的評(píng)論上傳失敗了
  3. 請(qǐng)求評(píng)論列表出現(xiàn)錯(cuò)誤

一開(kāi)始以為使用的緩存頁(yè)面,所以沒(méi)有刷出來(lái)評(píng)論李请,可用fiddler抓包發(fā)現(xiàn)2個(gè)現(xiàn)象:

  1. 發(fā)表評(píng)論的時(shí)候瞧筛,ajax請(qǐng)求返回的json,errorcode=0导盅,這說(shuō)明上傳評(píng)論是成功的较幌;
  2. 刷新頁(yè)面確實(shí)重新請(qǐng)求了評(píng)論列表,返回的json白翻,errorcode=0乍炉,說(shuō)明請(qǐng)求列表也是成功的,但是居然不包含剛剛發(fā)的評(píng)論滤馍!

抓包可以說(shuō)明兩件事:

  1. 基本可以排除是本地緩存導(dǎo)致的問(wèn)題
  2. 極有可能是后端出了問(wèn)題

所以找了下后端的開(kāi)發(fā)岛琼,了解了下評(píng)論邏輯。上傳的評(píng)論一般都需要審核(人工審核)巢株,但是為了能在審核之前讓用戶(hù)可以馬上看到自己剛發(fā)表的評(píng)論(防止以為是個(gè)bug)槐瑞,所以在服務(wù)端把剛評(píng)論的message種到了cookie里面,只要拿到cookie就可以顯示出評(píng)論了阁苞。

然而抓包過(guò)程中困檩,并沒(méi)有發(fā)現(xiàn)服務(wù)端發(fā)送任何cookie,查了很久那槽,終于發(fā)現(xiàn)最終的原因:

Apps that target KITKAT or below default to allowing third party cookies. Apps targeting LOLLIPOP or later default to disallowing third party cookies.

在A(yíng)ndroid 4.4及以下的系統(tǒng)悼沿,webview是默認(rèn)接收第三方cookie的。但是骚灸,從android 5.0開(kāi)始糟趾,webview默認(rèn)是不接受第三方cookie的。

我們的服務(wù)端和頁(yè)面剛好不在同一個(gè)域里面甚牲,而我的測(cè)試機(jī)是android 6.0的义郑,所以導(dǎo)致接受不到cookie。
既然知道了根源丈钙,也就好解決了魔慷,接收第三方cookie的開(kāi)關(guān)是:

if(Build.VERSION.SDK_INT > Build.VERSION_CODES.KITKAT) { 
     CookieManager.getInstance().setAcceptThirdPartyCookies(mWebView,true);
}

另外,注意到第一個(gè)參數(shù)是webview著恩,說(shuō)明這個(gè)設(shè)置不是全局的院尔,這一點(diǎn)android官網(wǎng)也做了說(shuō)明

Allowing third party cookies is a per WebView policy and can be set differently on different WebView instances.

所以蜻展,如果新建了一個(gè)webview,這個(gè)webview默認(rèn)還是不接收第三方cookie的邀摆,這點(diǎn)要特別注意!

感謝您的耐心閱讀纵顾,以上如果有錯(cuò)誤的地方或者理解有失偏頗,請(qǐng)留言指正栋盹,謝謝~~

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末施逾,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子例获,更是在濱河造成了極大的恐慌汉额,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,884評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件榨汤,死亡現(xiàn)場(chǎng)離奇詭異蠕搜,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)收壕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,755評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)妓灌,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人蜜宪,你說(shuō)我怎么就攤上這事虫埂。” “怎么了圃验?”我有些...
    開(kāi)封第一講書(shū)人閱讀 158,369評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵掉伏,是天一觀(guān)的道長(zhǎng)。 經(jīng)常有香客問(wèn)我澳窑,道長(zhǎng)斧散,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,799評(píng)論 1 285
  • 正文 為了忘掉前任照捡,我火速辦了婚禮,結(jié)果婚禮上话侧,老公的妹妹穿的比我還像新娘栗精。我一直安慰自己,他們只是感情好瞻鹏,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,910評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布悲立。 她就那樣靜靜地躺著,像睡著了一般新博。 火紅的嫁衣襯著肌膚如雪薪夕。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 50,096評(píng)論 1 291
  • 那天赫悄,我揣著相機(jī)與錄音原献,去河邊找鬼馏慨。 笑死,一個(gè)胖子當(dāng)著我的面吹牛姑隅,可吹牛的內(nèi)容都是我干的写隶。 我是一名探鬼主播,決...
    沈念sama閱讀 39,159評(píng)論 3 411
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼讲仰,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼慕趴!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起鄙陡,我...
    開(kāi)封第一講書(shū)人閱讀 37,917評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤冕房,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后趁矾,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體耙册,經(jīng)...
    沈念sama閱讀 44,360評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,673評(píng)論 2 327
  • 正文 我和宋清朗相戀三年愈魏,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了觅玻。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,814評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡培漏,死狀恐怖溪厘,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情牌柄,我是刑警寧澤畸悬,帶...
    沈念sama閱讀 34,509評(píng)論 4 334
  • 正文 年R本政府宣布,位于F島的核電站珊佣,受9級(jí)特大地震影響蹋宦,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜咒锻,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,156評(píng)論 3 317
  • 文/蒙蒙 一冷冗、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧惑艇,春花似錦蒿辙、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,882評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至恭取,卻和暖如春泰偿,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背蜈垮。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,123評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工耗跛, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留裕照,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,641評(píng)論 2 362
  • 正文 我出身青樓课兄,卻偏偏與公主長(zhǎng)得像牍氛,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子烟阐,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,728評(píng)論 2 351

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

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,871評(píng)論 25 707
  • afinalAfinal是一個(gè)android的ioc搬俊,orm框架 https://github.com/yangf...
    passiontim閱讀 15,412評(píng)論 2 45
  • 相關(guān)類(lèi)介紹 WebResourceRequest添加于A(yíng)PI21,封裝了一個(gè)Web資源的請(qǐng)求信息蜒茄,包含:請(qǐng)求地址唉擂,...
    愛(ài)碼士閱讀 853評(píng)論 0 5
  • 上午睡太多,導(dǎo)致還是沒(méi)法按計(jì)劃睡著 所以去看了微博一個(gè)博主的timeline 善良有時(shí)候真的是刻在臉上的檀葛。 并且如...
    六六六六六六六六六閱讀 93評(píng)論 0 0
  • 守陵衛(wèi) 通向陵墓的神道 無(wú)字碑:碑上的題字眾多玩祟,其中有契丹文題寫(xiě)的碑文十分珍貴。 明朝人想要表達(dá)“……到此一游” ...
    北辰維特和伯羅奔尼撒閱讀 588評(píng)論 0 0