每日漏洞 | 跨站請(qǐng)求偽造

01?漏洞描述

HTTP的無狀態(tài)性滤馍,導(dǎo)致Web應(yīng)用程序必須使用會(huì)話機(jī)制來識(shí)別用戶。一旦與Web站點(diǎn)建立連接(訪問配乓、登錄)仿滔,用戶通常會(huì)分配到一個(gè)Cookie,隨后的請(qǐng)求犹芹,都會(huì)帶上這個(gè)Cookie崎页,這樣Web站點(diǎn)就很容易分辨請(qǐng)求來自哪個(gè)用戶,該修改哪個(gè)用戶的數(shù)據(jù)羽莺。如果從第三方發(fā)起對(duì)當(dāng)前站點(diǎn)的請(qǐng)求实昨,該請(qǐng)求也會(huì)帶上當(dāng)前站點(diǎn)的Cookie。正是這是這個(gè)缺陷盐固,導(dǎo)致了CSRF的產(chǎn)生荒给,利用這個(gè)漏洞可以劫持用戶執(zhí)行非意愿的操作。

02?漏洞檢測(cè)

CSRF的利用場(chǎng)景常常是在用戶已登錄的情況下刁卜,偽造用戶意愿從站外發(fā)起請(qǐng)求志电。更深入剖析:請(qǐng)求能從站外發(fā)起(跨站)、請(qǐng)求的參數(shù)和值可以偽造(偽造請(qǐng)求)蛔趴,因此挑辆,CSRF的檢測(cè)也是從這兩點(diǎn)入手。

以轉(zhuǎn)賬為例,輸入賬戶和金額鱼蝉,點(diǎn)擊Transfer即可完成轉(zhuǎn)賬洒嗤。我們檢測(cè)該功能是否存在CSRF。

是否可跨站

要檢測(cè)是否可跨站魁亦,只需要操作請(qǐng)求頭中的referer字段即可渔隶。referer字段記錄了請(qǐng)求的來源,如果請(qǐng)求頭中沒有referer字段洁奈,或者刪掉請(qǐng)求頭中的referer字段间唉,均響應(yīng)成功,那么服務(wù)器就沒有校驗(yàn)請(qǐng)求來源利术,存在“跨站”呈野。

首先正常提交請(qǐng)求包,發(fā)現(xiàn)轉(zhuǎn)賬成功印叁。

我們可以看到請(qǐng)求頭中有個(gè)Referer字段被冒,其中的值表示我們是從哪個(gè)頁面請(qǐng)求過來的。我們?cè)囍鴮eferer字段刪除并再次提交喉钢,查看賬戶余額有沒有變化姆打。

發(fā)現(xiàn)賬戶余額從990變成980,說明服務(wù)器并沒有驗(yàn)證請(qǐng)求來源肠虽,可以“跨站”。

是否可偽造請(qǐng)求

偽造請(qǐng)求的前提是玛追,我們知道如何去偽造請(qǐng)求中的參數(shù)和值税课,也就是說我們知道請(qǐng)求中包含哪些參數(shù),知道參數(shù)的準(zhǔn)確值或者范圍痊剖。因此韩玩,檢測(cè)是否可偽造請(qǐng)求,只需要查看請(qǐng)求中是否有我們無法偽造的參數(shù)和值即可陆馁。

可以看到找颓,請(qǐng)求中有4個(gè)參數(shù),account表示賬號(hào)叮贩,amount表示轉(zhuǎn)賬金額击狮,這兩個(gè)很好偽造,action表示執(zhí)行的動(dòng)作益老,不需要偽造彪蓬,直接使用即可。token是什么東西捺萌?(Token令牌了解一下)

token參數(shù)的值這么長(zhǎng)档冬,一看就知道不好偽造。那刪掉token試試,萬一和referer字段一樣酷誓,服務(wù)器沒有對(duì)token進(jìn)行校驗(yàn)?zāi)亍?/p>

反復(fù)重放了幾次請(qǐng)求披坏,發(fā)現(xiàn)賬戶余額保持不變,很顯然盐数,token參數(shù)必須有棒拂。那我們隨便改一下token的值,看請(qǐng)求中是不是只要有token參數(shù)就行了娘扩,但服務(wù)器并不會(huì)校驗(yàn)token的值着茸。

反復(fù)重放幾次,發(fā)現(xiàn)賬戶余額依然保持不變琐旁,說明服務(wù)器對(duì)Token做了校驗(yàn)涮阔,請(qǐng)求中不能缺失token或token錯(cuò)誤。

正打算放棄的時(shí)候灰殴,無聊的重放著原始請(qǐng)求包敬特,突然發(fā)現(xiàn)賬戶余額變成了900。

WTF牺陶,同一個(gè)token值好像可以反復(fù)使用伟阔,均能通過校驗(yàn),難道這token是永久的掰伸?后來發(fā)現(xiàn)只要不退出重新登錄皱炉,token會(huì)一直有效,了解了狮鸭,這叫“韓式半永久”合搅。

驗(yàn)證CSRF

既能“跨站”,又能偽造請(qǐng)求歧蕉,那CSRF的驗(yàn)證就很簡(jiǎn)單了灾部。重新抓包,利用抓包工具生成CSRF的POC惯退。

復(fù)制其中的HTML代碼赌髓,在本地新建一個(gè)HTML頁面,將復(fù)制的代碼保存其中催跪,然后在同一個(gè)瀏覽器中打開(不懂的請(qǐng)gun去學(xué)習(xí)Cookie方面的知識(shí))锁蠕。


點(diǎn)擊CSRF頁面中的按鈕,發(fā)現(xiàn)會(huì)跳轉(zhuǎn)到轉(zhuǎn)賬頁面叠荠,且賬戶余額只有400匿沛,少了500。?


CSRF的檢測(cè)到此圓滿結(jié)束榛鼎。至于CSRF的利用逃呼,簡(jiǎn)單說兩句鳖孤,可以構(gòu)造一個(gè)鏈接(GET)、隱藏的表單(POST)抡笼、圖片等苏揣,然后想方設(shè)法讓用戶點(diǎn)擊或訪問就可以了。??

03?漏洞修復(fù)

請(qǐng)求來源驗(yàn)證推姻;HTTP請(qǐng)求頭中有個(gè)referer字段平匈,該字段記錄了當(dāng)前HTTP請(qǐng)求的來源〔毓牛可以通過檢查請(qǐng)求是否來自站外增炭,來防御站外發(fā)起的CSRF,但不能防御從站內(nèi)發(fā)起的CSRF拧晕,且存在被繞過的風(fēng)險(xiǎn)隙姿。

Token驗(yàn)證;在請(qǐng)求中添加攻擊者無法預(yù)測(cè)的Token令牌厂捞,當(dāng)請(qǐng)求中缺失Token或Token值不對(duì)時(shí)输玷,則拒絕請(qǐng)求。請(qǐng)使用一次性的Token靡馁,而且記得及時(shí)更新欲鹏,不然還是可以繞過。(這種情況工作中已經(jīng)遇到過無數(shù)次了)

使用圖形驗(yàn)證碼臭墨,但可能會(huì)影響用戶體驗(yàn)赔嚎。

04?PS

我這里舉了一個(gè)既包含referer又包含token的例子,為了讓大家更好的理解CSRF的檢測(cè)胧弛,排版可能會(huì)與實(shí)際情況有些出入尽狠。實(shí)際工作中,我個(gè)人習(xí)慣先多次重放叶圃,看token是否可重復(fù)使用,如果可重復(fù)使用践图,自然不用修改token值或刪除掺冠,只需要檢測(cè)是否可“跨站”即可;如果不能重復(fù)使用码党,說明會(huì)校驗(yàn)token值德崭,那么就不必修改token值,只需直接刪除token試試揖盘,最后再測(cè)試是否可“跨站”眉厨。而且在實(shí)際利用中,token值的獲取沒有這么簡(jiǎn)單兽狭。只是在檢測(cè)過程中憾股,我們發(fā)現(xiàn)token機(jī)制存在缺陷鹿蜀,那我們應(yīng)該防患于未然,將風(fēng)險(xiǎn)降低到零服球。這里簡(jiǎn)要解釋一下文章內(nèi)容與實(shí)際工作中相出入的幾點(diǎn)茴恰。

文章風(fēng)格,盡量簡(jiǎn)單明了斩熊,再以幽默風(fēng)趣的方式給大家介紹漏洞的檢測(cè)往枣。個(gè)人覺得我的校友們應(yīng)該能看懂,如果實(shí)在是忙于做菜和開挖掘機(jī)粉渠,沒時(shí)間看懂分冈,可以在公眾號(hào)里留言,有時(shí)間我就會(huì)回復(fù)霸株。新開的公眾號(hào)雕沉,文章底部暫不支持留言,這個(gè)有點(diǎn)頭疼淳衙。每日漏洞系列需要校友們有一定基礎(chǔ)蘑秽,定位也是定在如何檢測(cè),所以理論的東西不會(huì)介紹太多箫攀,校友們平時(shí)可以適當(dāng)補(bǔ)充理論知識(shí)肠牲,這樣更容易消化每日漏洞的內(nèi)容。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末靴跛,一起剝皮案震驚了整個(gè)濱河市缀雳,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌梢睛,老刑警劉巖肥印,帶你破解...
    沈念sama閱讀 219,110評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異绝葡,居然都是意外死亡深碱,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,443評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門藏畅,熙熙樓的掌柜王于貴愁眉苦臉地迎上來敷硅,“玉大人,你說我怎么就攤上這事愉阎〗时模” “怎么了?”我有些...
    開封第一講書人閱讀 165,474評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵榜旦,是天一觀的道長(zhǎng)幽七。 經(jīng)常有香客問我,道長(zhǎng)溅呢,這世上最難降的妖魔是什么澡屡? 我笑而不...
    開封第一講書人閱讀 58,881評(píng)論 1 295
  • 正文 為了忘掉前任猿挚,我火速辦了婚禮,結(jié)果婚禮上挪蹭,老公的妹妹穿的比我還像新娘亭饵。我一直安慰自己,他們只是感情好梁厉,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,902評(píng)論 6 392
  • 文/花漫 我一把揭開白布辜羊。 她就那樣靜靜地躺著,像睡著了一般词顾。 火紅的嫁衣襯著肌膚如雪八秃。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,698評(píng)論 1 305
  • 那天肉盹,我揣著相機(jī)與錄音昔驱,去河邊找鬼。 笑死上忍,一個(gè)胖子當(dāng)著我的面吹牛骤肛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播窍蓝,決...
    沈念sama閱讀 40,418評(píng)論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼腋颠,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了吓笙?” 一聲冷哼從身側(cè)響起淑玫,我...
    開封第一講書人閱讀 39,332評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎面睛,沒想到半個(gè)月后穿肄,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體羊初,經(jīng)...
    沈念sama閱讀 45,796評(píng)論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,968評(píng)論 3 337
  • 正文 我和宋清朗相戀三年裸影,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了验庙。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片熙兔。...
    茶點(diǎn)故事閱讀 40,110評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡颁股,死狀恐怖嫁审,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情克锣,我是刑警寧澤,帶...
    沈念sama閱讀 35,792評(píng)論 5 346
  • 正文 年R本政府宣布腔长,位于F島的核電站袭祟,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏捞附。R本人自食惡果不足惜巾乳,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,455評(píng)論 3 331
  • 文/蒙蒙 一您没、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧胆绊,春花似錦氨鹏、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,003評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至种冬,卻和暖如春镣丑,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背娱两。 一陣腳步聲響...
    開封第一講書人閱讀 33,130評(píng)論 1 272
  • 我被黑心中介騙來泰國打工莺匠, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人十兢。 一個(gè)月前我還...
    沈念sama閱讀 48,348評(píng)論 3 373
  • 正文 我出身青樓趣竣,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國和親旱物。 傳聞我的和親對(duì)象是個(gè)殘疾皇子遥缕,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,047評(píng)論 2 355

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