一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - java防盜鏈在報表中的應用實例(推薦)

java防盜鏈在報表中的應用實例(推薦)

2020-06-15 12:11jingxian JAVA教程

下面小編就為大家帶來一篇java防盜鏈在報表中的應用實例(推薦)。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

今天我們來聊Java防盜鏈,多說無用,直接上應用案例。

這里所用的工具是報表軟件FineReport,搭配有決策系統(一個web前端展示系統,主要用于權限控制),可以采用java防盜鏈的方式來實現頁面權限。

瀏覽器中直接輸入報表URL的時候,它的頭文件是空的,因此,可以在訪問的時候做兩個判斷:頭文件是否為空以及以什么頁面進行跳轉,如果不符合跳到錯誤頁面即可。

什么是Referer?

這里的 Referer 指的是HTTP頭部的一個字段,也稱為HTTP來源地址(HTTP Referer),用來表示從哪兒鏈接到目前的網頁,采用的格式是URL。換句話說,借著 HTTP Referer 頭部網頁可以檢查訪客從哪里而來,這也常被用來對付偽造的跨網站請求。

java防盜鏈在報表中的應用實例(推薦)

 

什么是空Referer,什么時候會出現空Referer?

首先,我們對空Referer的定義為,Referer 頭部的內容為空,或者,一個HTTP請求中根本不包含Referer頭部。

那么什么時候HTTP請求會不包含Referer字段呢?根據Referer的定義,它的作用是指示一個請求是從哪里鏈接過來,那么當一個請求并不是由鏈接觸發產生的,那么自然也就不需要指定這個請求的鏈接來源。

比如,直接在瀏覽器的地址欄中輸入一個資源的URL地址,那么這種請求是不會包含Referer字段的,因為這是一個“憑空產生”的HTTP請求,并不是從一個地方鏈接過去的。

java防盜鏈在報表中的應用實例(推薦)

 

在防盜鏈設置中,允許空Referer和不允許空Referer有什么區別?

在防盜鏈中,如果允許包含空的Referer,那么通過瀏覽器地址欄直接訪問該資源URL是可以訪問到的;

但如果不允許包含空的Referer,那么通過瀏覽器直接訪問也是被禁止的。

操作步驟

1、添加class文件

編寫一個類文件,用來判斷頭文件是否為空,代碼如下:

package com.fr.test;

import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

public class Dodo implements Filter {
  public void destroy() {
    // TODO Auto-generated method stub

  }

  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");
  //下面的IP地址是正常頁面請求
  if(null != referer && (referer.trim().startsWith("http://localhost:8033")||referer.trim().startsWith("http://www.finereporthelp.com/test/hello.html"))){
     System.out.println("正常頁面請求"+referer);
     chain.doFilter(req, resp);
  //下面的就是出現不是正常頁面請求的時候跳轉
  }else{
     System.out.println("盜鏈"+referer);
     req.getRequestDispatcher("/LdapLogin.jsp").forward(req, resp);
  }
}
  public void init(FilterConfig arg0) throws ServletException {
    // TODO Auto-generated method stub

  }
}

java防盜鏈在報表中的應用實例(推薦)將Dodo.java編譯成class文件,并放在%TOMCAT_HOME%\WebReport\WEB-INF\classes\com\fr\test目錄下。

java防盜鏈在報表中的應用實例(推薦)

2、修改web.xml文件

打開%TOMCAT_HOME%\webapps\WebReport\WEB-INF下的web.xml文件,配置一個過濾filter,在出現ReportServer的時候執行過濾,代碼如下:

java防盜鏈在報表中的應用實例(推薦)

<filter>
<filter-name>AuthFilter</filter-name>
<filter-class>com.fr.test.Dodo</filter-class></filter>
<filter-mapping>
<filter-name>AuthFilter</filter-name>
<url-pattern>/ReportServer</url-pattern>
</filter-mapping>

兩步就可以搞定,如果屬于盜鏈,則跳轉至上述的LdapLogin錯誤頁面,這里沒有LdapLoign頁面,所以直接跳轉404。如果還想實現數據權限,則可以通過單點登錄或者session注入的方式。

效果測試

準備兩個html文件

假設hello.html是正確的網址

<html>
<body>
<p>測試</p>

<a href="http://localhost:8033/WebReport/ReportServer?reportlet=demo%2Fnewchart%2Fothers%2FLogarithmic_axis.cpt&op=write">防盜鏈測試</a>
</body>
<html>

假設steal.html是盜鏈的網址

<html>
<body>
<p>測試,錯誤的鏈接地址</p>

<a href="http://localhost:8033/WebReport/ReportServer?reportlet=demo%2Fnewchart%2Fothers%2FLogarithmic_axis.cpt&op=write">防盜鏈測試</a>
</body>
</html>

情況一

通過hello.html跳轉,跳轉鏈接正確,即referer不為空且正確

java防盜鏈在報表中的應用實例(推薦)java防盜鏈在報表中的應用實例(推薦)

情況二

java防盜鏈在報表中的應用實例(推薦)java防盜鏈在報表中的應用實例(推薦)

通過steal.html跳轉,跳轉鏈接錯誤,即referer不為空且錯誤

 

情況三

java防盜鏈在報表中的應用實例(推薦)

直接訪問URL地址,即referer為空

以上這篇java防盜鏈在報表中的應用實例(推薦)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 91成人啪国产啪永久地址 | 精品久久久久久亚洲 | 国产精品自在欧美一区 | 男生和老师一起差差差 | 欧美a级完整在线观看 | 日本乱中文字幕系列在线观看 | 潘甜甜在线观看 | 久久这里只精品国产99re66 | 日韩在线免费播放 | 99久热只有精品视频免费观看17 | 国产免费视 | 久九九精品免费视频 | 爽好大快深点一视频 | 婚前试爱全集免费观看 | 亚洲系列国产精品制服丝袜第 | 国内精品久久久久久不卡影院 | 国产日韩精品一区二区 | 久草在在线免视频在线观看 | 美女脱了内裤打开腿让人桶网站o | 亚洲精品日韩专区在线观看 | 特黄特级高清免费视频毛片 | 天天做日日爱 | 日韩高清成人毛片不卡 | 俄罗斯处女摘花 | 99爱在线观看精品视频 | 国产精品福利在线观看免费不卡 | 免费福利资源站在线视频 | 欧美一级裸片又黄又裸 | 91伊人网 | 乌克兰成人性色生活片 | 亚洲欧美专区精品伊人久久 | 日本伦理动漫在线观看 | 1314酒色| 美女靠逼免费视频 | 亚洲小视频网站 | 呜嗯啊野战h呻吟男男双性 污小说在线阅读 | www.国产在线观看 | 99精品久久精品一区二区 | 美味情缘韩国在线观看视频 | china中国xxxxfree| 日本肉体xxxx |