SQL注入问题

SQL注入

  SQL注入即是指web应用程序对用户输入数据的合法性没有判断或过滤不严,攻击者可以在web应用程序中

事先定义好的查询语句的结尾上添加额外的SQL语句,在管理员不知情的情况下实现非法操作,以此来实现欺骗

数据库服务器执行非授权的任意查询,从而进一步得到相应的数据信息。 

 

正常输入情况下:

public class SqlInjection {
    public static void main(String[] args) {
        login("lisi","123456");
    }
    public static void login(String username,String password){
        Connection conn = null;
        Statement st= null;
        ResultSet rs = null;
        try {
            conn = JdbcUtils.getConnection();
            st = conn.createStatement();
            String sql = "select * from users where `NAME`='"+username+"' AND `password`='"+password+"'";
            rs = st.executeQuery(sql);
            while (rs.next()){
                System.out.println("name="+rs.getString("NAME"));
                System.out.println("password="+rs.getString("PASSWORD"));
                System.out.println("+++++++++++++++++++++++");
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }finally {
            JdbcUtils.release(conn,st,rs);
        }
    }
}

非正常情况下:

public class SqlInjection {
    public static void main(String[] args) {
        login("'or '1=1","'or '1=1");
    }
    public static void login(String username,String password){
        Connection conn = null;
        Statement st= null;
        ResultSet rs = null;
        try {
            conn = JdbcUtils.getConnection();
            st = conn.createStatement();
            String sql = "select * from users where `NAME`='"+username+"' AND `password`='"+password+"'";
            rs = st.executeQuery(sql);
            while (rs.next()){
                System.out.println("name="+rs.getString("NAME"));
                System.out.println("password="+rs.getString("PASSWORD"));
                System.out.println("+++++++++++++++++++++++");
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }finally {
            JdbcUtils.release(conn,st,rs);
        }
    }
}

区别就在于登录的时候输入的用户名密码

 拼接一下sql得到

select * from users where `name` = 'lisi' and `password`='123456';

select * from users where `name`=' 'or ' 1=1' and `password`=' ' or '1=1';(恒成立,name,password中的1=1永远为true)

 

PreparedStatement对象

  PreparedStatement可以防止SQL注入,效率更高

1.新增

public class TestInsert {
    public static void main(String[] args) {
        Connection conn = null;
        PreparedStatement pst = null;
        ResultSet rs = null;
        try {
            conn = JdbcUtils.getConnection();
            //开始有区别了,使用问号占位符代替参数
            String sql = "insert into users(id,`NAME`,`PASSWORD`,`email`,birthday) values(?,?,?,?,?)";
            pst = conn.prepareStatement(sql);//需要一个预编译SQL,不执行
            //手动给参数赋值
            pst.setInt(1,4);//id赋值
            pst.setString(2,"wuwu");//NAME赋值
            pst.setString(3,"33232");//password赋值
            pst.setString(4,"232412@qq.com");//email赋值
            pst.setDate(5,new java.sql.Date(new Date().getTime()));//birthday赋值
            //最后执行
            int i = pst.executeUpdate();
            if (i>0){
                System.out.println("插入成功!!!");
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }finally {
            JdbcUtils.release(conn,pst,rs);
        }
    }
}

2.删除

public class TestDelete {
    public static void main(String[] args) {
        Connection conn = null;
        PreparedStatement pst = null;
        ResultSet rs = null;
        try {
            conn = JdbcUtils.getConnection();
            String sql = "delete from users where id = ?";
            pst = conn.prepareStatement(sql);
            pst.setInt(1,4);
            int i = pst.executeUpdate();
            if (i>0){
                System.out.println("删除成功!!!");
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }finally {
            JdbcUtils.release(conn,pst,rs);
        }
    }
}

3.更新

public class TestUpdate {
    public static void main(String[] args) {
        Connection conn = null;
        PreparedStatement pst = null;
        ResultSet rs= null;
        try {
            conn = JdbcUtils.getConnection();
            String sql = "update users set `NAME`=? where id=?";
            pst = conn.prepareStatement(sql);
            pst.setString(1,"lisi");
            pst.setInt(2,1);
            int i = pst.executeUpdate();
            if (i>0){
                System.out.println("更新成功!!!");
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }finally {
            JdbcUtils.release(conn,pst,rs);
        }
    }
}

4.查询

public class TestSelect {
    public static void main(String[] args) {
        Connection conn = null;
        PreparedStatement pst = null;
        ResultSet rs = null;
        try {
            conn = JdbcUtils.getConnection();
            String sql = "select * from users where `NAME`=?";
            pst = conn.prepareStatement(sql);
            pst.setString(1,"lisi");
            rs = pst.executeQuery();
            while (rs.next()){
                System.out.println("id="+rs.getObject("id"));
                System.out.println("name="+rs.getObject("NAME"));
                System.out.println("password="+rs.getObject("PASSWORD"));
                System.out.println("email="+rs.getObject("email"));
                System.out.println("birthday="+rs.getObject("birthday"));
                System.out.println("+++++++++++++++++++++++");
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }finally {
            JdbcUtils.release(conn,pst,rs);
        }
    }
}

 

posted on 2022-12-20 16:45  键盘敲烂的朱  阅读(49)  评论(0编辑  收藏  举报