8種網站防止盜鏈的方法

来源:https://www.cnblogs.com/zmdComeOn/archive/2019/01/22/10302455.html
-Advertisement-
Play Games

作為普通的網民來說,一般不需要知道也不用關心什麼是盜鏈,不過如果你是網站的開發者或維護者,就不得不重視盜鏈的問題了。如果你剛剛開發完一個沒有防盜鏈的帶有文件下載功能的網站,掛上internet,然後上傳幾個時下非常熱門的軟體或電影併在網站內公佈下載地址,讓MSN上的所有好友都來體驗一下你的傑作。 不 ...


作為普通的網民來說,一般不需要知道也不用關心什麼是盜鏈,不過如果你是網站的開發者或維護者,就不得不重視盜鏈的問題了。如果你剛剛開發完一個沒有防盜鏈的帶有文件下載功能的網站,掛上internet,然後上傳幾個時下非常熱門的軟體或電影併在網站內公佈下載地址,讓MSN上的所有好友都來體驗一下你的傑作。

不用多久就會發現網速出奇地變慢,甚至伺服器托管中心的服務員會熱情地打電話告訴你的網站流量很大,估計是網站受歡迎起來了,問你是不是該考慮加錢租用帶寬更寬但價格更貴的網線了。在這個值得慶祝的時候趕快打開Google Analytics看看有多少人來光顧你的網站了吧,如果發現訪客每天才十來個人,很遺憾地告訴你:你的網站資源不幸地被人盜鏈了。

而且更糟糕的是,當你把網站上的文件和電影通通刪光之後,網站仍然沒有變快多少,從web伺服器的訪問日誌里會發現瘋狂的訪問請求正從四面八方涌過來,web伺服器為了迎接這批訪客而沒有時間處理正常的頁面,這種狀況可能會一直持續好幾個周時間。

網站資源被盜鏈簡單來說就是別人不是從你的網站通過下載資源,被盜鏈的幾種可能情況:

1、人氣非常旺的網站、論壇、社區的網頁里直接引用了(使用標記)你網站上的圖片,或者直接在其他網頁(使用flash或媒體播放插件)里嵌入了你網站上的mp3。

2、在人氣非常旺的網站、論壇、社區里提供了你的資源的下載地址。

3、你網站的資源可能被一些下載軟體列入了“資源候選名單”,當其他人用下載工具下載相同的文件時,下載軟體會自動找上門並且從你的伺服器下載。

既然被盜鏈的後果這麼可怕,那有哪些方法可以防止盜鏈呢下麵從簡到繁總結一下常見的以及自己實踐過的一些方法,並簡單分析一下。不過很遺憾地,這些方法都沒法完全杜絕被盜鏈,並且防盜鏈的目的應該是從一定的程度上減少被盜鏈所產生的影響,同時能讓合法的用戶能夠以自然的方式、順暢地從你的網站下載資源。

方法1:判斷引用地址

這個方法是最早及最常見的方法。所謂判斷引用地址,就是判斷瀏覽器請求時HTTP頭的Referer欄位的值,這個值在asp.net裡面可以用 Request.UrlReferrer屬性取得。幾個例子來說,在正常情況下當用戶在瀏覽 http://uushare.com/abc.html 時點擊一個鏈接去到 http://uushare.com/jacky.mp3 文件時,瀏覽器在發出請求jacky.mp3 資源時還會附帶當刻瀏覽器所處的頁面地址(即http://uushare.com/abc.html),所以當你的網站程式接收到下載 jacky.mp3 資源請求的時候,先判斷http的referer欄位的值,如果是從 自己的功能變數名稱(uushare.com)過來的,則可以認為是合法的連接請求,否則就返回一個錯誤的提示信息。

這種方法通常用於圖片、 mp3這種容易被人用html“嵌入”到其他網站的資源,使用這種方法可以防止你的圖片直接出現在別人的網頁里(或者防止mp3直接被其他網站嵌入到 flash播放器里),不過訪客使用下載工具還是可以輕鬆下載,因為現在的下載工具一般會自動用你的功能變數名稱構造一個引用地址,所以如果想再進一步防範的話,可以使用一個對應表限制每個資源的引用地址,例如將 jacky.mp3 的引用地址限製為 http://uushare.com/abc.htmlid=12345,這樣下載工具就不太可能構造一個“正確”的引用地址了。

方法2:使用登錄驗證

這個方法常見於論壇、社區。當訪客請求網站上的一個資源時,先判斷此請求是否通過登錄驗證(在asp.net里常用session或form驗證來記錄登錄狀態),如果尚未登錄則返回一個錯誤提示信息。使用這個方法還可以進一步判斷登錄的用戶的許可權是否足夠,以實現帶“許可權”的下載。

不過因為登錄狀態依賴於會話id,而會話id往往儲存於http請求的cookie欄位里,下載工具一般沒法獲得瀏覽器的cookie欄位,所以這些資源往往無法使用下載工具來下載,給正常合法用戶帶來諸多不便(因為大部分網民的系統都安裝了下載工具,一點擊下載鏈接一般會被下載工具攔截,導致無法使用瀏覽器本身的下載功能)。簡單的解決方法是將這個session id放到URL中。
這種方法的另外一個缺點是訪客無法匿名下載,所以這個方法一般只用於論壇和社區網站。

方法3:使用cookie

其實這種方法原理上跟方法2差不多。就是在顯示“下載”鏈接的頁面里產生一個動態值的cookie,然後在處理資源下載請求時先判斷cookie里有沒有正確的cookie,如果沒有則返回錯誤提示信息。至於這個動態值如何產生,只要能逆向判斷動態值是否合法的都可以,例如將當前的時間去除秒數取哈希值(也叫散列值)。如果網頁程式是asp.net則更簡單,可以往Session里隨便存一個字元串或數字,然後在處理下載請求時先檢查Session 里是否存在這個字元串或數字。使用這個方法的缺點跟方法2一樣。

方法4:使用POST下載

客戶端瀏覽器請求資源都是使用HTTP的GET方法的,其實使用POST方法也可以往客戶端返回數據。所以可以將下載鏈接換成一個表單(Form)和一個按鈕(Submit),將待下載的文件的名稱或id放到表單的一個隱藏文本框(Input)里,當用戶點擊提交按鈕時,服務程式先判斷請求是否為 POST方式,如果是則讀取目標資源的二進位數據並寫入響應對象(在asp.net里是respone.BinaryWrite方法)。

使用這個方法的缺點同樣是無法使用下載工具,更沒法實現斷點續傳。 不過比方法2,3好一點的是,下載工具不會攔截你的下載動作,所以正常用戶還是比較順暢地下載到文件。這個方法比較適合小文件的下載。

方法5:使用圖形驗證碼

使用這個方法可以保證每次下載都是“人”在你的網站上下載,而不是下載工具。因為網上很多介紹使用圖形驗證碼的方法,所以這裡就不再重覆了。這個方法的缺點是比較容易讓正常的用戶感到麻煩。

方法6:使用動態文件名

也叫動態鑰匙法,當用戶點擊一個下載鏈接時,先在程式端計算一個Key(使用一定規律產生的Key,最好不要使用隨機字元串例如GUID,並且這個 Key必須有一定時效的),然後在資料庫或Cache里記錄這個Key以及它所對應的資源ID或文件名,最後讓網頁重定向一個新的URL地址,這個新 URL地址里需要包含這個Key。當瀏覽器或下載工具發出下載請求時,程式先檢測這個Key是否存在,如果存在則返回對應的資源數據。

使用這個方法的好處是下載工具也可以下載,並且在Key失效前可以斷點續傳,並且可以通過Key來控制下載的線程數。

使用這個方法(包括以上所有支持下載工具的方法)的缺點是:當任意一個用戶下載成功之後,你的資源就會被一些下載工具列入“資源候選名單”,以後其他人在其他地方下載同樣的文件時,下載工具會不斷連接你的伺服器,即使你的文件已經刪除或者Key已經失效了,這樣會造成類DDos攻擊的後果,下麵再介紹兩個即可以讓下載工具下載,又可以防止盜鏈的方法。

方法7:擅改資源的內容

一般熱門的資源都是電影、mp3、較大的壓縮包等,這些文件都是有很多可以插入數據的地方的,例如mp3有一個tag區,rar/zip有一個備註區,電影的內容隨便一個地方,只要在下載過程當中,動態地往這些地方註入一些隨機的位元組(幾個位元組即可),就可以達到讓整個文件的哈希值(即散列值、指紋值)發生改變,讓從你網站下載的文件的哈希值跟別人的不一樣,就可以防止下載工具主動找上門了。用這個方法配合方法6,可以達到較好的防盜鏈的效果。缺點是,雖然文件被修改的部分不會被“看”、“聽”出來,不過多多少少讓知道的人覺得不爽。另外就是如果別人把從你網站下載的文件放到其他網站,那麼仍然存在下載工具主動找上門的情況(雖然實際上它下載不了內容)。

方法8:打包下載

這個方法跟方法7的道理是一樣的,只不過這次不是往原始文件里修改,而是在原始的文件基礎上再加個“外殼”,讓資源的哈希值跟別人的不一樣。使用這個方法可以在不擅改資源原始的內容基礎上實現方法6同樣的效果,並且狠一點的話,甚至可以在打包的時候放入自己的一些廣告。缺點是用戶每次下載都得加壓縮,不過目前大部分人都懂得解壓,所以這個缺點有時可以忽略不計。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • html代碼 css代碼 js代碼 效果圖 ...
  • from:http://visjs.org/timeline_examples.html https://github.com/almende/vis https://github.com/moment/moment/ https://momentjs.com/ ...
  • 數組是js中最常用到的數據集合,其內置的方法有很多,熟練掌握這些方法,可以有效的提高我們的工作效率,同時對我們的代碼質量也是有很大影響。本文所有的慄子都是在es7環境下測試的,如果有問題歡迎留言交流 創建數組 我將創建數組的方式分為以下四大類 一、字面量方式 使用對象字面量方式創建數組是我們最常用的 ...
  • Quill是一個很流行的富文本編輯器,github上star大約21k: github:https://github.com/quilljs/quill/ 官網: https://quilljs.com/ 使用 下載: vue中使用: 效果 創建Quill實例需要兩個參數,container與opt ...
  • 首先,ES6 的 class 屬於一種“語法糖”,所以只是寫法更加優雅,更加像面對對象的編程,其思想和 ES5 是一致的。 function Point(x, y) { this.x = x; this.y = y; } Point.prototype.toString = function() { ...
  • if (window.performance) { console.info("window.performance is supported"); console.log(performance.navigation.type) } ...
  • 一、 主要知識點:html佈局,css變換,js事件觸發 二.CSS屬性記憶: CSS規則:子元素會繼承父元素的佈局屬性。不專本改變子元素的屬性,其會跟隨父元素。 功能 語句 margin 外邊距 Padding 內邊距 關於文本的水平居中為: text-align: center; 關於文本的垂直 ...
  • 1. 博客皮膚選擇 SimpleMemory 因為簡單,所以愛~ 2. 在”頁面定製CSS代碼“中填入以下內容 重要提示:側邊欄藍色風格,有的模塊可能遺漏,需要請自行在CSS樣式中的“側邊欄”加上對應DIV的id或者class 3. 在“首頁Html代碼”中填入以下內容: 說明:此樣式非首創,收集了 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...