码迷,mamicode.com
首页 > 数据库 > 详细

java后台防止sql注入的方法

时间:2017-04-29 15:06:44      阅读:283      评论:0      收藏:0      [点我收藏+]

标签:sql注入   正则表达   str   resultset   static   div   log   预编译   blog   

1.采用预编译语句集,它内置了处理SQL注入的能力,只要使用它的setString方法传值即可:

        String sql= "select * from users where username=? and password=?;
        PreparedStatement preState = conn.prepareStatement(sql);
        preState.setString(1, userName);
        preState.setString(2, password);
        ResultSet rs = preState.executeQuery();

2.采用正则表达式将包含有 单引号(‘),分号(;) 和 注释符号(--)的语句给替换掉来防止SQL注入

    public static String SQL(String str)
    {
        return str.replaceAll(".*([‘;]+|(--)+).*", " ");
    }

    userName=SQL(userName);
    password=SQL(password);

    String sql="select * from users where username=‘"+userName+"‘ and password=‘"+password+"‘ "
    Statement sta = conn.createStatement();
    ResultSet rs = sta.executeQuery(sql);

 

java后台防止sql注入的方法

标签:sql注入   正则表达   str   resultset   static   div   log   预编译   blog   

原文地址:http://www.cnblogs.com/2016-10-07/p/6785106.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!