Java Web XSS安全防御

news/2024/5/18 13:12:07 标签: Spring, XSS, EL, JSTL

        XSS攻击简单来讲就是攻击者在请求中巧妙地加上执行脚本,达到攻击的目的。实践过滤器方案和JSP的EL表达式+JSTL标签库方案都还可以达到防XSS攻击的目的。

一.过滤器方案

XSSFilter.java

package com.bijian.study.filter;

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.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;

/**
 * Servlet Filter implementation class XSSFilter
 */
@WebFilter("/XSSFilter")
public class XSSFilter implements Filter {
    
    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
    }

    @Override
    public void destroy() {
    }

    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException,
            ServletException {

        chain.doFilter(new XSSRequestWrapper((HttpServletRequest) request), response);
    }
}

XSSRequestWrapper.java

 

package com.bijian.study.filter;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletRequestWrapper;

import org.apache.commons.lang.StringEscapeUtils;

public class XSSRequestWrapper extends HttpServletRequestWrapper {
    
    public XSSRequestWrapper(HttpServletRequest servletRequest) {
        super(servletRequest);
    }

    @Override
    public String[] getParameterValues(String parameter) {
        
        String[] values = super.getParameterValues(parameter);
        if (values == null) {
            return null;
        }
        int count = values.length;
        String[] encodedValues = new String[count];
        for (int i = 0; i < count; i++) {
            encodedValues[i] = stripXSS(values[i]);
        }
        return encodedValues;
    }

    @Override
    public String getParameter(String parameter) {
        String value = super.getParameter(parameter);
        return stripXSS(value);
    }

    @Override
    public String getHeader(String name) {
        String value = super.getHeader(name);
        return stripXSS(value);
    }

    private String stripXSS(String value) {
        value = StringEscapeUtils.escapeHtml(value); 
        value = StringEscapeUtils.escapeJavaScript(value); 
        value = StringEscapeUtils.escapeSql(value);
        return value;
    }
}

web.xml中的配置

<filter>
	<filter-name>XSSFilter</filter-name>
	<filter-class>com.bijian.study.filter.XSSFilter</filter-class>
</filter>
<filter-mapping>
	<filter-name>XSSFilter</filter-name>
	<url-pattern>*.do</url-pattern>
</filter-mapping>
<filter-mapping>
	<filter-name>XSSFilter</filter-name>
	<url-pattern>*.jsp</url-pattern>
</filter-mapping>

 

二.JSP的EL表达式+JSTL标签库方案

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
<%
	String path = request.getContextPath();
	String basePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + path + "/";
	String nameStr = request.getParameter("name");//用request得到
	request.setAttribute("nameAttr", nameStr);
%> 
<!DOCTYPE html>   
<html>   
<head>   
	<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">   
	<title>Hello</title>   
</head>   
<body>
    Hi,<c:out value="${nameAttr}"/>
	<!--  
	Hi,<%=nameStr%>
	Hi,${param.name}
	-->
</body>   
</html>

 

XSS更详细的背景及方案,请参看:http://www.cnblogs.com/flyingeagle/articles/6746732.html


http://www.niftyadmin.cn/n/1316383.html

相关文章

跨域的解决方案

跨域的解决方案 Ajax简介&#xff1a; Ajax是Asynchronou Javascript XML 的缩写。Ajax通信与数据无关。Ajax能向服务器请求额外的数据而无需卸载页面&#xff0c;其核心是 XMLHttpRequest 对象&#xff08;简称XHR&#xff09;&#xff0c;XHR为向服务器发送请求和解析服务器相…

高度并行的指令级的超级处理器

超标量处理器&#xff1a; 在一个时钟周期可以同时处理机称为超标量处理机。 超流水线处理机&#xff1a; 在一个时钟周期内可以分时发射多条指令的处理机称为超流水线处理机。下图所看到的的是每一个时钟周期分时发送3条指令的超流水线 超长指令字&#xff08;VLIW&#xff09…

ELF文件的解析和加载

1. elf文件基本概念 elf&#xff08;Executable and Linkable Format&#xff09;文件是一种目标文件格式&#xff0c;是一种用于二进制文件、可执行文件、目标代码、共享库和核心转储格式文件。 2. elf文件结构组成 ELF文件由4部分组成&#xff0c;分别是ELF头&#xff08;E…

knockoutJS学习笔记05:控制文本和外观绑定

测试数据&#xff1a; function Person(name,age){var self this;self.name ko.observable(name);self.age ko.observable(age);self.isShow ko.observable("");self.html "<div>没有div</div>",self.isRed true}var person new Person…

BSS段为什么一定要初始化

1. 什么是BSS段&#xff1f; 一个程序本质上都是由bss段、data段、text段三个组成的。 BSS段通常是指用来存放程序中未初始化的全局变量和静态变量的一块内存区域。 2. BSS段的特点 bss段是不会出现在程序下载文件&#xff08;*.bin *.hex&#xff09;中的&#xff0c;因为全…

Google开源项目ZXing(二维条码编解码)简单使用(Java版)

Google开源项目ZXing的网方网址&#xff1a;http://code.google.com/p/zxing/ ZXing (pronounced "zebra crossing") is an open-source, multi-format 1D/2D barcode image processing library implemented in Java, with ports to other languages. Our focus is o…

进程和线程的区别(举例说明)

1. 一句话描述 进程是资源分配的最小单位&#xff0c;线程是CPU调度的最小单位 2. 举例说明&#xff08;假设进程火车&#xff0c;线程车厢&#xff09; &#xff08;1&#xff09;包含关系 如果一个进程内有多个线程&#xff0c;则执行过程不是一条线的&#xff0c;而是多条…

ios键盘退出

点击空白处退出键盘 1 -(void)touchesBegan:(nonnull NSSet<UITouch *> *)touches withEvent:(nullable UIEvent *)event{ 2 [self.view endEditing:YES]; 3 } 转载于:https://www.cnblogs.com/Eazy/p/4836896.html