欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java防盜鏈在報(bào)表中的應(yīng)用實(shí)例(推薦)

 更新時(shí)間:2016年09月13日 15:45:21   投稿:jingxian  
下面小編就為大家?guī)?lái)一篇java防盜鏈在報(bào)表中的應(yīng)用實(shí)例(推薦)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

今天我們來(lái)聊Java防盜鏈,多說(shuō)無(wú)用,直接上應(yīng)用案例。

這里所用的工具是報(bào)表軟件FineReport,搭配有決策系統(tǒng)(一個(gè)web前端展示系統(tǒng),主要用于權(quán)限控制),可以采用java防盜鏈的方式來(lái)實(shí)現(xiàn)頁(yè)面權(quán)限。

瀏覽器中直接輸入報(bào)表URL的時(shí)候,它的頭文件是空的,因此,可以在訪問(wèn)的時(shí)候做兩個(gè)判斷:頭文件是否為空以及以什么頁(yè)面進(jìn)行跳轉(zhuǎn),如果不符合跳到錯(cuò)誤頁(yè)面即可。

什么是Referer?

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

什么是空Referer,什么時(shí)候會(huì)出現(xiàn)空Referer?

首先,我們對(duì)空Referer的定義為,Referer 頭部的內(nèi)容為空,或者,一個(gè)HTTP請(qǐng)求中根本不包含Referer頭部。

那么什么時(shí)候HTTP請(qǐng)求會(huì)不包含Referer字段呢?根據(jù)Referer的定義,它的作用是指示一個(gè)請(qǐng)求是從哪里鏈接過(guò)來(lái),那么當(dāng)一個(gè)請(qǐng)求并不是由鏈接觸發(fā)產(chǎn)生的,那么自然也就不需要指定這個(gè)請(qǐng)求的鏈接來(lái)源。

比如,直接在瀏覽器的地址欄中輸入一個(gè)資源的URL地址,那么這種請(qǐng)求是不會(huì)包含Referer字段的,因?yàn)檫@是一個(gè)“憑空產(chǎn)生”的HTTP請(qǐng)求,并不是從一個(gè)地方鏈接過(guò)去的。

在防盜鏈設(shè)置中,允許空Referer和不允許空Referer有什么區(qū)別?

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

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

操作步驟

1、添加class文件

編寫(xiě)一個(gè)類文件,用來(lái)判斷頭文件是否為空,代碼如下:

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

  }
}

將Dodo.java編譯成class文件,并放在%TOMCAT_HOME%\WebReport\WEB-INF\classes\com\fr\test目錄下。

2、修改web.xml文件

打開(kāi)%TOMCAT_HOME%\webapps\WebReport\WEB-INF下的web.xml文件,配置一個(gè)過(guò)濾filter,在出現(xiàn)ReportServer的時(shí)候執(zhí)行過(guò)濾,代碼如下:


<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>

兩步就可以搞定,如果屬于盜鏈,則跳轉(zhuǎn)至上述的LdapLogin錯(cuò)誤頁(yè)面,這里沒(méi)有LdapLoign頁(yè)面,所以直接跳轉(zhuǎn)404。如果還想實(shí)現(xiàn)數(shù)據(jù)權(quán)限,則可以通過(guò)單點(diǎn)登錄或者session注入的方式。

效果測(cè)試

準(zhǔn)備兩個(gè)html文件

假設(shè)hello.html是正確的網(wǎng)址

<html>
<body>
<p>測(cè)試</p>

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

假設(shè)steal.html是盜鏈的網(wǎng)址

<html>
<body>
<p>測(cè)試,錯(cuò)誤的鏈接地址</p>

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

情況一

通過(guò)hello.html跳轉(zhuǎn),跳轉(zhuǎn)鏈接正確,即referer不為空且正確

情況二

通過(guò)steal.html跳轉(zhuǎn),跳轉(zhuǎn)鏈接錯(cuò)誤,即referer不為空且錯(cuò)誤

情況三

直接訪問(wèn)URL地址,即referer為空

以上這篇java防盜鏈在報(bào)表中的應(yīng)用實(shí)例(推薦)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 基于rocketmq的有序消費(fèi)模式和并發(fā)消費(fèi)模式的區(qū)別說(shuō)明

    基于rocketmq的有序消費(fèi)模式和并發(fā)消費(fèi)模式的區(qū)別說(shuō)明

    這篇文章主要介紹了基于rocketmq的有序消費(fèi)模式和并發(fā)消費(fèi)模式的區(qū)別說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • SpringBoot解決跨域的5種方式小結(jié)

    SpringBoot解決跨域的5種方式小結(jié)

    在項(xiàng)目開(kāi)發(fā)中,時(shí)常會(huì)遇到跨域問(wèn)題,本文主要介紹了五種解決跨域的方法,使用最多的是第三種,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-06-06
  • Java中常見(jiàn)的5種WEB服務(wù)器介紹

    Java中常見(jiàn)的5種WEB服務(wù)器介紹

    這篇文章主要介紹了Java中常見(jiàn)的5種WEB服務(wù)器介紹,它們分別是Tomcat、Resin、JBoss、WebSphere、WebLogic,需要的朋友可以參考下
    2014-07-07
  • SpringBoot?@Value與@ConfigurationProperties二者有哪些區(qū)別

    SpringBoot?@Value與@ConfigurationProperties二者有哪些區(qū)別

    這篇文章主要介紹了SpringBoot?@Value與@ConfigurationProperties二者的區(qū)別,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧
    2022-10-10
  • mybatis?collection和association的區(qū)別解析

    mybatis?collection和association的區(qū)別解析

    這篇文章主要介紹了mybatis?collection解析以及和association的區(qū)別,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-07-07
  • idea中l(wèi)ombok的用法

    idea中l(wèi)ombok的用法

    lombok是開(kāi)源的代碼生成庫(kù),是一款非常實(shí)用的小工具,在更改實(shí)體類時(shí)只需要修改屬性即可,減少了很多重復(fù)代碼的編寫(xiě)工作,今天小編給大家介紹idea中l(wèi)ombok的用法,感興趣的朋友一起看看吧
    2021-12-12
  • Java通過(guò)cellstyle屬性設(shè)置Excel單元格常用樣式的全面總結(jié)講解

    Java通過(guò)cellstyle屬性設(shè)置Excel單元格常用樣式的全面總結(jié)講解

    在處理Excel文件時(shí),經(jīng)常需要對(duì)單元格進(jìn)行樣式設(shè)置,以滿足特定的需求和美化要求,這篇文章主要給大家介紹了關(guān)于Java通過(guò)cellstyle屬性設(shè)置Excel單元格常用樣式的相關(guān)資料,需要的朋友可以參考下
    2024-01-01
  • 淺談Java 對(duì)于繼承的初級(jí)理解

    淺談Java 對(duì)于繼承的初級(jí)理解

    下面小編就為大家?guī)?lái)一篇淺談Java 對(duì)于繼承的初級(jí)理解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-06-06
  • Springboot整合junit過(guò)程解析

    Springboot整合junit過(guò)程解析

    這篇文章主要介紹了Springboot整合junit過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-05-05
  • IDEA報(bào)錯(cuò):無(wú)效的源發(fā)行版解決方案

    IDEA報(bào)錯(cuò):無(wú)效的源發(fā)行版解決方案

    很多小伙伴在刷新maven的時(shí)候總會(huì)報(bào) Error:java:無(wú)效的源發(fā)行版,下面這篇文章主要給大家介紹了關(guān)于IDEA報(bào)錯(cuò):無(wú)效的源發(fā)行版的解決方案,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09

最新評(píng)論