XSSRequestWrapper.javaimport javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRequestWrapper; import org.apache.commons.lang.StringEscapeUtils; public class XSSRequestWrapper extends HttpServletRequestWrapper { public XSSRequestWrapper(HttpServletRequest request) { super(request); } /** * 处理参数值 */ @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] = dealString(values[i]); } return encodedValues; } @Override public String getParameter(String parameter) { String value = super.getParameter(parameter); return dealString(value); } @Override public String getHeader(String name) { String value = super.getHeader(name); return dealString(value); } private String dealString(String value) { if (value != null) { // 采用spring的StringEscapeUtils工具类 实现 StringEscapeUtils.escapeHtml(value); StringEscapeUtils.escapeJavaScript(value); StringEscapeUtils.escapeSql(value); } return value; } }XSSFilter.javaimport 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攻击 过滤器(顺便过滤了 sql攻击) */ public class XSSFilter implements Filter { @Override public void init(FilterConfig arg0) 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); } }
java防止xss脚本注入攻击,采用spring工具类方式
最新推荐文章于 2025-08-30 22:33:30 发布
          
          
       
          
       
      
本文介绍了一种通过自定义请求包装器XSSRequestWrapper和过滤器XSSFilter来防御XSS攻击及附带SQL注入风险的方法。XSSRequestWrapper通过重写getParameterValues、getParameter和getHeader方法对输入进行转义处理,而XSSFilter则负责创建并应用该包装器。
          
                  
                  
                  
                  
                            
      
          
                
                
                
                
              
                
                
                
                
                
              
                
                
              
            
                  
					3135
					
被折叠的  条评论
		 为什么被折叠?
		 
		 
		
    
  
    
  
            


            