国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 網(wǎng)站 > Apache > 正文

使用Apache打造完美限制的HTTP下載服務(wù)器

2024-08-27 18:26:21
字體:
供稿:網(wǎng)友

一開始本來準(zhǔn)備選擇使用FTP作為下載服務(wù)器的,不過過了幾天就發(fā)現(xiàn)很多都是通過盜鏈的方式來FTP下載。這下服務(wù)器在持續(xù)性全速提供上傳,但是網(wǎng)站的頁面瀏覽量卻少得可憐。因為FTP天生不能放盜鏈的特性所以只能考慮放棄使用,最后決定用HTTP下載來替代。

   直接用HTTP服務(wù)器下載也不是很容易的事。最開始在IIS里面配置,IIS只能設(shè)定最大下載速度和最大連接數(shù),這對于一些使用下載工具一來就開50+線程霸道下載的朋友明顯是防不住的。網(wǎng)上搜了N久就發(fā)現(xiàn)一個用Delphi寫的看不懂的ISAPI Filter以及別的收費軟件若干。試過之后都起不了作用,也便放棄了,最后發(fā)現(xiàn)Apache有這些開源的功能模塊,最終打造出完美限制的HTTP下載服務(wù)器。

首先說說完美限制的意思:防盜鏈、限制客戶端下載線程數(shù),限制下載帶寬。下面一一介紹怎么在Apache里面實現(xiàn)這些功能。

   防盜鏈

   傳統(tǒng)的防盜鏈都是通過Referer來判斷用戶來路的,不過這樣的方法對于下載工具來說形同虛設(shè),因為現(xiàn)在的下載工具早就能偽造Referer了。

   現(xiàn)在一些流行的防盜鏈的方式都是用在瀏覽頁面的時候產(chǎn)生一個隨機驗證碼,在用戶點擊連接的時候服務(wù)器會驗證這個驗證碼是否有效從而決定是否允許下載。或者就是用某些方法把文件實際地址進(jìn)行偽裝。不過我覺得這些都不怎么好用,我用了一個簡單有效的方式來實現(xiàn)防盜鏈。

   其實就是用Cookie,配合Apache的URL Rewrite模塊很簡單的就能實現(xiàn)防盜鏈下載。
   首先在瀏覽頁面的時候,會向客戶端發(fā)送一個特別的Cookie,例如“Site=3grjz.com“,盜鏈而來的將沒有這個Cookie。

   在Apache的httpd.conf文件里面搜索:

   #LoadModule rewrite_module modules/mod_rewrite.so

  把它前面的#去掉,再找到<Directory />塊,在里面加入類似如下代碼:

復(fù)制代碼 代碼如下:

   <Directory />
  # Other configurations …
  RewriteEngine On   # 啟動URL Rewrite引擎
   RewriteCond   %{HTTP_COOKIE} !^.*(?:Site=3grjz.com).*$   # 對于Cookie里面沒有特殊記錄的請求進(jìn)行重定向

   RewriteRule ^.*$ error.html # 將非法訪問重定向到錯誤頁面
   </Directory>


  這樣如果一個盜鏈而來的請求將會因為沒有特殊Cookie而被重定向到錯誤頁面,就算實際地址暴露也不怕。至于這個Cookie的內(nèi)容是什么以及有效時間完全可以由管理員自己來設(shè)定,也就是說下載工具也沒法偽造,從而防止了服務(wù)器資源被盜鏈的危險。

   限制客戶端多線程下載操作流程

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 金塔县| 英德市| 泗水县| 陕西省| 龙门县| 正镶白旗| 蓬溪县| 巫溪县| 乌鲁木齐市| 湄潭县| 法库县| 舒城县| 林西县| 威海市| 大足县| 佛冈县| 武陟县| 永清县| 万全县| 团风县| 麦盖提县| 南京市| 罗山县| 南通市| 东兴市| 来凤县| 汝城县| 叙永县| 闻喜县| 龙海市| 安国市| 泸水县| 米易县| 樟树市| 留坝县| 宝丰县| 华容县| 内江市| 平南县| 岳阳市| 奇台县|