Apache mime.types 不全导致上传不安全-php.rar漏洞

2008年12月19日 11:25 查看1515次 作者: 扶凯  【
文章分类:PHP安装配置

注意,经测试,本情况发生在少量配置有问题的服务器上.一般正式版apache无此问题.

一般的网站都会开放rar附件上传,并可能会保留原来文件名称,这从而可能导致一个很严重的问题,xxx.php.rar文件会被Apache当作php文件来执行, 造成极大的安全隐患 .

如何测试? 将你的某个php程序文件后缀名修改成  xxx.php.rar , 这时测试一下, 还是按照PHP文件解析执行,Apache并不会认为这是一个rar文件, 这是为什么呢?

原来,每遇到一种后双重后缀名(如xxx.php.rar)的文件,Apache都会去conf/mime.types 文件中检查最后一个后缀, 如果最后一个后缀并没有在mime.types文件中定义, 则使用前一个后缀来解释 , 因为在默认情况下,rar并未在mime.types中定义, 故Apache会使用php后缀来解释文件, 这就是漏洞的原因所在.

由此类推,如果使用xxx.jsp.ppp.rar 则会认为是jsp文件, 如果修改成xxx.shtml.rar ,则会识别成shtml文件.

a.php.c.d.e.rar 也是会被当成PHP文件解释的!
想想,不知道有多少网站存在这个问题?

那么针对网络管理员,如何杜绝这个隐患 ?
1.修改mime.types文件,在最后面加一条:
application/rar            rar
然后重新启动Apache,即可.

针对WEB管理员及WEB程序开发者,如何更安全?
1.只允许上传指定后缀名的文件,当然,要禁止掉rar格式文件上传.(但这条往往行不通,一般的网站都需要上传rar文件)
2.对上传后的文件进行强制重命名, 强制使用最后一个扩展名,如原始文件名为xxx.php.rar ,上传后强制重命名为 20080912.rar即可避免这个隐患.

早期版本的phpcms 2007, discuz, ecshop都存在这个漏洞,  或许你的网站被挂马,就是因此引起.

 

上面的文章是转的,我测试了一下,还真这样,不过修改mime.types是没有用的.

需要在http.conf中加入下面这些内容

AddType application/rar .rar
AddType application/x-compressed .rar
AddType application/x-rar .rar
AddType application/x-rar-compressed .rar
AddType application/x-rar-compressed; application/x-compressed .rar
AddType compressed/rar; application/x-rar-compressed .rar 
 

这样就不会出问题了,测试过了,加我上面这些是没有问题的。

责任编辑:抽烟的蚊子

给文章打个分先...

平均分:1.7(46 次)

-5 -4 -3 -2 -1 0 1 2 3 4 5
6

顶一下

发表我的见解...

  • 您的大名: 留空为匿名
  • 您的主页:
  • 您的邮箱:

看看大家怎么说...

  • 创意产品 发表于09年04月23日 17:22

    学习了

  • 某游客 发表于09年03月22日 19:47

    这种垃圾文章都发.. 诶 早点删掉吧

  • lxrm 发表于09年02月20日 17:16

    恩,实惠的东西,顶了

  • Summer 发表于09年02月01日 11:53

    你提供的方法没用,只堵住了rar这个后缀, 我上传一个 foo.php.dsfgfkjh 照样能执行。关键是要把未知 mime type 给堵住

  • skyblue 发表于08年12月23日 20:23

    如果是这样的话 那不单RAR 包括zip 7z啥的还有其他更多类型的文件类型都能被这么利用了?

  • 某游客 发表于08年12月19日 21:12

    呵呵 这个问题不普遍……

  • Leslee 发表于08年12月19日 17:14

    没有吧? 我在ubuntu下测试没有这个问题