技术分享:如何利用文件上传执行XSS?

boyanx6个月前技术教程20

利用文件上传实现XSS攻击是一个Hacking Web应用的很好机会,特别是无处不在的用户头像上传案例中,这就给予我们很多发现开发者错误的机会。基本的文件上传 XSS 攻击有以下几种。

1) 文件名

文件名本身可能就是网页的一部分可以造成反射,所以可以通过将 XSS 语句插入文件名中来触发反射。

尽管不是有意为之,但是这个 XSS 可以实践在
http://www.w3schools.com/jsref/tryit.asp?filename=tryjsref_fileupload_value。

2) 元数据

使用 exiftool(
http://www.sno.phy.queensu.ca/~phil/exiftool/) 工具可以修改 EXIF 元数据,从而在某些地方造成反射:

$ exiftool -FIELD=XSS FILE

例子:

$ exiftool -Artist=’ “><img src=1 onerror=alert(document.domain)>’ brute.jpeg

3) 内容

如果 Web 应用允许上传 SVG(一种图像类型)扩展名,则以下内容可以用来触发 XSS:

<svg xmlns="http://www.w3.org/2000/svg" onload="alert(document.domain)"/>

一个 POC 可以在这里看到 brutelogic.com.br/poc.svg。

4)源码

我们可以很容易的创建一张包含 javascript payload 的 GIF 图片,然后将这张图片当做源码加以引用。如果我们可以成功的注入相同的域名,如下所示,则这样可以有效的帮我们绕过 CSP(内容安全策略)防护(其不允许执行例如<script>alert(1)</script>

创建这样一张图片可以使用如下内容并将文件命名为 .gif 后缀:

GIF89a/*<svg/onload=alert(1)>*/=alert(document.domain)//;

GIF 文件标识 GIF89a 做为一个 javascript 的变量分配给 alert 函数。中间注释部分的 XSS 是为了以防图像被检索为 text/HTML MIME 类型时,通过请求文件来执行 payload。

我们通过下图可以发现,类 UNIX 命令的 PHP 函数 exif_imagetype() 和 getimagesize() 都会将这个文件识别为 GIF 文件。而一般的 Web 应用都是使用这些函数来验证图像类型的,所以这样一个文件是可以被上传的(但上传后可能会被杀毒软件查杀)。

更多可以用作 javascript 变量赋值的 ASCII 文件类型标识符,请参见
https://en.wikipedia.org/wiki/List_of_file_signatures 。

更多关于文件上传 XSS 的详尽示例,包括绕过像 GD 库等过滤的例子,请参见
https://github.com/d0lph1n98/Defeating-PHP-GD-imagecreatefro.gif 。

转自FreeBuf黑客与极客(FreeBuf.COM),黑客迷修改发布!

标签: js文件上传

相关文章

文件上传漏洞全面渗透姿势总结

文件上传的场景真的随处可见,不加防范小心,容易造成漏洞,造成信息泄露,甚至更为严重的灾难。比如某博客网站评论编辑模块,右上角就有支持上传图片的功能,提交带有恶意字符串的图片后,就直接可以显示在评论中了...

js获取上传文件类型以及大小的方法

前端web上传文件时,需要在上传之前判断一下文件的类型以及文件的大小,HTML为前端的标记语言是无法做到这一点,只能使用javascript 动态脚本代码来实现。js获取上传文件大小的方法示例代码:&...

安全漏洞之经典上传漏洞

0x01 概要说明文件上传漏洞可以说是日常渗透测试用得最多的一个漏洞,因为用它获得服务器权限最快最直接。但是想真正把这个漏洞利用好却不那么容易,其中有很多技巧,也有很多需要掌握的知识。俗话说,知己知彼...

DeepSeek从入门到精通(13)——上传文件功能

DeepSeek 提供的 上传文件功能 让你可以上传本地文件(如 PDF、Word、Excel、PPT、TXT 等),然后DeepSeek可以帮助你阅读、解析和提取文件中的信息,并回答你的相关问题。主...

文件太大上传不了?看这里,秒传

前言相信很多开发者,都做过文件上传的功能。简单的文件上传很容易,在PHP里两个函数就能搞定:file_existsmove_uploaded_file第一个函数判断文件是否存在,第二个函数上传文件。但...

AspNetCore中的文件上传与下载优化

在现代Web开发中,文件上传和下载是常见的功能需求。然而,随着文件大小的增加或网络环境的变化,传统的文件上传和下载方式可能会遇到性能瓶颈或用户体验问题。本文将深入讲解如何在AspNetCore中实现...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。