File Upload

File Upload

File Upload(文件上传),Web应用程序的安全漏洞,如果应用程序未能正确验证和限制用户上传文件的类型、大小和内容。攻击者可以通过构造特制的文件来绕过这些验证,上传包含恶意代码的文件,并在服务器上执行恶意操作。

Low

可以看到代码没有验证上传文件的类型,代码没有限制上传文件的大小。

我们使用cobaltstrike创建一个Windows可执行程序的后门上传。(正常情况下会直接被window安全中心拦截隔离,这里做测试用,先允许此后门的存在)

我们顺着这个目录去找这个文件, 可以看到确实上传成功了

随后,我们在cs的客户端就可以查看,进行会话交互、提权、浏览探测。

Medium

这里对文件类型和大小进行了验证,仅允许大小为100000 字节的 JPEG 和 PNG 类型的文件上传.

我们在上传时使用先将文件的后缀修改为png,然后在burp中抓包修改文件后缀即可上传成功。

High

代码在文件上传方面做了一改进,包括文件类型验证、文件大小限制、以及通过 getimagesize() 函数进一步验证文件是否是图片。

所以我们使用图片木马+文件包含来实现上传

将木马文件的内容复制到图片上面,通过上传图片,把木马传进去。

使用 copy 命令,通过 /b 选项将二进制文件合并,/a 选项将文件连接在一起。

test.pngshell.txt 合并成一个新的文件 new.png

上传文件new.png 上传成功

此时 我们利用 file inclusion的漏洞加载图片,成功解析,此时可以使用蚂剑或类似的工具进行连接,此处不做演示

相关推荐
板鸭〈小号〉9 小时前
Socket网络编程(1)——Echo Server
开发语言·网络·php
kjl53656615 小时前
Redis配置文件(redis.conf)
redis·bootstrap·php
東雪蓮☆17 小时前
LNMP 环境部署 WordPress
linux·运维·mysql·nginx·php
Gary Studio1 天前
ESP32 IDF GET_HTTPS
网络协议·https·php
迎風吹頭髮1 天前
UNIX下C语言编程与实践41-UNIX 单线程 I/O 超时处理:终端方式、信号跳转方式与多路复用方式
c语言·php·unix
心静财富之门1 天前
【无标题】标签单击事件
开发语言·php
weixin_446260851 天前
快速构建网站的利器——Symfony PHP框架
开发语言·php·symfony
朝新_1 天前
【EE初阶 - 网络原理】网络通信
java·开发语言·网络·php·javaee
-dcr1 天前
22.Nginx 服务器 LNMP项目
运维·服务器·nginx·php·lnmp
qq_252924192 天前
PHP 8.0+ 极限性能优化与系统级编程
开发语言·性能优化·php