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

Java過濾器如何解決存儲型xss攻擊問題

 更新時間:2024年05月27日 10:48:02   作者:馮浩月  
這篇文章主要介紹了Java過濾器如何解決存儲型xss攻擊問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

Java過濾器解決存儲型xss攻擊

XSS攻擊場景

攻擊者可以通過構(gòu)造URL注入JavaScript、VBScript、ActiveX、HTML或者Flash的手段,利用跨站腳本漏洞欺騙用戶,收集Cookie等相關(guān)數(shù)據(jù)并冒充其他用戶。

通過精心構(gòu)造的惡意代碼,可以讓訪問者訪問非法網(wǎng)站或下載惡意木馬,如果再結(jié)合其他攻擊手段(如社會工程學(xué)、提權(quán)等),甚至可以獲取系統(tǒng)的管理權(quán)限。

舉例說明

例如:

在項目看板里待材料初審存儲下面代碼,點擊A項目會彈出框

Payload: <iframe οnlοad=alert("xss");></iframe>

在這里插入圖片描述

例如:

全部階段結(jié)果標(biāo)準(zhǔn)-存儲下面代碼,點擊20200927測試-2

Payload: <textarea οnfοcus=alert("xss"); autofocus>

在這里插入圖片描述

解決方案

找到項目已有的filter過濾器,在過濾HttpServletRequest參數(shù)時,進行參數(shù)的處理,使用轉(zhuǎn)義,將 < 轉(zhuǎn)義為 & lt , > 轉(zhuǎn)義為 & gt

  public PaasHttpRequestWrapper(HttpServletRequest request) {
        super(request);
        StringBuilder stringBuilder = new StringBuilder();
        InputStream inputStream = null;
        try {
            inputStream = request.getInputStream();
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
        if (inputStream != null) {
            try (BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(inputStream))) {
                char[] charBuffer = new char[CHAR_BUFFER_LENGTH];
                int bytesRead;
                while ((bytesRead = bufferedReader.read(charBuffer)) > 0) {
                    stringBuilder.append(charBuffer, BUFFER_START_POSITION, bytesRead);
                }
            } catch (IOException e) {
                e.printStackTrace();
            }
        } else {
            stringBuilder.append("");
        }
        body = stringBuilder.toString();
        // 解決xss攻擊問題
        if (body.contains("<")) {
            body = body.replace("<", "&lt");
        }
        if (body.contains(">")) {
            body = body.replace(">", "&gt");
        }
        initParameterMap();
    }

XSS攻擊及解決方案

什么是XSS攻擊?

XSS攻擊使用Javascript腳本注入進行攻擊

XSS攻擊常出現(xiàn)在提交表單中,如博客的評論區(qū)等,用戶可以通過提交評論:<script>alert("你的網(wǎng)站太垃圾了!")</script>,那么只要訪問該頁面的用戶都會彈窗,當(dāng)然,這可能是為了娛樂娛樂,不要小看XSS攻擊,有些人利用XSS攻擊竊取用戶名密碼,調(diào)用黑客的工程,將用戶名和密碼發(fā)送過去,也可以偽裝成釣魚網(wǎng)站。

例如在表單中注入: <script>location.href='http://www.xxx.com'</script> 那么頁面會跳轉(zhuǎn)到xxx.com

還可以根據(jù)js獲取本地瀏覽器的cookie信息,根據(jù)cookie信息完全可以模擬用戶。

注意:谷歌瀏覽器 已經(jīng)防止了XSS攻擊,為了演示效果,最好使用火狐瀏覽器。

那么該如何防止XSS攻擊呢?

實現(xiàn)思路:

使用轉(zhuǎn)義解決。將<轉(zhuǎn)義為&lt    >轉(zhuǎn)義為&gt

  • ①使用過濾器,攔截所有請求,重寫request
  • ②重寫獲取值的方法,將特殊代碼轉(zhuǎn)換成html

具體代碼實現(xiàn):

  • XssHttpServletRequest.java
package cn.itcats;
 
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletRequestWrapper;
 
import org.apache.commons.lang3.StringEscapeUtils;
import org.apache.commons.lang3.StringUtils;
 
public class XssHttpServletRequest extends HttpServletRequestWrapper{
    private HttpServletRequest request;
    
    //需要重寫構(gòu)造方法
    public XssHttpServletRequest(HttpServletRequest request) {
        super(request);
        this.request = request;
    }
        
    //需要重寫getParameter(name)方法,將value進行轉(zhuǎn)義
    public String getParameter(String name) {
        String value = request.getParameter(name);
        System.out.println("沒有轉(zhuǎn)義之前:value="+value);
        if(StringUtils.isNotBlank(value)){
            //轉(zhuǎn)化為html,<script>標(biāo)簽都會轉(zhuǎn)化為html格式  &lt;script&gt;
            //工具類來自于org.apache.commons.lang3.StringEscapeUtils
            value = StringEscapeUtils.escapeHtml4(value);
        }
        return value;
    }
 
}
  • web.xml配置過濾器
<!-- 防止XSS攻擊 -->
    <filter>
        <filter-name>FilterXSS</filter-name>
        <filter-class>cn.itcats.FilterXSS</filter-class>
    </filter>
    
    <filter-mapping>
        <filter-name>FilterXSS</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>

  • FilterXss.java
package cn.itcats;
 
import java.io.IOException;
 
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;
 
public class FilterXSS implements Filter{
 
    public void init(FilterConfig filterConfig) throws ServletException {
        
    }
 
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
            throws IOException, ServletException {
        //強轉(zhuǎn)為HttpServletRequest
        HttpServletRequest req = (HttpServletRequest)request;
        //需要重寫request,重建一個類XssHttpServletRequest 繼承 HttpServletRequestWrapper,重寫構(gòu)造和getParameter方法
        XssHttpServletRequest xssHttpServletRequest = new XssHttpServletRequest(req);
        //務(wù)必傳入是重寫過的request,放行
        chain.doFilter(xssHttpServletRequest, response);
    }
 
    public void destroy() {
        
    }
 
}

注意:只要是文本框、表單等,需要提交并在頁面展示的,一般都需要做防XSS攻擊。 

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • JAVA swing布局管理器實例解析

    JAVA swing布局管理器實例解析

    這篇文章主要介紹了JAVA swing布局管理器實例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-03-03
  • 一次Spring項目打包問題排查的實戰(zhàn)記錄

    一次Spring項目打包問題排查的實戰(zhàn)記錄

    這篇文章主要給大家介紹了一次Spring項目打包問題排查的實戰(zhàn)記錄,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者使用Spring具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • Java中的接口和抽象類用法實例詳解

    Java中的接口和抽象類用法實例詳解

    這篇文章主要介紹了Java中的接口和抽象類用法,結(jié)合實例形式較為詳細(xì)的分析了Java中關(guān)于接口和抽象類的概念、定義、用法與相關(guān)注意事項,需要的朋友可以參考下
    2015-12-12
  • SpringBoot熱部署啟動關(guān)閉流程詳解

    SpringBoot熱部署啟動關(guān)閉流程詳解

    Spring?Boot啟動熱部署是一種技術(shù),它能讓開發(fā)者在不重啟應(yīng)用程序的情況下實時更新代碼。這樣可以提高開發(fā)效率,避免頻繁重啟應(yīng)用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2023-04-04
  • 淺談Java面向接口編程

    淺談Java面向接口編程

    本文通過結(jié)合接口的本質(zhì)、面向?qū)ο缶幊膛c面向接口編程的關(guān)系以及一些作者自身的理解,向大家介紹了面向接口編程的一些東西,需要的朋友可以了解下。
    2017-09-09
  • Java實現(xiàn)的決策樹算法完整實例

    Java實現(xiàn)的決策樹算法完整實例

    這篇文章主要介紹了Java實現(xiàn)的決策樹算法,簡單描述了決策樹的概念、原理,并結(jié)合完整實例形式分析了java實現(xiàn)決策樹算法的相關(guān)操作技巧,代碼中備有較為詳盡的注釋便于理解,需要的朋友可以參考下
    2017-11-11
  • 了解Java虛擬機JVM的基本結(jié)構(gòu)及JVM的內(nèi)存溢出方式

    了解Java虛擬機JVM的基本結(jié)構(gòu)及JVM的內(nèi)存溢出方式

    這篇文章主要介紹了Java虛擬機JVM的基本結(jié)構(gòu)及JVM的內(nèi)存溢出方式,涉及到Java內(nèi)存分配相關(guān)方面的知識,需要的朋友可以參考下
    2016-01-01
  • SpringBoot整合jasypt實現(xiàn)重要數(shù)據(jù)加密

    SpringBoot整合jasypt實現(xiàn)重要數(shù)據(jù)加密

    Jasypt是一個專注于簡化Java加密操作的開源工具,這篇文章主要為大家介紹了詳細(xì)介紹了如何使用jasypt實現(xiàn)重要數(shù)據(jù)加密,感興趣的小伙伴可以了解下
    2025-03-03
  • Java前端Layer.open.btn驗證無效解決方法

    Java前端Layer.open.btn驗證無效解決方法

    在本篇文章里我們給大家整理了一篇關(guān)于Java前端Layer.open.btn驗證無效解決方法以及實例代碼,需要的朋友們可以參考學(xué)習(xí)下。
    2019-09-09
  • Java Yml格式轉(zhuǎn)換為Properties問題

    Java Yml格式轉(zhuǎn)換為Properties問題

    本文介紹了作者編寫一個Java工具類來解決在線YAML到Properties轉(zhuǎn)換時屬性內(nèi)容遺漏的問題,通過遍歷YAML文件的樹結(jié)構(gòu),作者成功實現(xiàn)了屬性的完整轉(zhuǎn)換,總結(jié)指出,該工具類適用于多種數(shù)據(jù)類型,并且代碼簡潔易懂
    2024-12-12

最新評論