站长

2021年,SQL注入死透了么?

作者:admin 2021-04-24 我要评论

本文转载自微信公众号「小姐姐味道」,作者小姐姐养的狗 。转载本文请联系小姐姐味道公众号。 很长一段时间,我认为后端开发,在安全性方面最容易出问题的地方就...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

本文转载自微信公众号「小姐姐味道」,作者小姐姐养的狗 。转载本文请联系小姐姐味道公众号。

很长一段时间,我认为后端开发,在安全性方面最容易出问题的地方就在于SQL注入。通过 where 1=1这种魔幻的SQL写法,就可以很容易的对一个存在问题的系统进行攻击,以至于最终演进出sqlmap这样的神器存在。

后来的fastjson刷新了我的认知,这个框架也算是对互联网安全概念的一种推动。连不懂技术的老板,都知道fastjson快的要命,作为程序员安全理念就得到了一次提升。

为什么对sql注入情有独钟?因为开发人员和SQL打交道的地方太多了。甚至有的专门开发报表的同学,写的SQL行数,比写的代码行数还多!

问题是。很久很久之前,早在10年前,就有人在喊SQL注入已经死掉了,但时至今日,依然有一大批的SQL注入教程和SQL注入的案例。

SQL注入是漏洞之王,这可不是吹的。

当然在这方面,PHP的贡献最大,Java甘拜下风。

SQL注入流行的原因,就是开发人员对自己太自信了,或者使用的工具太原始了,没有经过框架层进行一次过滤。如果你用了Java界的MyBatis或者JPA,发生SQL注入的可能性就变的非常的低。现在PHP也有了类似于thinkphp一样的框架,代表着能搞的SQL注入漏洞已经越来越少了。

但不代表着没有,只是门槛提高了。我们以MyBatis为例,看一下到底还能不能发生SQL注入。

MyBatis依然存在SQL注入

使用Mybatis的同学,第一个接触的概念,就是#和$的区别。这两个符号非常的像Shell中的魔幻符号,但好在只有两种情况。

  • # 代表的是使用sql预编译方式,安全可靠
  • $ 代表着使用的是拼接方式,有SQL注入的风险

比如下面这个xml配置,就是一个绝对安全的写法。因为整个#{id}会被替换成?。

  1. <select id="queryAll"  resultMap="resultMap"> 
  2.   SELECT * FROM order WHERE id = #{id} 
  3. </select> 

但可惜的是,有些场景,并不能使用预编译方式(或者你仅仅是不知道或者懒)。像一些代码重构,把表名/列名/排序等字段,动态传入的时候,不可避免的就需要SQL拼接的方式,SQL注入依然有搞头。

但更容易发生问题的,还是LIKE和IN等类似的语句。

下面是两句Like模糊查询的写法,实际测试会发现,使用#竟然不好使了,会报错,需要使用sql拼接的$。问题由此发生。

  1. SELECT * FROM order WHERE name like '%#{name}%'  //会报语法错 
  2. SELECT * FROM order WHERE name like '%${name}%'  //可以运行 

而正确的写法,应该使用函数拼接。但是工期压死人,在不知不觉间,大多数人就选择了简单的写法。毕竟功能第一嘛,也是体现工作量的最主要方式。

  1. SELECT * FROM order WHERE  name like concat(‘%’,#{name}, ‘%’) //正确的写法 

同样的问题,存在于IN语句。

  1. in (#{tag}) //报错 
  2. in (${tag}) //可以运行 

既然几个字符就可以运行,当然没人选择下面复杂的写法。

  1. tag in 
  2. <foreach collection="tag" item="item" open="("separatosr="," close=")"> 
  3. #{tag}  
  4. </foreach> 

还有order by,也千万不要掉以轻心,一不小心就会万劫不复。

  1. SELECT * FROM order order by createDate #{sortType} //报错 
  2. SELECT * FROM order order by createDate ${sortType} //正常 

这种情况下,就需要把sortType搞成白名单了。不就一个ASC和DESC了,你给我传一个长长的串,是怎么回事?

总结

SQL注入在2021年,依然存在,只不过门槛提高了。现在SQL注入减少,都是框架的功劳,和程序员的水平没半毛关系。sql拼接的情况永远不会消失,因为这是最快捷简单的方式,会让人欲罢不能。无数的外包项目,十几年躺尸不动的系统比比皆是,寄希望于在框架层全部消灭SQL注入,是一个梦想。

因为它的对手,是人性的懒惰。谁也无法战胜它。

【责任编辑:赵宁宁 TEL:(010)68476606】
本文转载自网络,原文链接:http://mp.weixin.qq.com/s?__biz=MzA4MTc4NTUxNQ==&mid=2650523591&idx=1&sn=dfe099fb7d626d42786c12736cbfef0a&chksm=8780c003b0f7491512a45437ce04c1bf737e92b612e7961f176eaeb87ff6b24d07ab08ca64d2&mpshare=1&s

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • 优质而不是大量 漏洞管理中的数据问题

    优质而不是大量 漏洞管理中的数据问题

  • SITA称航空客运系统遭遇数据泄露事件

    SITA称航空客运系统遭遇数据泄露事件

  • 白宫警告微软Exchange服务遭黑客攻击

    白宫警告微软Exchange服务遭黑客攻击

  • 发现一个木马,竟然偷传我珍藏几十G的

    发现一个木马,竟然偷传我珍藏几十G的