码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 利用mybatis框架时,常见的三种sql注入方式


    什么是Sql注入

    Sql注入是web应用中最常见的一种漏洞,其实质就是攻击者可以通过拼接sql来对数据库进行攻击。在java项目中,随着预编译和ORM框架(如Mybatis)的使用,这样的问题也会随之减少,但是,在mybatis使用不当的情况下,也会造成sql注入。

    Mybatis的SQL注入

    在java项目中,mybatis的sql语句通常是写在xml文件中。编写xml语句时候,支持两种参数符号,一种是#,一种是KaTeX parse error: Expected ‘EOF’, got ‘#’ at position 4: ,其中#会使用预编译,而是拼接sql。在Mybatis中,sql注入很容易产生于以下三种情况:

    1、使用模糊查询

    select * from student where name like '%#{张三}%'
    
    • 1

    上面的sql语句使用了模糊查询,但是这个sql在mybatis中会报错,因为没法对其进行预编译,但是改为$时就正确了,但是这样会造成sql注入的漏洞,因此推荐下面的写法:

    select * from student where name like concat('%', #{张三}, '%"}
    
    • 1

    2、in之后跟多个参数
    在in之后的多个查询参数使用#符号时,同样会报错

    select * from student where id in (#{ids})
    
    • 1

    正确写法是利用foreach,而不是将#换成$,如下所示:

    select * from student where id in
    
      #{id}
      
    
    • 1
    • 2
    • 3
    • 4

    3、order by之后
    这种场景应当在Java层面做映射,设置一个字段/表名数组,仅允许用户传入索引值。这样保证传入的字段或者表名都在白名单里面。需要注意的是在mybatis-generator自动生成的SQL语句中,order by使用的也是$,而like和in没有问题。

  • 相关阅读:
    【JAVA并发】二、JAVA是如何解决并发问题的
    功能测试求职难,现在不懂自动化测试连外包都进不去了?
    R语言计算两个向量成对元素的最小值:使用pmin函数计算dataframe数据中多个数据列的逐行最小值
    进阶笔录-深入理解Java线程之Synchronized
    开源的网站数据分析统计平台——Matomo
    【mysql】遇到的问题及解决办法(在centos下)
    外包干了3个月,技术退步明显。。。。。
    如何进行高性能架构的设计
    【深度学习实验】卷积神经网络(三):自定义二维卷积层:步长、填充、输入输出通道
    Unity Text文字超过长度显示为省略号
  • 原文地址:https://blog.csdn.net/geejkse_seff/article/details/126616253
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号