mybatis特殊字符及SQL注入

  • 方法一 转义字符
    用转义字符把特殊字符替换掉。
    XML转义字符
注意: 需要把;号带上,否则会出现代码错误!!
	&lt;     	<   	小于号   
	&gt;     	>   	大于号   
	&amp;     	&&apos;     	’   	单引号   
	&quot;     	"   	双引号   

示例代码:

<if test="startTime != null ">
	    AND order_date &gt;= #{startTime,jdbcType=DATE} 
	</if>
	<if test="endTime != null ">
	    AND order_date &lt;= #{endTime,jdbcType=DATE} 
	</if>
注意下,这里的startTime,endTime都是Date类型的~
  • 方法二 <![CDATA[ code ]]>

      使用 <![CDATA[ code ]]> 符号进行说明,将此类符号在xml文件中不进行解析 。
    

    示例代码

		<if test="startTime != null ">
		    AND <![CDATA[ order_date >= #{startTime,jdbcType=DATE}  ]]>
		</if>
		<if test="endTime != null ">
		    AND <![CDATA[ order_date <= #{endTime,jdbcType=DATE}  ]]>
		</if>

Mybatis 防止SQL注入

1. 采用“#{xxx}”这样的格式。若不得不使用“${xxx}”参数,做好过滤工作,来防止SQL注入攻击。

2. #{}:相当于JDBC中的PreparedStatement

3. ${}:是输出变量的值

4. #{}是经过预编译的,是安全的;${}是未经过预编译的,仅仅是取变量的值,是非安全的,存在SQL注入。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一介布衣+

做好事,当好人

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值