SQL注入与预编译SQL

1、SQL注入

SQL注入:是通过操作输入的数据来修改事先定义好的SQL语句,以达到执行代码对服务器进行攻击的方法。

由于没有对用户输入进行充分检查,而SQL又是拼接而成,在用户输入参数时,在参数中添加一些SQL关键字,达到改变SQL运行结果的目的,也可以完成恶意攻击。

实行SQL注入:

在这里插入图片描述

用户在页面提交数据的时候人为的添加一些特殊字符,使得sql语句的结构发生了变化,最终可以在没有用户名或者密码的情况下进行登录。
在这里插入图片描述

2、预编译SQL

预编译SQL有两个优势:
  • 性能更高:预编译SQL,编译一次之后会将编译后的SQL语句缓存起来,后面再次执行这条语句时,不会再次编译。(只是输入的参数不同)。
  • 更安全(防止SQL注入):将敏感字进行转义,保障SQL的安全性。

在这里插入图片描述

3、参数占位符

在Mybatis中提供的参数占位符有两种:${...} 、#{...}
  • #{…}
    • 执行SQL时,会将#{…}替换为?,生成预编译SQL,会自动设置参数值
    • 使用时机:参数传递,都使用#{…}
  • ${…}
    • 拼接SQL。直接将参数拼接在SQL语句中,存在SQL注入问题
    • 使用时机:如果对表名、列表进行动态设置时使用

注意事项:在项目开发中,建议使用#{…},生成预编译SQL,防止SQL注入安全。

4、使用预编译SQL(参数占位符)预防SQL注入

使用预编译SQL(参数占位符)预防SQL注入:

在这里插入图片描述

把整个' or '1'='1作为一个完整的参数,赋值给第2个问号(' or '1'='1进行了转义,只当做字符串使用)
在这里插入图片描述

相关推荐

  1. 编译真的能完美防御SQL注入吗?

    2023-12-05 23:10:04       58 阅读
  2. SpringBoot解析MyBatis编译SQL

    2023-12-05 23:10:04       29 阅读
  3. <span style='color:red;'>sql</span><span style='color:red;'>注入</span>

    sql注入

    2023-12-05 23:10:04      54 阅读
  4. <span style='color:red;'>SQL</span><span style='color:red;'>注入</span>

    SQL注入

    2023-12-05 23:10:04      52 阅读
  5. SQL注入

    2023-12-05 23:10:04       39 阅读
  6. <span style='color:red;'>SQL</span><span style='color:red;'>注入</span>

    SQL注入

    2023-12-05 23:10:04      39 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-05 23:10:04       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-05 23:10:04       100 阅读
  3. 在Django里面运行非项目文件

    2023-12-05 23:10:04       82 阅读
  4. Python语言-面向对象

    2023-12-05 23:10:04       91 阅读

热门阅读

  1. 深入了解HttpSession:Web开发中的用户状态管理

    2023-12-05 23:10:04       51 阅读
  2. Vue3的reactive、ref、toRef、toRefs用法以及区别

    2023-12-05 23:10:04       55 阅读
  3. SQL语句常用语法(开发场景中)

    2023-12-05 23:10:04       41 阅读
  4. 数据结构:链表应用:第8关:链表的逆转

    2023-12-05 23:10:04       54 阅读
  5. 【.NET Core】Linq查询运算符(一)

    2023-12-05 23:10:04       37 阅读
  6. 大数据技术发展

    2023-12-05 23:10:04       52 阅读
  7. 【brpc学习实践十三】基于brpc的redis client的实现

    2023-12-05 23:10:04       54 阅读
  8. RedisTemplate序列化配置

    2023-12-05 23:10:04       53 阅读
  9. k8s部署的四种方案

    2023-12-05 23:10:04       48 阅读
  10. Redis 如何批量删除指定前缀的Key

    2023-12-05 23:10:04       57 阅读
  11. 前端请求patch接口,只传入已修改字段值的字段

    2023-12-05 23:10:04       50 阅读
  12. PHP 判断给定两个时间是否在同一周,月,年

    2023-12-05 23:10:04       67 阅读