menu arrow_back 湛蓝安全空间 |狂野湛蓝,暴躁每天 chevron_right ... chevron_right OKLite v2.0.0 后台更新压缩包导致getshell chevron_right OKLite v2.0.0 后台更新压缩包导致getshell.md
  • home 首页
  • brightness_4 暗黑模式
  • cloud
    xLIYhHS7e34ez7Ma
    cloud
    湛蓝安全
    code
    Github
    OKLite v2.0.0 后台更新压缩包导致getshell.md
    3.02 KB / 2021-07-15 19:58:15
        OKLite v2.0.0 后台更新压缩包导致getshell
    ========================================
    
    一、漏洞简介
    ------------
    
    OKlite
    2.0.0管理后台支持压缩包升级,攻击者可以构造包含一句话木马的压缩包文件之后上传到目标服务器,目标服务器在升级过程中会自动解压该压缩包,将一句话木马解压出来,从而导致Getshell。
    
    二、漏洞影响
    ------------
    
    OKLite v2.0.0
    
    三、复现过程
    ------------
    
    ### 漏洞分析
    
    文件位置:`OKLite_2.0.0\framework\view\update_index.html`逻辑代码:zip压缩包升级时会自动调用update类中的zip函数来构造上传表单:
    
    ![1.png](./resource/OKLitev2.0.0后台更新压缩包导致getshell/media/rId25.png)
    
    文件位置:`OKLite_2.0.0\framework\admin\update_control.php`代码逻辑:调用zip函数来构造zip上传表单
    
    ![2.png](./resource/OKLitev2.0.0后台更新压缩包导致getshell/media/rId26.png)
    
    文件位置:`OKLite_2.0.0\framework\libs\form.php`代码逻辑:格式化表单信息
    
    ![3.png](./resource/OKLitev2.0.0后台更新压缩包导致getshell/media/rId27.png)
    
    文件位置:`OKLite_2.0.0\framework\view\update_zip.html`代码逻辑:使用上传的zip文件进行升级
    
    ![4.png](./resource/OKLitev2.0.0后台更新压缩包导致getshell/media/rId28.png)
    
    文件位置:`OKLite_2.0.0\framework\admin\update_control.php`代码逻辑:解压压缩包进行升级
    
    ![5.png](./resource/OKLitev2.0.0后台更新压缩包导致getshell/media/rId29.png)
    
    文件位置:`OKLite_2.0.0\framework\libs\phpzip.php`代码逻辑:解压缩更新包,在解压时未做任何检查操作
    
    ![6.png](./resource/OKLitev2.0.0后台更新压缩包导致getshell/media/rId30.png)
    
    文件位置:`OKLite_2.0.0\framework\admin\update_control.php`代码逻辑:执行程序升级
    
    ![7.png](./resource/OKLitev2.0.0后台更新压缩包导致getshell/media/rId31.png)
    
    之后会逐一匹配压缩包中的文件,如果未匹配到会直接解压到根目录下面,所以我们这里可以构造一个shell.zip,之后在压缩包中放置包含一句话木马的shell.php文件,之后进行更新,直接可以Getshell\~
    
    ### 漏洞复现
    
    构造shell.zip文件如下:
    
    ![8.png](./resource/OKLitev2.0.0后台更新压缩包导致getshell/media/rId33.png)
    
    之后选择压缩包升级,上传压缩包
    
    ![9.png](./resource/OKLitev2.0.0后台更新压缩包导致getshell/media/rId34.png)
    
    ![10.png](./resource/OKLitev2.0.0后台更新压缩包导致getshell/media/rId35.png)
    
    之后点击"开始升级"进行升级:
    
    ![11.png](./resource/OKLitev2.0.0后台更新压缩包导致getshell/media/rId36.png)
    
    之后在网站根目录下可以看到shell.php文件生成:
    
    ![12.png](./resource/OKLitev2.0.0后台更新压缩包导致getshell/media/rId37.png)
    
    之后使用菜刀远程连接:![13.png](./resource/OKLitev2.0.0后台更新压缩包导致getshell/media/rId38.png)
    
    成功getshell![14.png](./resource/OKLitev2.0.0后台更新压缩包导致getshell/media/rId39.png)
    
    参考链接
    --------
    
    > https://xz.aliyun.com/t/8130\#toc-3
    
    
    links
    file_download