Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 297|回复: 0

过滤器解决SQL盲注安全问题

[复制链接]
  • TA的每日心情
    奋斗
    2024-4-6 11:05
  • 签到天数: 748 天

    [LV.9]以坛为家II

    2034

    主题

    2092

    帖子

    70万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    705612
    发表于 2021-6-2 14:29:56 | 显示全部楼层 |阅读模式
    import java.io.IOException;
    import java.util.Enumeration;
    import java.util.LinkedHashMap;
    import java.util.Map;
    import java.util.Set;
    
    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;
    
    /**
     * <p>[过滤器解决SQL盲注安全问题]</p>
     * * 
     */
    public class SqlFilter implements Filter{
    	private static Map<String,String> filterMap = new LinkedHashMap<String,String>();
    	private String failPage = "/error.jsp";//发生注入时,跳转页面
    	public void destroy() {
    	}
    
    	public void doFilter(ServletRequest request, ServletResponse response,
    			FilterChain fc) throws IOException, ServletException {
    		//判断是否有注入攻击字符
    	    HttpServletRequest req = (HttpServletRequest) request;
    	 	String inj = injectInput(req);
    		if (!inj.equals("")) {
    			 request.getRequestDispatcher(failPage).forward(request, response);
    			 return;
    	    } else {
    		    // 传递控制到下一个过滤器
    	    	fc.doFilter(request, response);
    	    }
    
    	}
        /**
         * 判断request中是否含有注入攻击字符
         */
        public String injectInput(ServletRequest request) {
    	    
    	    Enumeration e = request.getParameterNames();
    	    String attributeName;
    	    String attributeValues[];
    	    String inj = "";
    	    String nameHasXss="";
    	    
    	    while (e.hasMoreElements()) { 
    	    	attributeName = (String)e.nextElement();
    //	    	//不对密码信息进行过滤,一般密码中可以包含特殊字符
    //	    	if(attributeName.equals("userPassword")||attributeName.equals("confirmPassword")||attributeName.equals("PASSWORD")
    //	    			||attributeName.equals("password")||attributeName.equals("PASSWORD2")||attributeName.equals("valiPassword")){
    //	    		continue;
    //	    	}
    	    	nameHasXss = cleanXSS(attributeName);
    	    	if(!"".equals(nameHasXss)){
    	    		return nameHasXss;
    	    	}else{
    	    		attributeValues = request.getParameterValues(attributeName);
    		    	for (int i = 0; i < attributeValues.length; i++) {
    		    		
    					if(attributeValues==null||attributeValues.equals(""))
    					    			continue;
    					 inj = cleanXSS(attributeValues);
    					 if (!inj.equals("")) {
    					    return inj;
    					 }
    				}
    	    	}
    		}   
    	    return inj;
    	 }
        /**
    	 * 清除恶意的脚本
    	 */
    	private String cleanXSS(String value) {
    		Set<String> keySet = filterMap.keySet();
    		for(String key : keySet){
    			if(value.contains(key)){
    				return value;
    			}
    } return ""; } public void init(FilterConfig fConfig) throws ServletException { //含有脚本script filterMap.put("[s|S][c|C][r|R][i|C][p|P][t|T]", ""); //含有脚本javascript filterMap.put("[\\\"\\\'][\\s]*[j|J][a|A][v|V][a|A][s|S][c|C][r|R][i|I][p|P][t|T]:(.*)[\\\"\\\']", "\"\""); //含有eval函数 filterMap.put("[e|E][v|V][a|A][l|L]\\((.*)\\)", ""); //含有特殊符号 filterMap.put("<", "<"); filterMap.put(">", ">"); filterMap.put("\\(", "("); filterMap.put("\\)", ")"); filterMap.put("(", "("); filterMap.put(")", ")"); filterMap.put("'", "'"); filterMap.put("\"", """); filterMap.put(";", ";"); filterMap.put("+", "+"); filterMap.put("|", "¦"); filterMap.put("$", ";"); filterMap.put("@", ";"); filterMap.put("%", ";"); } }

     

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-5-18 16:04 , Processed in 0.067665 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表