【数据库学习笔记】SQL注入及解决方法

SQL注入

以下面的代码为例:

我们假设下面的语句执行后返回的row不为空则为登陆成功

Statement statement= connection.createStatement();
statement.executeQuery("select * from accounts where username='"+username+"' and password='" + password+"'");

username 和 password 是读取用户输入的string 变量

这个时候,假设用户输入的用户名是

a

password是

' or 'a'='a

 

此时语句就会变成

select * from accounts where username='a' and password='' or 'a'='a'

这个时候,由于sql逻辑运算符的特性,运算逻辑是这样的

select * from accounts where (username='a' and password='') or ('a'='a')

注:这是不符合语法的,只是方便理解

所以,在这种情况下,无论你用户名输入的是什么,都会返回整个列表,也就是,都能登陆成功

这就是SQL注入

解决方法

使用PreparedStatement代替Statement

把上面的代码替换成:

// ?代表预留占位符
String query="select * from accounts where username=? and password=?";

// 把query预编译,占位符等待参数注入
// 我的理解是:
// 与直接执行不同的是,通过预编译,保存了语句结构
// 无论后面占位符注入的是什么,都不会改变这个结构(不会增加判断条件),只会为结构内的col筛选条件赋值
PreparedStatement psm= connection.prepareStatement(query);

// 赋值占位符, 第一个参数代表占位符位置
psm.setString(1,username);
psm.setString(2,password);

// 执行
psm.executeQuery();

这样就可以解决SQL注入

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值