互聯(lián)網(wǎng)視頻防盜鏈的研究(referer,Token防盜鏈)

一.盜鏈的定義:

某內(nèi)容不在自己服務(wù)器上春瞬,而通過技術(shù)手段,繞過別人放廣告有利益的最終頁操刀,直接在自己的有廣告有利益的頁面上向最終用戶提供此內(nèi)容摔刁。 常常是一些名不見經(jīng)傳的小網(wǎng)站來盜取一些有實力的大網(wǎng)站的地址(比如一些音樂、圖片净蚤、軟件的下載地址)然后放置在自己的網(wǎng)站中钥组,通過這種方法盜取大網(wǎng)站的空間和流量。內(nèi)容不在自己服務(wù)器上今瀑,而通過技術(shù)手段程梦,繞過別人放廣告有利益的最終頁,直接在自己的有廣告有利益的頁面上向最終用戶提供此內(nèi)容橘荠。 常常是一些名不見經(jīng)傳的小網(wǎng)站來盜取一些有實力的大網(wǎng)站的地址(比如一些音樂屿附、圖片、軟件的下載地址)然后放置在自己的網(wǎng)站中哥童,通過這種方法盜取大網(wǎng)站的空間和流量挺份。

二.某視防盜鏈:

1.Referer防盜鏈(央視網(wǎng)H5采用referer防盜鏈+token防盜鏈)

什么是referer?Referer是HTTP協(xié)議中request header的一部分贮懈,當(dāng)瀏覽器向web服務(wù)器發(fā)送請求的時候匀泊,一般會帶上Referer,告訴服務(wù)器我是從哪個頁面鏈接過來的朵你,服務(wù)器基此可以獲得一些信息用于處理各聘。如果refer信息不是來自本站,就阻止訪問或者跳到其它鏈接抡医。

我對某視網(wǎng)的H5進行了抓包躲因,發(fā)現(xiàn)其采用了referer防盜鏈:

referer驗證過程抓包

不妨推測一下某視網(wǎng)referer防盜鏈的流程:

第一步:b_match進行referer驗證,成功訪問返回btime和bauth的信息魂拦,然后將btime和bauth通過b_mattching的進行referer驗證毛仪,通過繼續(xù)訪問,不通過返回error芯勘,箱靴。

我將b.matching的url復(fù)制到瀏覽器進行了驗證,即空referer的情況荷愕,charles截圖如下:

空referer的request截圖

請求返回結(jié)果如下圖:

由此可見衡怀,對referer的判斷可以起到防盜鏈的作用。但是安疗,refer防盜鏈易于破解抛杨,大大降低了防盜鏈的作用。

第二步荐类,b.matching通過驗證會返回一個tag怖现,然后請求vdn,解析獲取視頻的原始url,然后把原始url作為參數(shù)進行new_url請求(參數(shù)還有btime屈嗤,bauth以及referer):

請求返回新的url潘拨,response截圖·如下:

第三步,用新的url請求CDN

還有一種UA防盜鏈饶号,也叫做客戶端白名單铁追,依據(jù)就是User Agent字段,其原理和referer防盜鏈類似茫船。UA 防盜鏈通常用在手機 APP 或者一些可自定義 User Agent 的應(yīng)用琅束。User agent和referer一樣,易于偽造算谈。

2.Token防盜鏈(時間戳防盜鏈)

什么是token防盜鏈涩禀?Token防盜鏈通過對時間有關(guān)的字符串進行簽名,將時間濒生,簽名信息通過一定的方式傳遞給CDN節(jié)點服務(wù)器作為判斷依據(jù)埋泵,CDN 節(jié)點則會根據(jù) URL 的加密形式幔欧,取出對應(yīng)的過期時間罪治,和當(dāng)前服務(wù)器時間進行比較,確認請求是否過期礁蔗,過期的話觉义,則直接拒絕;如果時間未過期浴井,CDN 節(jié)點將根據(jù)約定的簽名算法和密文晒骇,計算后的值和 URL 中的原始加密串進行比較;通過之后磺浙,請求會被認為是合法的洪囤。不合法的請求可以采取禁止訪問或其他操作。

1)客戶端業(yè)務(wù)服務(wù)器生成驗證信息撕氧,驗證信息的生成由業(yè)務(wù)服務(wù)器負責(zé)瘤缩,具體的加密過程需要確認如下事項:

a.確認過期時間的格式,默認采用UNIX時間戳格式

b.確認驗證信息中的密文伦泥,用戶計算驗證信息剥啤,需要和 CDN 平臺約定

c.確認驗證信息時加入的參數(shù),默認為 URL 的路徑部分

d.根據(jù)上文的算法說明計算驗證信息不脯,其中請求 URL 中的驗證參數(shù)為 _upt

2CDN節(jié)點驗證過程

a.根據(jù)約定解析取出過期時間府怯,和當(dāng)前 CDN 節(jié)點服務(wù)器時間進行比較,確認請求是否過期

b.根據(jù)上文約定好的算法計算方式防楷,計算出 MD5 加密串后牺丙,和 URL 中的加密串進行比較,驗證加密串是否一致

c.如果以上兩個步驟都驗證通過复局,請求才會被認為是合法的冲簿,這時 CDN 會請求資源響應(yīng)給客戶端是整,否則會被認為是非法請求,直接響應(yīng) HTTP status code 403民假。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末浮入,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子羊异,更是在濱河造成了極大的恐慌事秀,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,755評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件野舶,死亡現(xiàn)場離奇詭異易迹,居然都是意外死亡,警方通過查閱死者的電腦和手機平道,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評論 3 395
  • 文/潘曉璐 我一進店門睹欲,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人一屋,你說我怎么就攤上這事窘疮。” “怎么了冀墨?”我有些...
    開封第一講書人閱讀 165,138評論 0 355
  • 文/不壞的土叔 我叫張陵闸衫,是天一觀的道長。 經(jīng)常有香客問我诽嘉,道長蔚出,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,791評論 1 295
  • 正文 為了忘掉前任虫腋,我火速辦了婚禮骄酗,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘悦冀。我一直安慰自己趋翻,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,794評論 6 392
  • 文/花漫 我一把揭開白布雏门。 她就那樣靜靜地躺著嘿歌,像睡著了一般。 火紅的嫁衣襯著肌膚如雪茁影。 梳的紋絲不亂的頭發(fā)上宙帝,一...
    開封第一講書人閱讀 51,631評論 1 305
  • 那天,我揣著相機與錄音募闲,去河邊找鬼步脓。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的靴患。 我是一名探鬼主播仍侥,決...
    沈念sama閱讀 40,362評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼鸳君!你這毒婦竟也來了农渊?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,264評論 0 276
  • 序言:老撾萬榮一對情侶失蹤或颊,失蹤者是張志新(化名)和其女友劉穎砸紊,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體囱挑,經(jīng)...
    沈念sama閱讀 45,724評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡醉顽,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,900評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了平挑。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片游添。...
    茶點故事閱讀 40,040評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖通熄,靈堂內(nèi)的尸體忽然破棺而出唆涝,到底是詐尸還是另有隱情,我是刑警寧澤棠隐,帶...
    沈念sama閱讀 35,742評論 5 346
  • 正文 年R本政府宣布石抡,位于F島的核電站,受9級特大地震影響助泽,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜嚎京,卻給世界環(huán)境...
    茶點故事閱讀 41,364評論 3 330
  • 文/蒙蒙 一嗡贺、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧鞍帝,春花似錦诫睬、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,944評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至蚓曼,卻和暖如春亲澡,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背纫版。 一陣腳步聲響...
    開封第一講書人閱讀 33,060評論 1 270
  • 我被黑心中介騙來泰國打工床绪, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 48,247評論 3 371
  • 正文 我出身青樓癞己,卻偏偏與公主長得像膀斋,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子痹雅,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,979評論 2 355

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