码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • #{} ${} 解析


    #{}是预编译处理,是占位符 ,加 ’ ’。 ${}是字符串替换,是拼接符,不加’ ’

    #{}
    Mybatis在处理#{}的时候会将sql中的#{}替换成占位符 ?号,调用PreparedStatement来赋值,在值的两端加上单引号,可以防止sql注入

    select * from user where name = #{userName};设userName=sss
    看日志我们可以看到解析时将#{userName}替换成了 ?
    select * from user where name = ?;
    然后再把yuze放进去,外面加上单引号
    select * from user where name ='sss'
    
    • 1
    • 2
    • 3
    • 4
    • 5

    M y b a t i s 在处理 {} Mybatis在处理 Mybatis在处理{}的时候就是把${}替换成变量的值,不加单引号。调用Statement来赋值

    select * from user where name = #{userName};设userName=yuze
    看日志可以发现就是直接把值拼接上去了,不加引号
    select * from user where name = yuze;
    这极有可能发生sql注入
    
    • 1
    • 2
    • 3
    • 4

    为什么#{}可以有效防止sql注入?
    预编译机制,预编译是提前对SQL语句进行预编译 预编译完成之后,SQL的结构已经固定,即便用户输入非法参数,也不会对SQL的结构产生影响,从而避免了潜在的安全风险。

    在某些特殊场合下只能用${},不能用#{}。
    例如:在使用排序时ORDER BY ${id},如果使用#{id},则会被解析成ORDER BY “id”,这显然是一种错误的写法。

  • 相关阅读:
    高数 |【2020数一真题】部分错题及经典题自用思路整理
    go面试题
    可用性测试的理解
    每日五道java面试题之mysql数据库篇(五)
    ElasticSearch(超详细解说)[springBoot整合ES并简单实现增删改查]
    matlab写shpfile文件(字段名改为中文)
    linux内核中的SPI
    10. python字典
    Web开发-基础知识扫盲
    mongodb(快速上手)(一)
  • 原文地址:https://blog.csdn.net/weixin_45511599/article/details/126119884
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号