XSS 跨站脚本攻击 的防御解决方案

跨站脚本攻击(Cross Site Scripting),为不和层叠样式表(Cascading Style Sheets,CSS)的缩写混淆,故将跨站脚本攻击缩写为XSS。

XSS的攻击原理和分类

XSS分为:存储型、反射型 、DOM型XSS

存储型XSS:存储型XSS,持久化,代码是存储在服务器中的,如在个人信息或发表文章等地方,插入代码,如果没有过滤或过滤不严,那么这些代码将储存到服务器中,用户访问该页面的时候触发代码执行。这种XSS比较危险,容易造成蠕虫,盗窃cookie
反射型XSS:非持久化,需要欺骗用户自己去点击链接才能触发XSS代码(服务器中没有这样的页面和内容),一般容易出现在搜索页面。反射型XSS大多数是用来盗取用户的Cookie信息。
DOM型XSS:不经过后端,DOM-XSS漏洞是基于文档对象模型(Document Objeet Model,DOM)的一种漏洞,DOM-XSS是通过url传入参数去控制触发的,其实也属于反射型XSS。


这里我是写的一个工具类,放在后台代码的形式进行过滤滴。

    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;
    
    /**
     * 过滤器  实现防止xss攻击
     * @author Administrator
     *
     */
    public class XssFilter implements Filter {
        FilterConfig filterConfig = null;
    
        public void init(FilterConfig filterConfig) throws ServletException {
            this.filterConfig = filterConfig;
        }
    
        public void destroy() {
            this.filterConfig = null;
        }
    
        public void doFilter(ServletRequest request, ServletResponse response,
                FilterChain chain) throws IOException, ServletException {
            chain.doFilter(new XssHttpServletRequestWrapper(
                    (HttpServletRequest) request), response);
        }
    }

    import java.util.regex.Pattern;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletRequestWrapper;
    
    public class XssHttpServletRequestWrapper extends HttpServletRequestWrapper {
    	
    	public XssHttpServletRequestWrapper(HttpServletRequest servletRequest) {
    		super(servletRequest);
    	}
    
    	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] = cleanXSS(values[i]);
    		}
    		return encodedValues;
    	}
    
    	/**
         * 覆盖getParameter方法,将参数名和参数值都做xss过滤。
         * 如果需要获得原始的值,则通过super.getParameterValues(name)来获取
         * getParameterNames,getParameterValues和getParameterMap也可能需要覆盖
         */
    	public String getParameter(String parameter) {
    		String value = super.getParameter(parameter);
    		if (value == null) {
    			return null;
    		}
    		return cleanXSS(value);
    	}
    
    	/**
         * 覆盖getHeader方法,将参数名和参数值都做xss过滤。
         * 如果需要获得原始的值,则通过super.getHeaders(name)来获取
         * getHeaderNames 也可能需要覆盖
         */
    	public String getHeader(String name) {
    		String value = super.getHeader(name);
    		if (value == null)
    			return null;
    		return cleanXSS(value);
    	}
    
    	/**
    	 * 请求的参数过滤一些关键字
    	 * @param value
    	 *  CASE_INSENSITIVE 不区分大小写
    	 *  MULTILINE 多行匹配
    	 *  DOTALL 匹配任意字符
    	 * @return
    	 */
    	private String cleanXSS(String value) {
    		
    		if (value != null) {
                // 避免 null 字符
                value = value.replaceAll("", "");
        		value = value.replaceAll("<", "& lt;").replaceAll(">", "& gt;");
        		value = value.replaceAll("<", "& lt;").replaceAll(">", "& gt;");//  全角大于号  全角小于号
        		value = value.replaceAll("\\(", "& #40;").replaceAll("\\)", "& #41;");// \\(  \\)
        		value = value.replaceAll("'", "& #39;");
        		value = value.replaceAll("[\\\"\\\'][\\s]*javascript:(.*)[\\\"\\\']", "\"\"");
        		value = value.replaceAll("alert", "");
                // 避免 任何  script 标签  
                Pattern scriptPattern = Pattern.compile("", Pattern.CASE_INSENSITIVE);
                value = scriptPattern.matcher(value).replaceAll("");
                // 避免 任何  src="..."
                scriptPattern = Pattern.compile("src[\r\n]*=[\r\n]*\\\'(.*?)\\\'", Pattern.CASE_INSENSITIVE | Pattern.MULTILINE | Pattern.DOTALL);
                value = scriptPattern.matcher(value).replaceAll("");
                scriptPattern = Pattern.compile("src[\r\n]*=[\r\n]*\\\"(.*?)\\\"", Pattern.CASE_INSENSITIVE | Pattern.MULTILINE | Pattern.DOTALL);
                value = scriptPattern.matcher(value).replaceAll("");
                // 删除任何  标签
                scriptPattern = Pattern.compile("", Pattern.CASE_INSENSITIVE);
                value = scriptPattern.matcher(value).replaceAll("");
                // 删除任何 
                    
                    

你可能感兴趣的:(XSS)