防止sql注入记录

今天做项目时,leader要求项目必须实现sql注入的防护。虽然说听说过这个sql注入是通过在页面输入时,输入一些恶意的sql语句来达到欺骗数据库的目的,从而操作数据库,。

sql注入:
web页面表单的提交
输入域名或页面请求的查询字符串

防止方法
1.使用PreparedStatement对象,PreparedStatement是预编译的,也就是一条sql语句是在运行了一次之后,被DB的编译器编译后的执行代码被缓存下来,那么下次调用时只要是相同的预编译语句就不需要编译,只要将参数直接传入编译过的语句执行代码中
PreparedStatement对于批量处理可以大大提高效率.也叫JDBC存储过程

在执行SQL命令时,我们有二种选择:可以使用PreparedStatement对象,也可以使用Statement对象。无论多少次地使用同一个SQL命令,PreparedStatement都只对它解析和编译一次。当使用Statement对象时,每次执行一个SQL命令时,都会对它进行解析和编译。
这样黑客就无法将参数传入到sql语句中,因为PreparedStatement所包含的sql 语句不是动态编译的。

使用PreparedStatement:是Statement的子接口,可以传入带占位符的SQL语句,提供了补充占位符变量的方法

未完待续。。。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值