有效预防xss_预防XSS***

开发时间 2016-03-02日

项目地点:深圳

开发人员 yekang

在web.xml中配置过滤器

创建类

package com.palic.elis.ceis.common.filter;

import java.io.IOException;

import java.util.LinkedHashMap;

import java.util.Map;

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 XssFilter implements Filter {

// XSS处理Map

private static Map xssMap = new LinkedHashMap();

@Override

public void destroy() {

}

@Override

public void doFilter(ServletRequest request, ServletResponse response,

FilterChain chain) throws IOException, ServletException {

// TODO Auto-generated method stub

// 强制类型转换 HttpServletRequest

HttpServletRequest httpReq = (HttpServletRequest) request;

// 构造HttpRequestWrapper对象处理XSS

HttpRequestWrapper httpReqWarp = new HttpRequestWrapper(httpReq, xssMap);

//

chain.doFilter(httpReqWarp, response);

}

@Override

public void init(FilterConfig filterConfig) throws ServletException {

// 含有脚本: script

xssMap.put("[s|S][c|C][r|R][i|I][p|P][t|T]", "");

// 含有脚本 javascript

xssMap.put(

"[\\\"\\\'][\\s]*[j|J][a|A][v|V][a|A][s|S][c|C][r|R][i|I][p|P][t|T]:(.*)[\\\"\\\']",

"\"\"");

// 含有函数: eval

xssMap.put("[e|E][v|V][a|A][l|L]\\((.*)\\)", "");

// 含有符号 <

xssMap.put("

// 含有符号 >

xssMap.put(">", ">");

// 含有符号 (

xssMap.put("\\(", "(");

System.out.println("1111111111111");

// 含有符号 )

xssMap.put("\\)", ")");

// 含有符号 '

xssMap.put("'", "'");

// 含有符号 "

xssMap.put("\"", "\"");

System.out.println("22222222222222");

}

}

创建类

package com.palic.elis.ceis.common.filter;

import java.util.Map;

import java.util.Set;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletRequestWrapper;

public class HttpRequestWrapper extends HttpServletRequestWrapper {

private Map xssMap;

public HttpRequestWrapper(HttpServletRequest Request) {

super(Request);

}

public HttpRequestWrapper(HttpServletRequest request,

Map xssMap) {

super(request);

this.xssMap = xssMap;

}

@Override

public String[] getParameterValues(String parameter) {

String[] values = super.getParameterValues(parameter);

if (values == null||values.length == 0) {

return null;

}

// 遍历每一个参数,检查是否含有

for (int i = 0; i < values.length; i++) {

values[i] = cleanXSS(values[i]);

}

return values;

}

public String getParameter(String parameter) {

String value = super.getParameter(parameter);

if (value == null) {

return null;

}

return cleanXSS(value);

}

public String getHeader(String name) {

String value = super.getHeader(name);

if (value == null)

return null;

return cleanXSS(value);

}

private String cleanXSS(String value) {

Set keySet = xssMap.keySet();

for (String key : keySet) {

String v = xssMap.get(key);

value = value.replaceAll(key, v);

}

return value;

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值