当前位置: 首页 > article >正文

SQL 注入攻击

SQL 注入攻击了解吗?

攻击者在 HTTP 请求中注入恶意的 SQL 代码,服务器使用参数构建数据库 SQL 命令时,恶意 SQL 被一起构造,并在数据库中执行。

用户登录,输入用户名 lianggzone , 密码  123  or  1=1 ,如果此时使用参数构造的方法,就会出现select * from user where name = 'lianggzone' and password = '123' or '1' = '1'; 不管用户名和密码是什么内容,使查询出来的用户列表不为空。

如何防范 SQL 注入攻击?

使用预编译的 PrepareStatement 是必须的,但是一般我们会从两个方面同时入手。

Web 端

1)有效性检验。

2)限制字符串输入的长度

服务端

1)不用拼接 SQL 字符串

2)使用预编译的 PrepareStatement

3) 有效性检验。(为什么还要做有效性检验?第一准则,外部都是不可信的,防止攻击者绕过 Web 端请求)

4)过滤 SQL 需要的参数中的特殊字符。比如单引号、双引号。


http://www.kler.cn/a/553205.html

相关文章:

  • 神经网络|(十)概率论基础知识-正态分布及python仿真
  • EasyExcel 自定义头信息导出
  • Linux-GlusterFS进阶分布式卷
  • 华为最新OD机试真题-通过软盘拷贝文件-Python-OD统一考试(E卷)
  • Vision Transformer图像分类实现
  • Activity 任务栈 taskAffinity 用法
  • 【机器学习与数据挖掘实战】案例14:基于随机森林分类器的汽车公司客户细分预测
  • CMU 15-445 23Fall Lab 总结
  • ​33页PDF | 基于数字化转型的数据指标与标签体系应用架构设计方案
  • JavaScript 前端面试 4(作用域链、this)
  • 【nodejs+mysql2+docker】node后端开发+docker部署简记
  • 让大模型帮我设计crnn网络及可运行demo,gpt4o豆包qwendeepseek-r1
  • jenkins+docker自动发版java后端完整流程
  • draggable+el-tag 拖动元素有div宽度抖动问题
  • pycharm画图程序如何一步一步的调试
  • 技术分享:MyBatis SQL 日志解析脚本
  • Discuz! X3.5 根目录权限设置
  • 软件开源与AI开源的区别
  • Shapr3D在ipad上无法识别鼠标点击问题
  • 机器翻译中的编码器、自注意和解码器