首頁  >  文章  >  Java  >  Java中關於防盜鏈詳解以及解決方法詳解

Java中關於防盜鏈詳解以及解決方法詳解

黄舟
黄舟原創
2017-07-22 15:44:311839瀏覽

這篇文章主要介紹了java 防盜鏈詳解及解決辦法的相關資料,這裡介紹了防盜鏈的概念、產生原因及Http中的referer,最後介紹解決辦法,需要的朋友可以參考下

 java 防盜鏈詳解及解決方法

一.防盜鏈的概念

內容不在自己的伺服器上,透過技術手段將其他網站的內容(例如一些音樂、圖片、軟體的下載位址)放置在自己的網站中,透過這種方法盜取其他網站的空間和流量。

二.防盜鏈的產生

一般情況下,http請求時,一個完整的頁面並不是一次全部傳送到客戶端的。如果請求的是一個帶有許多圖片和其它訊息的頁面,那麼最先的一個Http請求被傳送回來的是這個頁面的文本,然後透過客戶端的瀏覽器對這段文本的解釋執行,發現其中還有圖片,那麼客戶端的瀏覽器會再發送一條Http請求,就這樣一個完整的頁面也許要經過發送多條Http請求才能夠被完整的顯示。基於這樣的機制,就會產生一個問題,那就是盜鏈問題:就是一個網站中如果沒有起頁面中所說的信息,例如圖片信息,那麼它完全可以將這個圖片的連接到別的網站。這樣提高自己訪問量的同時,也加大了對別人伺服器的負載。

三.Http中的referer

HTTP Referer是header的一部分,當瀏覽器向web伺服器發送請求的時候,一般會帶上Referer ,告訴伺服器我是從哪個頁面連結過來的,伺服器籍此可以獲得一些資訊來處理。

四.Java解決防盜鏈

我們可以設定一個過濾器,攔截所有請求,在外部請求過來時提取出http中的referer,然後再進行判斷,如果是本網站的來源,那麼允許訪問,否則拒絕。


public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) 
      throws IOException, ServletException { 
      HttpServletRequest req = (HttpServletRequest) request; 
      HttpServletResponse resp = (HttpServletResponse) response; 
      String referer = req.getHeader("referer"); 
      if(null != referer && referer.trim().startsWith("http://localhost:8080/dstn")){ 
         System.out.println("正常页面请求"); 
         chain.doFilter(req, resp); 
      }else{ 
         System.out.println("盗链"); 
         req.getRequestDispatcher("/html/error.html").forward(req, resp); 
      } 
 }

以上是Java中關於防盜鏈詳解以及解決方法詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn