麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

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

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

2024-08-27 18:30:31
字體:
來源:轉載
供稿:網(wǎng)友

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

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

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

   防盜鏈

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

   現(xiàn)在一些流行的防盜鏈的方式都是用在瀏覽頁面的時候產(chǎ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 />塊,在里面加入類似如下代碼:

 

復制代碼 代碼如下:

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

 

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


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

 

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

   限制多線程現(xiàn)在需要用到一個Apache的擴展模塊mod_limitipconn,這里是作者的官方網(wǎng)站[url]http://dominia.org/djao/limitipconn2.html[/url],先下載適合自己版本的模塊文件到Apache安裝目錄下的modules目錄下面,然后在httpd.conf文件中搜索:

   #LoadModule status_module modules/mod_status.so

  把它前面的#去掉,再加入:

   ExtendedStatus On
  LoadModule limitipconn_module modules/mod_limitipconn.dll
 # 如果你下載的不是Win版,請把后面的文件名改為你所下載的文件名

 

復制代碼 代碼如下:

   <IfModule mod_limitipconn.c>

 

  <Location /> # 這里表示限制根目錄,即全部限制,可以根據(jù)需要修改
   MaxConnPerIP 2 # 這里表示最多同時兩個線程
   NoLimit html/* # 這里表示html目錄下不受限制
   </Location>
  </IfModule>

 

  這樣來自同一客戶端的超過2個的線程請求將被拒絕,從而限制了客戶端的多線程下載。

   限制下載帶寬操作流程

   這個同樣需要擴展模塊支持,模塊是mod_bw,在作者的官方網(wǎng)站[url]http://ivn.cl/apache/[/url]可以下載到。同樣也是放入modules目錄下面,然后在httpd.conf文件中加入:

   LoadModule bw_module modules/mod_bw.dll
  再找到<Directory />塊,加入:

復制代碼 代碼如下:

   <Directory />
  # Other configurations …
  BandwidthModule On # 啟動帶寬限制
   ForceBandwidthModule On # 啟動帶寬限制
   MaxConnection all 2000 # 最大連接數(shù)2000
  Bandwidth all 200000 # 單個客戶端最大帶寬200KB
  </Directory>

 

  這樣限制了同時最多2000個連接數(shù),每個客戶端最大200KB的下載帶寬。

   到此,我們的完美限制的HTTP下載服務器就配置完成了,重新啟動你的Apache這些功能便能生效了。因為Apache和這些模塊都是開源免費的,我們不需要為此掏一分錢,不用去購買那些第三方的軟件,只是需要多去了解一下這些軟件的使用說明。不要一切都祈禱有現(xiàn)成美好的東西,自己動手做一次會有不一樣的收獲。

 

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 91热久久免费频精品黑人99 | 免费黄色成人 | 日韩精品dvd | 在线a亚洲视频播放在线观看 | 久久思思爱| 中文亚洲视频 | 亚洲视色| 久久国产一 | 中文日韩欧美 | 极品xxxx欧美一区二区 | 久久国产成人精品国产成人亚洲 | 国产69精品久久久久久久久久 | 72pao成人国产永久免费视频 | 全黄裸片武则天艳史 | 久久国产免费 | 激情久久免费视频 | 中文字幕亚洲视频 | 国产成人在线一区二区 | www69xxxxx| 国产精品久久99精品毛片三a | 中文字幕在线观看网址 | 成人在线视频黄色 | 久久久www成人免费精品 | av免费在线观看不卡 | 国产午夜免费视频 | 亚洲男人一区 | 久久国产精品免费视频 | 看一级毛片 | 成人福利在线看 | 日日狠狠久久 | 日韩精品一二三区 | 欧美日韩国产成人在线观看 | 欧美在线观看禁18 | 国产精品久久久久永久免费 | 久久久久亚洲国产精品 | 国产成人自拍小视频 | 欧美一级美片在线观看免费 | 欧美成人精品欧美一级乱黄 | 黄色片免费看网站 | 极品xxxx欧美一区二区 | 毛片免费看电影 |