Pass-01&Pass-02
upload-labs-master
upload-labs-master:是上传文件的靶场
Pass-01
我们可以看出,在这里就是一个对文件格式的一个只有前端验证,格式为 .jpg .png .gif 三种格式,所以我们需要绕过前端验证就行。
第一种方式:绕过前端验证
进入页面,刷新页面,进入检查,注销掉前端检查文件格式的js,如下所示:
注销掉完成后,我们再上传,发现一次请求,该shell文件就会被上传。
第二种方式:Burp抓包·,改变文件后缀名。、
我们可以发现,可以显示传入后台文件。
显示后台文件路径:打开浏览器检查:找到如下:
Pass-02
MIME介绍
所以首先要搞清楚MIME在数据包的哪里,MIME是个什么
关于MIME,由百度百科可知
MIME(Multipurpose Internet Mail Extensions)多用途互联网邮件扩展类型。是设定某种扩展名的文件用一种应用程序来打开的方式类型,当该扩展名文件被访问的时候,浏览器会自动使用指定应用程序来打开。多用于指定一些客户端自定义的文件名,以及一些媒体文件打开方式。
即文件的后缀
常见的类型如下:
超文本标记语言文本 .html text/html
xml文档 .xml text/xml
XHTML文档 .xhtml application/xhtml+xml
普通文本 .txt text/plain
RTF文本 .rtf application/rtf
PDF文档 .pdf application/pdf
Microsoft Word文件 .word application/msword
PNG图像 .png image/png
GIF图形 .gif image/gif
JPEG图形 .jpeg,.jpg image/jpeg
au声音文件 .au audio/basic
MIDI音乐文件 mid,.midi audio/midi,audio/x-midi
RealAudio音乐文件 .ra, .ram audio/x-pn-realaudio
MPEG文件 .mpg,.mpeg video/mpeg
AVI文件 .avi video/x-msvideo
GZIP文件 .gz application/x-gzip
TAR文件 .tar application/x-tar
任意的二进制数据 application/octet-stream
出现在HTTP数据包中的可能位置有:
MIME信息头有:
MIME-Version:
这个头提供了所用MIME的版本号。这个值习惯上为1.0。
Content-Type:
它定义了数据的类型,以便数据能被适当的处理。有效的类型有:text,image,audio,video,applications,multipart和message。注意任何一个二进制附件都应该被叫做application/octet- stream。这个头的一些用例为:image/jpg, application/mswork,multipart/mixed,这只是很少的一部分。
Content-Transfer-Encoding:
这是所有头中最重要的一个,因为它说明了对数据所执行的编码方式,客户/MUA 将用它对附件进行解码。对于每个附件,可以使用7bit,8bit,binary ,quoted-printable,base64和custom中的一种编码方式。7bit编码是用在US ASCII字符集上的常用的一种编码方式,也就是,保持它的原样。8bit和binary编码一般不用。对人类可读的标准文本,如果传输要经过对格式有影响的网关时对其进行保护,可以使用quoted printable 。Base64是一种通用方法,在需要决定使用哪一种编码方法时,它提供了一个不用费脑子的选择;它通常用在二进制,非文本数据上。注意,任何非7bit 数据必须用一种模式编码,这样它就可以通过Internet邮件网关!
Content-ID:
如果Content-Type是message/external-body或multipart/alternative时,这个头就有用了,它超出了本文的范围。
Content-Description:
这是一个可选的头。它是任何信息段内容的自由文本描述。描述必须使用us-ascii码。
Content-Disposition:
一个试验性的头,它用于给客户程序/MUA提供提示,来决定是否在行内显示附件或作为单独的附件。
MIME段头(出现在实际的MIME附件部分的头),除了MIME-Version头,可以拥有以上任何头字段。如果一个MIME头是信息块的一部分,它将作用于整个信息体。例如,如果Content-Transfer-Encoding显示在信息(指整个信息)头中,它应用于整个信息体,但是如果它显示在一个MIME段里,它"只能"用于那个段中。
注意:其可以对自动对收到的邮件进行解密。
解题过程
所以我们先判断可以上传的文件类型以及MIME在本题中出现的位置
先上传一个jpg文件然后抓个包试试看
我们找到了MIMIE的位置,在Content-Type中
文件上传成功,说明还是png类型的文件可以传
那么这次就上传一个 php文件
弹出错误信息
这个提示和Pass01的提示不太一样
Pass01是弹窗形式,Pass02显然是发送了数据包页面返回的信息,所以应该是可以抓包的
于是抓包看看,然后修改Content-Type
将php的Content-Type修改和jpg一样的
然后在upload目录下找我们上传的文件
文件上传成功
再进行蚁剑连接!!