8種網(wǎng)站防止盜鏈的方法

作為普通的網(wǎng)民來(lái)說(shuō)传藏,一般不需要知道也不用關(guān)心什么是盜鏈乾忱,不過(guò)如果你是網(wǎng)站的開(kāi)發(fā)者或維護(hù)者限匣,就不得不重視盜鏈的問(wèn)題了抖苦。如果你剛剛開(kāi)發(fā)完一個(gè)沒(méi)有防盜鏈的帶有文件下載功能的網(wǎng)站,掛上internet米死,然后上傳幾個(gè)時(shí)下非常熱門的軟件或電影并在網(wǎng)站內(nèi)公布下載地址睛约,讓MSN上的所有好友都來(lái)體驗(yàn)一下你的杰作。

不用多久就會(huì)發(fā)現(xiàn)網(wǎng)速出奇地變慢哲身,甚至服務(wù)器托管中心的服務(wù)員會(huì)熱情地打電話告訴你的網(wǎng)站流量很大辩涝,估計(jì)是網(wǎng)站受歡迎起來(lái)了,問(wèn)你是不是該考慮加錢租用帶寬更寬但價(jià)格更貴的網(wǎng)線了勘天。在這個(gè)值得慶祝的時(shí)候趕快打開(kāi)Google Analytics看看有多少人來(lái)光顧你的網(wǎng)站了吧怔揩,如果發(fā)現(xiàn)訪客每天才十來(lái)個(gè)人,很遺憾地告訴你:你的網(wǎng)站資源不幸地被人盜鏈了脯丝。

而且更糟糕的是商膊,當(dāng)你把網(wǎng)站上的文件和電影通通刪光之后,網(wǎng)站仍然沒(méi)有變快多少宠进,從web服務(wù)器的訪問(wèn)日志里會(huì)發(fā)現(xiàn)瘋狂的訪問(wèn)請(qǐng)求正從四面八方涌過(guò)來(lái)晕拆,web服務(wù)器為了迎接這批訪客而沒(méi)有時(shí)間處理正常的頁(yè)面,這種狀況可能會(huì)一直持續(xù)好幾個(gè)周時(shí)間材蹬。

網(wǎng)站資源被盜鏈簡(jiǎn)單來(lái)說(shuō)就是別人不是從你的網(wǎng)站通過(guò)下載資源实幕,被盜鏈的幾種可能情況:

1、人氣非常旺的網(wǎng)站堤器、論壇昆庇、社區(qū)的網(wǎng)頁(yè)里直接引用了(使用標(biāo)記)你網(wǎng)站上的圖片,或者直接在其他網(wǎng)頁(yè)(使用flash或媒體播放插件)里嵌入了你網(wǎng)站上的mp3闸溃。

2整吆、在人氣非常旺的網(wǎng)站、論壇辉川、社區(qū)里提供了你的資源的下載地址表蝙。

3、你網(wǎng)站的資源可能被一些下載軟件列入了“資源候選名單”乓旗,當(dāng)其他人用下載工具下載相同的文件時(shí)府蛇,下載軟件會(huì)自動(dòng)找上門并且從你的服務(wù)器下載。

既然被盜鏈的后果這么可怕寸齐,那有哪些方法可以防止盜鏈呢下面從簡(jiǎn)到繁總結(jié)一下常見(jiàn)的以及自己實(shí)踐過(guò)的一些方法欲诺,并簡(jiǎn)單分析一下抄谐。不過(guò)很遺憾地,這些方法都沒(méi)法完全杜絕被盜鏈扰法,并且防盜鏈的目的應(yīng)該是從一定的程度上減少被盜鏈所產(chǎn)生的影響蛹含,同時(shí)能讓合法的用戶能夠以自然的方式、順暢地從你的網(wǎng)站下載資源塞颁。

方法1:判斷引用地址

這個(gè)方法是最早及最常見(jiàn)的方法浦箱。所謂判斷引用地址,就是判斷瀏覽器請(qǐng)求時(shí)HTTP頭的Referer字段的值祠锣,這個(gè)值在asp.net里面可以用 Request.UrlReferrer屬性取得酷窥。幾個(gè)例子來(lái)說(shuō),在正常情況下當(dāng)用戶在瀏覽 http://uushare.com/abc.html 時(shí)點(diǎn)擊一個(gè)鏈接去到 http://uushare.com/jacky.mp3 文件時(shí)伴网,瀏覽器在發(fā)出請(qǐng)求jacky.mp3 資源時(shí)還會(huì)附帶當(dāng)刻瀏覽器所處的頁(yè)面地址(即http://uushare.com/abc.html)蓬推,所以當(dāng)你的網(wǎng)站程序接收到下載 jacky.mp3 資源請(qǐng)求的時(shí)候,先判斷http的referer字段的值澡腾,如果是從 自己的域名(uushare.com)過(guò)來(lái)的沸伏,則可以認(rèn)為是合法的連接請(qǐng)求,否則就返回一個(gè)錯(cuò)誤的提示信息动分。

這種方法通常用于圖片毅糟、 mp3這種容易被人用html“嵌入”到其他網(wǎng)站的資源,使用這種方法可以防止你的圖片直接出現(xiàn)在別人的網(wǎng)頁(yè)里(或者防止mp3直接被其他網(wǎng)站嵌入到 flash播放器里)澜公,不過(guò)訪客使用下載工具還是可以輕松下載姆另,因?yàn)楝F(xiàn)在的下載工具一般會(huì)自動(dòng)用你的域名構(gòu)造一個(gè)引用地址,所以如果想再進(jìn)一步防范的話坟乾,可以使用一個(gè)對(duì)應(yīng)表限制每個(gè)資源的引用地址迹辐,例如將 jacky.mp3 的引用地址限制為 http://uushare.com/abc.htmlid=12345,這樣下載工具就不太可能構(gòu)造一個(gè)“正確”的引用地址了糊渊。

方法2:使用登錄驗(yàn)證

這個(gè)方法常見(jiàn)于論壇右核、社區(qū)。當(dāng)訪客請(qǐng)求網(wǎng)站上的一個(gè)資源時(shí)渺绒,先判斷此請(qǐng)求是否通過(guò)登錄驗(yàn)證(在asp.net里常用session或form驗(yàn)證來(lái)記錄登錄狀態(tài)),如果尚未登錄則返回一個(gè)錯(cuò)誤提示信息菱鸥。使用這個(gè)方法還可以進(jìn)一步判斷登錄的用戶的權(quán)限是否足夠宗兼,以實(shí)現(xiàn)帶“權(quán)限”的下載。

不過(guò)因?yàn)榈卿洜顟B(tài)依賴于會(huì)話id氮采,而會(huì)話id往往儲(chǔ)存于http請(qǐng)求的cookie字段里殷绍,下載工具一般沒(méi)法獲得瀏覽器的cookie字段,所以這些資源往往無(wú)法使用下載工具來(lái)下載鹊漠,給正常合法用戶帶來(lái)諸多不便(因?yàn)榇蟛糠志W(wǎng)民的系統(tǒng)都安裝了下載工具主到,一點(diǎn)擊下載鏈接一般會(huì)被下載工具攔截茶行,導(dǎo)致無(wú)法使用瀏覽器本身的下載功能)。簡(jiǎn)單的解決方法是將這個(gè)session id放到URL中登钥。

這種方法的另外一個(gè)缺點(diǎn)是訪客無(wú)法匿名下載畔师,所以這個(gè)方法一般只用于論壇和社區(qū)網(wǎng)站。

方法3:使用cookie

其實(shí)這種方法原理上跟方法2差不多牧牢。就是在顯示“下載”鏈接的頁(yè)面里產(chǎn)生一個(gè)動(dòng)態(tài)值的cookie看锉,然后在處理資源下載請(qǐng)求時(shí)先判斷cookie里有沒(méi)有正確的cookie,如果沒(méi)有則返回錯(cuò)誤提示信息塔鳍。至于這個(gè)動(dòng)態(tài)值如何產(chǎn)生伯铣,只要能逆向判斷動(dòng)態(tài)值是否合法的都可以,例如將當(dāng)前的時(shí)間去除秒數(shù)取哈希值(也叫散列值)轮纫。如果網(wǎng)頁(yè)程序是asp.net則更簡(jiǎn)單腔寡,可以往Session里隨便存一個(gè)字符串或數(shù)字,然后在處理下載請(qǐng)求時(shí)先檢查Session 里是否存在這個(gè)字符串或數(shù)字掌唾。使用這個(gè)方法的缺點(diǎn)跟方法2一樣蹬蚁。

方法4:使用POST下載

客戶端瀏覽器請(qǐng)求資源都是使用HTTP的GET方法的,其實(shí)使用POST方法也可以往客戶端返回?cái)?shù)據(jù)郑兴。所以可以將下載鏈接換成一個(gè)表單(Form)和一個(gè)按鈕(Submit)犀斋,將待下載的文件的名稱或id放到表單的一個(gè)隱藏文本框(Input)里,當(dāng)用戶點(diǎn)擊提交按鈕時(shí)情连,服務(wù)程序先判斷請(qǐng)求是否為 POST方式叽粹,如果是則讀取目標(biāo)資源的二進(jìn)制數(shù)據(jù)并寫入響應(yīng)對(duì)象(在asp.net里是respone.BinaryWrite方法)。

使用這個(gè)方法的缺點(diǎn)同樣是無(wú)法使用下載工具却舀,更沒(méi)法實(shí)現(xiàn)斷點(diǎn)續(xù)傳虫几。 不過(guò)比方法2,3好一點(diǎn)的是挽拔,下載工具不會(huì)攔截你的下載動(dòng)作辆脸,所以正常用戶還是比較順暢地下載到文件。這個(gè)方法比較適合小文件的下載螃诅。

方法5:使用圖形驗(yàn)證碼

使用這個(gè)方法可以保證每次下載都是“人”在你的網(wǎng)站上下載啡氢,而不是下載工具。因?yàn)榫W(wǎng)上很多介紹使用圖形驗(yàn)證碼的方法术裸,所以這里就不再重復(fù)了倘是。這個(gè)方法的缺點(diǎn)是比較容易讓正常的用戶感到麻煩。

方法6:使用動(dòng)態(tài)文件名

也叫動(dòng)態(tài)鑰匙法袭艺,當(dāng)用戶點(diǎn)擊一個(gè)下載鏈接時(shí)搀崭,先在程序端計(jì)算一個(gè)Key(使用一定規(guī)律產(chǎn)生的Key,最好不要使用隨機(jī)字符串例如GUID猾编,并且這個(gè) Key必須有一定時(shí)效的)瘤睹,然后在數(shù)據(jù)庫(kù)或Cache里記錄這個(gè)Key以及它所對(duì)應(yīng)的資源ID或文件名升敲,最后讓網(wǎng)頁(yè)重定向一個(gè)新的URL地址,這個(gè)新 URL地址里需要包含這個(gè)Key轰传。當(dāng)瀏覽器或下載工具發(fā)出下載請(qǐng)求時(shí)驴党,程序先檢測(cè)這個(gè)Key是否存在,如果存在則返回對(duì)應(yīng)的資源數(shù)據(jù)绸吸。

使用這個(gè)方法的好處是下載工具也可以下載鼻弧,并且在Key失效前可以斷點(diǎn)續(xù)傳,并且可以通過(guò)Key來(lái)控制下載的線程數(shù)锦茁。

使用這個(gè)方法(包括以上所有支持下載工具的方法)的缺點(diǎn)是:當(dāng)任意一個(gè)用戶下載成功之后攘轩,你的資源就會(huì)被一些下載工具列入“資源候選名單”,以后其他人在其他地方下載同樣的文件時(shí)码俩,下載工具會(huì)不斷連接你的服務(wù)器度帮,即使你的文件已經(jīng)刪除或者Key已經(jīng)失效了,這樣會(huì)造成類DDos攻擊的后果稿存,下面再介紹兩個(gè)即可以讓下載工具下載笨篷,又可以防止盜鏈的方法。

方法7:擅改資源的內(nèi)容

一般熱門的資源都是電影瓣履、mp3率翅、較大的壓縮包等,這些文件都是有很多可以插入數(shù)據(jù)的地方的袖迎,例如mp3有一個(gè)tag區(qū)冕臭,rar/zip有一個(gè)備注區(qū),電影的內(nèi)容隨便一個(gè)地方燕锥,只要在下載過(guò)程當(dāng)中辜贵,動(dòng)態(tài)地往這些地方注入一些隨機(jī)的字節(jié)(幾個(gè)字節(jié)即可),就可以達(dá)到讓整個(gè)文件的哈希值(即散列值归形、指紋值)發(fā)生改變托慨,讓從你網(wǎng)站下載的文件的哈希值跟別人的不一樣,就可以防止下載工具主動(dòng)找上門了暇榴。用這個(gè)方法配合方法6厚棵,可以達(dá)到較好的防盜鏈的效果。缺點(diǎn)是跺撼,雖然文件被修改的部分不會(huì)被“看”窟感、“聽(tīng)”出來(lái),不過(guò)多多少少讓知道的人覺(jué)得不爽歉井。另外就是如果別人把從你網(wǎng)站下載的文件放到其他網(wǎng)站,那么仍然存在下載工具主動(dòng)找上門的情況(雖然實(shí)際上它下載不了內(nèi)容)哈误。

方法8:打包下載

這個(gè)方法跟方法7的道理是一樣的哩至,只不過(guò)這次不是往原始文件里修改躏嚎,而是在原始的文件基礎(chǔ)上再加個(gè)“外殼”,讓資源的哈希值跟別人的不一樣菩貌。使用這個(gè)方法可以在不擅改資源原始的內(nèi)容基礎(chǔ)上實(shí)現(xiàn)方法6同樣的效果卢佣,并且狠一點(diǎn)的話,甚至可以在打包的時(shí)候放入自己的一些廣告箭阶。缺點(diǎn)是用戶每次下載都得加壓縮虚茶,不過(guò)目前大部分人都懂得解壓,所以這個(gè)缺點(diǎn)有時(shí)可以忽略不計(jì)仇参。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末嘹叫,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子诈乒,更是在濱河造成了極大的恐慌罩扇,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,378評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件怕磨,死亡現(xiàn)場(chǎng)離奇詭異喂饥,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)肠鲫,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,356評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門员帮,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人导饲,你說(shuō)我怎么就攤上這事捞高。” “怎么了帜消?”我有些...
    開(kāi)封第一講書人閱讀 152,702評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵棠枉,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我泡挺,道長(zhǎng)辈讶,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 55,259評(píng)論 1 279
  • 正文 為了忘掉前任娄猫,我火速辦了婚禮贱除,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘媳溺。我一直安慰自己月幌,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,263評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布悬蔽。 她就那樣靜靜地躺著扯躺,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上录语,一...
    開(kāi)封第一講書人閱讀 49,036評(píng)論 1 285
  • 那天倍啥,我揣著相機(jī)與錄音,去河邊找鬼澎埠。 笑死虽缕,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的蒲稳。 我是一名探鬼主播氮趋,決...
    沈念sama閱讀 38,349評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼江耀!你這毒婦竟也來(lái)了剩胁?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 36,979評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤决记,失蹤者是張志新(化名)和其女友劉穎摧冀,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體系宫,經(jīng)...
    沈念sama閱讀 43,469評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡索昂,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,938評(píng)論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了扩借。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片椒惨。...
    茶點(diǎn)故事閱讀 38,059評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖潮罪,靈堂內(nèi)的尸體忽然破棺而出康谆,到底是詐尸還是另有隱情,我是刑警寧澤嫉到,帶...
    沈念sama閱讀 33,703評(píng)論 4 323
  • 正文 年R本政府宣布沃暗,位于F島的核電站,受9級(jí)特大地震影響何恶,放射性物質(zhì)發(fā)生泄漏孽锥。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,257評(píng)論 3 307
  • 文/蒙蒙 一细层、第九天 我趴在偏房一處隱蔽的房頂上張望惜辑。 院中可真熱鬧,春花似錦疫赎、人聲如沸盛撑。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 30,262評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)抵卫。三九已至狮荔,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間陌僵,已是汗流浹背轴合。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工创坞, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留碗短,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,501評(píng)論 2 354
  • 正文 我出身青樓题涨,卻偏偏與公主長(zhǎng)得像偎谁,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子纲堵,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,792評(píng)論 2 345

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

  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理巡雨,服務(wù)發(fā)現(xiàn),斷路器席函,智...
    卡卡羅2017閱讀 134,599評(píng)論 18 139
  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,510評(píng)論 25 707
  • 小時(shí)候铐望,里面有新衣服和壓歲錢 長(zhǎng)大了,里面有我的彩禮錢 后來(lái)茂附,爸爸走了 只有媽媽和箱子了 箱子正蛙,不知不覺(jué) 變得銹跡...
    天山之鷹閱讀 157評(píng)論 0 3
  • (廬山戀) 文/菊 鄱湖闊, 百里起煙波营曼。 春夏水深魚擊浪乒验, 秋冬枯草雁鵝窩。 群鳥互歡歌蒂阱。 【詞林正韻】第九部....
    斌之志閱讀 723評(píng)論 32 21
  • 你是我的小仙女 那個(gè)最美的小仙女 多么的希望 你在的地方 歡聲锻全、笑語(yǔ) 自由自在 陽(yáng)光、燦爛 無(wú)拘無(wú)束 有你的地方 ...
    身后一扇窗閱讀 130評(píng)論 0 0