MyBatis中怎么实现SQL注入攻击

发布时间:2021-07-05 18:33:54 作者:Leah
来源:亿速云 阅读:414

MyBatis中怎么实现SQL注入攻击,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。


1、模糊查询

Select * from news where title like ‘%#{title}%'

在这种情况下使用#程序会报错,新手程序员就把#号改成了$,这样如果java代码层面没有对用户输入的内容做处理势必会产生SQL注入漏洞。

正确写法:

select * from news where tile like concat(‘%',#{title}, ‘%')

2、in 之后的多个参数

in之后多个id查询时使用# 同样会报错,

Select * from news where id in (#{ids})

正确用法为使用foreach,而不是将#替换为$

`id in`
`<foreach collection="ids" item="item" open="("separatosr="," close=")">`
`#{ids}` 
`</foreach>`

3、order by 之后

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

二、实战思路

我们使用一个开源的cms来分析,java sql注入问题适合使用反推,先搜索xml查找可能存在注入的漏洞点–>反推到DAO–>再到实现类–>再通过调用链找到前台URL,找到利用点,话不多说走起

1、idea导入项目

Idea首页 点击Get from Version Control,输入https://gitee.com/mingSoft/MCMS.git

下载完成,等待maven把项目下载完成

MyBatis中怎么实现SQL注入攻击

2、搜索$关键字

Ctrl+shift+F 调出Find in Path,筛选后缀xml,搜索$关键字

MyBatis中怎么实现SQL注入攻击

根据文件名带Dao的xml为我们需要的,以IContentDao.xml为例,双击打开,ctrl +F 搜索$,查找到16个前三个为数据库选择,跳过,

MyBatis中怎么实现SQL注入攻击

继续往下看到疑似order by 暂时搁置

MyBatis中怎么实现SQL注入攻击

继续往下看发现多个普通拼接,此点更容易利用,我们以此为例深入,只查找ids从前端哪里传入

MyBatis中怎么实现SQL注入攻击

3、搜索映射对象

Mybatis 的select id对应要映射的对象名,我们以getSearchCount为关键字搜索映射的对象

MyBatis中怎么实现SQL注入攻击

搜到了IContentDao.java,IContentDaoimpl.java和McmsAction.java,分别对应映射的对象,对象的实现类和前端controler,直接跳转到controler类

MyBatis中怎么实现SQL注入攻击

发现只有categoryIds与目标参数ids相似,需进一步确认,返回到IContentDao.java按照标准流继续反推

MyBatis中怎么实现SQL注入攻击

找到ids为getSearchCount的最后一个参数,alt+f7查看调用链

MyBatis中怎么实现SQL注入攻击

调转到ContentBizImpl,确认前台参数为categoryIds

MyBatis中怎么实现SQL注入攻击

返回到McmsAction,参数由BasicUtil.getString接收,

MyBatis中怎么实现SQL注入攻击

跟进BasicUtil.getString

MyBatis中怎么实现SQL注入攻击

继续跳到SpringUtil.getRequest(),前端未做处理,sql注入实锤

MyBatis中怎么实现SQL注入攻击

4、漏洞确认

项目运行起来,构造sql语句http://localhost:8080/ms-mcms/mcms/search.do?categoryId=1%27)%20%20or+updatexml(1,concat(0x7e,(SELECT+%40%40version),0x7e),1)%23 得到mysql的版本5.7.27,验证注入存在。

MyBatis中怎么实现SQL注入攻击

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。

推荐阅读:
  1. 如何防止sql注入攻击
  2. sql注入攻击指的是什么

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

mybatis

上一篇:Java中Exception和Error的区别是什么

下一篇:Python多线程以及多线程中join()的使用方法

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》