文件上传漏洞——解析、验证、伪造(二)

之前做了一篇文件上传漏洞的文章,但是知识点和靶场都没讲完,所以这篇文章接着讲。

%00截断绕过

文件上传漏洞——解析、验证、伪造(二)_第1张图片
%00实际上就是十六进制的0x00,就是表示ASCII码值为0,有些函数在处理这个字符的时候会把这个当做结束符。在上传文件的时候如果遇到了白名单机制,只允许上传jpg格式。这时候可以使用%00截断。
思路就是上传一个1.php%00.jpg传参之后,有些过滤都是直接匹配字符串,然后允许上传,但是php的函数去执行的时候读取到0x00认为这是结束符。抓住一点图片存储路径可控
文件上传漏洞——解析、验证、伪造(二)_第2张图片
在保存路径的位置使用%00截断,这样这个上传的1.jpg的马儿最后会被保存为example.php执行
这里推荐一种一句话木马的写法


这样写get和post都能传参。
文件上传漏洞——解析、验证、伪造(二)_第3张图片

%00截断绕过(二)

文件上传漏洞——解析、验证、伪造(二)_第4张图片
这题其实和第一题差不多就是路径的传参变成了post传参。而get传参是经过url编码的,而修改post的话就通过抓包然后修改hex值在十六进制里00是结束的意思。
文件上传漏洞——解析、验证、伪造(二)_第5张图片
抓包在路径上附上example.phpa这加a是为了修改a的hex值为00截断
使服务器存储的这个文件为example.php
文件上传漏洞——解析、验证、伪造(二)_第6张图片
即可传入绕过上传php文件。

图片马绕过

文件上传漏洞——解析、验证、伪造(二)_第7张图片
这里看到程序检查了上传文件的前两个字节,就是查看了文件头,所以这题只需要制作一只图片马即上传绕过
文件上传漏洞——解析、验证、伪造(二)_第8张图片

getimagesize图片类型绕过

文件上传漏洞——解析、验证、伪造(二)_第9张图片
这里有一个getimagesize函数
getimagesize() 函数用于获取图像大小及相关信息,成功返回一个数组,失败则返回 FALSE 并产生一条 E_WARNING 级的错误信息。
如果不能访问 filename 指定的图像或者其不是有效的图像,getimagesize() 将返回 FALSE 并产生一条 E_WARNING 级的错误。
所以这里制作一个完整的图片马即可上传绕过。
文件上传漏洞——解析、验证、伪造(二)_第10张图片

php_exif模块图片类型绕过

文件上传漏洞——解析、验证、伪造(二)_第11张图片
exif_imagetype() 读取一个图像的第一个字节并检查其签名。
本函数可用来避免调用其它 exif 函数用到了不支持的文件类型上或和 $_SERVER[‘HTTP_ACCEPT’] 结合使用来检查浏览器是否可以显示某个指定的图像。
还是检查图片,所以图片马上传即可。

二次渲染绕过

文件上传漏洞——解析、验证、伪造(二)_第12张图片
二次渲染:就是根据用户上传的图片,新生成一个图片,将原始图片删除,将新图片添加到数据库中。比如一些网站根据用户上传的头像生成大中小不同尺寸的图像。但是图片的内容是不会变的。所以还是图片马上传即可

条件竞争绕过

竞争条件:指发生在多个线程同时访问同一个共享代码、变量、文件等没有进行锁操作或者同步操作的场景中。
文件上传漏洞——解析、验证、伪造(二)_第13张图片
开发者在进行代码开发的时候常常倾向于认为代码会以线性的方式执行,而且忽略了并忽视了并行服务器开发执行多个线程。

线程同步机制确保两个及以上的并发进程或线程不同执行某些特定的程序段,也称之为临界区,一般而言我们是上传了文件,上传了但是最后却因为过滤或者因为其他原因被删除了,那么我们可以使用条件竞争,我们实际上是unlink,是和删除文件的函数进行竞争。
就是我们不断发送上传包,然后我们不断地访问那个我们上传去的文件地址,我们就是和服务器删除的函数比手速,我们可以上传一个php然后访问后,有这个php去写一个一句话木马。手速不够快使用burp爆破

';file_put_contents('1.php',$a)?>

因为这里不好竞争,所以就不演示了。

move_uploaded_file()截断

文件上传漏洞——解析、验证、伪造(二)_第14张图片
move_uploaded_file()函数功能如下:
文件上传漏洞——解析、验证、伪造(二)_第15张图片
这题其实和前面的00截断做法一样
文件上传漏洞——解析、验证、伪造(二)_第16张图片
文件上传漏洞——解析、验证、伪造(二)_第17张图片
上传即可获得shell.

你可能感兴趣的:(Discard)