mybatis中$和#的区别以及各自的使用场景

目录

一、# 符号和$ 符号区别:

# 符号:

$ 符号:

二、使用场景:

# 符号

$ 符号:

三、XML代码示例

四、总结:

五、扩展:sql注入介绍及危害


        在 MyBatis 中,$# 都是用于参数绑定的,但它们之间存在明显的差异,主要体现在参数的预处理方式和安全性上。

一、# 符号和$ 符号区别:

  • # 符号:

    • # 符号用于预编译 SQL 语句中的参数绑定。
    • MyBatis 会为这些参数生成 PreparedStatement 中的占位符 ?,并设置相应的参数值。
    • 这种方式是安全的,因为它可以防止 SQL 注入攻击。
  • $ 符号:

    • $ 符号用于直接替换 SQL 语句中的字符串。
    • MyBatis 不会为其生成 PreparedStatement 中的占位符,而是直接将其替换为相应的参数值。
    • 这种方式是不安全的,因为它可能导致 SQL 注入攻击,特别是在将字符串拼接到 SQL 语句中时

二、使用场景:

  • # 符号

    • 当需要绑定 SQL 语句中的参数值时,应使用 # 符号。
    • 适用于所有类型的参数,包括基本数据类型、String、集合、对象等。
    • MyBatis 会为参数生成相应的占位符,并自动进行类型转换和参数设置。
  • $ 符号:

    • 当需要动态构建 SQL 语句的某部分时,可以使用 $ 符号。但请注意,这可能会增加 SQL 注入的风险,因此应谨慎使用。
    • 通常用于表名、列名等动态变化的部分,而不是用于绑定参数值。

三、XML代码示例

<select id="findUserById" resultType="User">
<!--#{id} 表示一个参数占位符,MyBatis 会将其替换为实际的参数值,并生成相应的 PreparedStatement。-->
SELECT * FROM user WHERE id = #{id}</select>
<select id="findUserByColumnName" resultType="User">
<!--${columnName} 表示一个直接替换的字符串,MyBatis 会将其替换为实际的列名。而 #{value} 则是一个参数占位符,用于绑定参数值。-->
SELECT * FROM user WHERE ${columnName} = #{value}</select>

        需要注意的是,使用 $ 符号进行动态 SQL 构建时,必须确保传入的参数值是安全的,避免 SQL 注入的风险。一种常见的做法是使用白名单机制,只允许预定义的、安全的值作为动态 SQL 的部分。

四、总结:

  • # 符号用于参数绑定,生成 PreparedStatement 中的占位符,安全且推荐使用。
  • $ 符号用于直接替换字符串,不安全且应谨慎使用,主要用于动态构建 SQL 语句的某部分。

五、扩展:sql注入介绍及危害

        SQL注入是一种常见的计算机安全漏洞,它利用了对数据库执行SQL查询时未正确过滤或转义用户输入的情况。攻击者可以在输入框或参数中注入恶意的SQL代码,从而影响数据库的执行逻辑。

SQL注入的危害包括但不限于以下几点:

  1. 数据泄露:攻击者可以通过SQL注入获取未经授权的数据,包括用户信息、敏感数据甚至是整个数据库的内容。
  2. 数据篡改:攻击者可以修改数据库中的数据,包括插入虚假信息、篡改现有数据或者删除数据,导致数据的不一致性和损坏。
  3. 绕过认证:攻击者可以利用SQL注入绕过身份验证机制,以管理员权限执行操作,甚至获取系统控制权。
  4. 拒绝服务攻击:通过恶意构造的SQL查询,攻击者可以消耗数据库资源,导致数据库性能下降甚至瘫痪,从而造成拒绝服务。

        为了防范SQL注入攻击,在开发时需要尽量少使用$进行拼接,并没有必须使用$符号的时候。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/752904.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

关于大根堆,set重载运算符

题目描述 \,\,\,\,\,\,\,\,\,\,制定合理的日程能够帮助利用好时间进行加训&#xff0c;加训和加训。 \,\,\,\,\,\,\,\,\,\,新学期开始了&#xff0c;应该好好学习了&#xff01;凌晨两点整&#xff0c;加睡失败的你在为新一天的各项重要事件制定闹钟。 \,\,\,\,\,\,\,\,\,\, \,…

【SpringBoot】请求与响应参数 IoC与DI 总结

文章目录 ① —— 请求 ——一、简单参数 RequestParam1.1 参数与形参 命名相同1.2 参数与形参 命名不同 二、实体参数2.1 简单实体对象2.2 复杂实体对象 三、数组集合参数3.1 数组3.2 集合 RequestParam 四、日期参数 DateTimeFormat五、JSON参数 RequestBody六、路径参数 Pat…

C语言如何初始化字符数组?

一、问题 字符数组如何初始化&#xff0c;与数值型数组有什么不同&#xff1f; 二、解答 字符数组的初始化操作有以下⼏种⽅法&#xff1a; &#xff08;1&#xff09;逐个字符赋给数组中各元素 这是最容易理解的初始化字符数组的⽅式。例如&#xff0c;初始化⼀个字符数组。…

docker镜像管理基础-3

文章目录 镜像的概念docker镜像层docker存储驱动AUFSOverlayFSDeviceMapper docker registrydocker镜像的制作Docker Hubdocker镜像的获取镜像的生成基于容器制作镜像 镜像的导入与导出 镜像的概念 镜像可以理解为应用程序的集装箱&#xff0c;而docker用来装卸集装箱。 docke…

代码+视频,R语言使用BOOT重抽样获取cox回归方程C-index(C指数)可信区间

bootstrap自采样目前广泛应用与统计学中&#xff0c;其原理很简单就是通过自身原始数据抽取一定量的样本&#xff08;也就是取子集&#xff09;&#xff0c;通过对抽取的样本进行统计学分析&#xff0c;然后继续重新抽取样本进行分析&#xff0c;不断的重复这一过程N&#xff0…

简单实现接口自动化测试(基于python)

一、简介 本文从一个简单的登录接口测试入手&#xff0c;一步步调整优化接口调用姿势&#xff0c;然后简单讨论了一下接口测试框架的要点&#xff0c;最后介绍了一下我们目前正在使用的接口测试框架pithy。期望读者可以通过本文对接口自动化测试有一个大致的了解。 二、引言 …

text-generation-webui大模型部署

1 简介 text-generation-webui是一个挺好用的大模型部署UI&#xff0c;提供了很多便于交互的接口&#xff0c;安装部署好之后将model放置到对应的位置即可在网页访问&#xff0c;若是在服务器部署也可以通过ssh端口转发至公网服务器进行访问。 其中&#xff0c;模型的下载可参…

Android的三种动画详解(帧动画,View动画,属性动画)

Android的三种动画详解&#xff08;帧动画、View动画、属性动画&#xff09;_android动画效果大全-CSDN博客 1、帧动画 缺点是&#xff1a;占用内存较高&#xff0c;播放的是一帧一帧的图片&#xff0c;很少使用。 顺序播放预先定义的图片&#xff0c;类似于播放视频。 步骤…

代码随想录阅读笔记-字符串【替换数字】

题目 给定一个字符串 s&#xff0c;它包含小写字母和数字字符&#xff0c;请编写一个函数&#xff0c;将字符串中的字母字符保持不变&#xff0c;而将每个数字字符替换为number。 例如&#xff0c;对于输入字符串 "a1b2c3"&#xff0c;函数应该将其转换为 "anu…

PlayBook 详解

4&#xff09;Playbook 4.1&#xff09;Playbook 介绍 PlayBook 与 ad-hoc 相比&#xff0c;是一种完全不同的运用 Ansible 的方式&#xff0c;类似与 Saltstack 的 state 状态文件。ad-hoc 无法持久使用&#xff0c;PlayBook 可以持久使用。 PlayBook 剧本是 由一个或多个 “…

使用Docker搭建Nascab

使用Docker来部署Nascab能够让这个过程变得更加灵活和便捷&#xff0c;因为Docker可以在隔离的环境中运行应用程序&#xff0c;简化了部署和配置的复杂性。 使用Docker CLI部署Nascab docker run -d \ --name nascab \ -p 18080:80 \ -p 18443:443 \ -p 18090:90 \ -p 18021:…

Linux之shell变量

华子目录 什么是变量&#xff1f;变量的名称示例 变量的类型变量的定义示例 自定义变量查看变量&#xff08;自定义变量和全局变量&#xff09; 环境变量定义环境变量&#xff08;全局变量&#xff09;法一法二法三env&#xff0c;printenv&#xff0c;export注意 C语言与shell…

upload-labs 0.1 靶机详解

下载地址https://github.com/c0ny1/upload-labs/releases Pass-01 他让我们上传一张图片&#xff0c;我们先尝试上传一个php文件 发现他只允许上传图片格式的文件&#xff0c;我们来看看源码 我们可以看到它使用js来限制我们可以上传的内容 但是我们的浏览器是可以关闭js功能的…

蓝桥杯-粘木棍-DFS

题目 思路 --有n根木棍&#xff0c;需要将其粘成m根木棍&#xff0c;并求出最小差值&#xff0c;可以用DFS枚举出所有情况。粘之前有n根短木棍&#xff0c;粘之后有m根长木棍&#xff0c;那么让长木棍的初始长度设为0。外循环让所有的短木棍都参与粘&#xff0c;内循环让要粘的…

windows 11访问Debian10上的共享目录

步骤 要在Windows 11上访问Debian 10.0.0的共享目录&#xff0c;可以通过以下步骤来实现&#xff1a; 1. 设置Samba服务&#xff1a;在Debian系统上&#xff0c;需要安装并配置Samba服务&#xff0c;以便能够实现文件夹共享。Samba是一个允许Linux/Unix服务器与Windows操作系…

threejs 实现鼠标大面积选取场景内3d模型,SelectionBox API 案例使用

SelectionBox API 案例使用 这个函数创建了一个 3D 场景&#xff0c;包括一个相机、光源、多个立方体以及一个 WebGL 渲染器&#xff0c;并在页面上渲染这个场景 function init() {// 创建一个容器 div 元素并将其添加到页面的 body 中container document.createElement(div)…

php反序列化及其常见魔术方法及其触发条件

反序列化介绍&#xff1a; PHP对象反序列化操作是指将一个之前通过serialize()函数转换为字符串表示的PHP对象数据&#xff0c;还原成原始PHP对象结构的过程。当需要从存储&#xff08;如数据库、文件或网络传输&#xff09;中恢复对象状态时&#xff0c;会使用unserialize()函…

【爬虫】User-Agent反爬虫

指服务器端通过校验usr-agent 来区分正常用户和爬虫程序的手段&#xff0c;是较为初级的爬虫。 一般是在做请求的 header 中。 user-agent 记录了请求的设备信息&#xff0c;如果在请求的时候没带 user-agent 可以视为爬虫故意请求&#xff0c;对这样的请求服务器可以拦截。 使…

C# Array(进阶)_Lambda表达式_冒泡排序_集合

文章目录 数组操作与高阶方法Lambda表达式Lambda表达式在C#中的应用及练习 数组排序&#xff1a;深入理解冒泡排序与选择排序冒泡排序原理 选择排序原理 选择排序和冒泡排序的区别 C#排序&#xff1a;掌握Sort()方法的使用集合类型全览&#xff1a;C#集合的使用详解C# 中的集合…

2024年阿里云数据库价格_云数据库收费标准最新

2024年阿里云数据库价格查询&#xff0c;云数据库优惠活动MySQL版2核2GB 50GB配置99元一年&#xff0c;续费不涨价&#xff0c;续费也是99元1年&#xff0c;云数据库MySQL基础系列经济版 2核4GB 100GB配置227元1年&#xff0c;RDS SQL Server云数据库2核4G配置299元1年&#xf…