当ASP以其灵活、简单、实用、强大的特性迅速风靡全球网站的时候,其本身的一些缺陷、漏洞也正威胁着所有的网站开发者,继上一篇中介绍了一些IIS的系统漏洞及ASP的安全问题后,本期中将针对最新的ASP、IIS安全漏洞进行详细的探讨,请所有的ASP网站开发者密切关注,提高警惕。
bguTWI8bk %WAaoR&u IUSV\X9 本月初微软再次被指责对其出品的WEB服务器软件的安全问题不加重视。在微软的流行产品IIS
j+NsNIJq SEVER4.0中被发现存在一种被称为“非法HTR请求”的缺陷。据微软称,此缺陷在特定情况下会导致任意代码都可以在服务器端运行。但用发现这一漏洞的Internet安全公司eEye的CEO
-mqL[ h, Firas Bushnaq的话说:这只是冰山一角而已。Bushnaq说,微软隐瞒了些情况,比如黑客可以利用这一漏洞对IIS服务器进行完全的控制,而恰恰许多电子商务站点是基于这套系统的。
!1[ZfTX^a 3fdqFJ O w'zSV1 EKf! j3 CQ/ps,~M 下面罗列出了该IIS系统漏洞的详细情况:
%{ +>\0x `IH*~d] ~__rI-/_ ).8NZ
Aj IIS的最新安全漏洞
!(#d7R KSxZ4Y
( =t41-l |0xP'( 受影响的系统:
OXD*ZKi8 BT*{&'\/ %hN7K Y20T$5{# Internet Information Server 4.0 (IIS4)
]qO*(m:}o OSIf>1 t 4>\;
%eW2w@8] Microsoft Windows NT 4.0 SP3 Option Pack 4
^17i98w ~w"e 2a +r$ M 9 h_\OtoRa Microsoft Windows NT 4.0 SP4 Option Pack 4
mV#U=zqb!S \VHRI<$+5 7[It .F/0:) Microsoft Windows NT 4.0 SP5 Option Pack 4
A&L2&ofV&q Wh^wKF~% X{tfF!+iy rL|9Xru 公布日期:6.8.1999
. 9@y*_9 !;E{D &Rt^G 'W*ODAz6 microsoft已经证实了这个漏洞,但目前还没有提供可用的补丁程序。
~As_O6JI ,QPo%{:p ChRCsu~ O~D]C
grTwo 微软安全公告 (MS99-019):
!]l;n
Fd g4}K6)@ * \%b1 2aJ_[3p/h] 主题:非正常的 HTR 请求 漏洞
v?s%qb= T !n|4w$t"V ie}?}s !a^'Jbb 发布时间: 6.15.1999
/kNSB; _6]c f!H PYr'1D'
/PZxF 摘要:
Y;#H0v>E BoP,MpF I\Pw` M+-1/vR *@ 微软已经证实在其发布的WEB服务器产品Internet Information Server
A?"/ >LM 4.0中存在一个严重的系统漏洞,该漏洞导致对于IIS服务器的“服务拒绝攻击”,在这种情况下,可能导致任何2进制代码在服务器上运行。有关该漏洞的补丁将在近期发布,请所有IIS用户密切关注。
m4,inA:o l\HtP7] +%?\#E QJ rnRWL4 y;=/S?L.: 漏洞介绍:
"GB493=v U[|o!2$ '4,>#D8@O !+_X q$9_ IIS支持多种需要服务器端处理的文件类型,譬如:ASP、ASA、IDC、HTR,当一个WEB用户从客户端请求此类文件时,相应的DLL文件将自动对其进行处理。然而在ISM.DLL这个负责处理HTR文件的文件中被发现存在严重的安全漏洞。(注:HTR文件本身是用来远程管理用户密码的)
~RRS{\, cS RmC StU9r0` 该漏洞包含了一个在ISM.DLL中未经验证的缓冲,它可能对WEB服务器的安全运作造成两方面的威胁。首先,是来自服务拒绝攻击的威胁,一个来自非正常的对.HTR文件请求将导致缓存溢出,从而直接导致IIS崩溃,当这种情况发生时,无须重启服务器,但是IIS
^ wb 9 n WEB
BQL](Y" 服务器必须重新启动。另一个威胁更令人头痛,通过使用一个精心构建过的文件请求将可以利用标准的缓存溢出手段导致2进制代码在服务器端运行,在这种情况下,什么都可能发生!该漏洞不包括提供用来管理用户密码的功能的.HTR文件。
\T {<{<n ca,U>'(y S3gd'Bahq _bSn YhS nHl{'|~ 原理分析:
J=Hyoz+9 ^b6yN\,S *}=z^;_oq >j)y7DSE 至少在一个IIS的扩展名中(例如:ASP,IDC,HTR)存在溢出。我们推测溢出将在IIS把完整的URL传递给DLL去处理扩展名时发生。如果ISAPI
M i047-% ( DLL 没有正确的检查限制范围从而导致INETINFO.EXE产生一个溢出,用户就从可以远端执行2进制代码。攻击方法:向IIS发一个如下的HTTP请求:GET
nTCwLnX(O /[overflow].htr HTTP/1.0,IIS将崩溃。这里的[overflow]可以是3K长的代码。
qL~|bfN . H9a b}J,&eYD 大家可能对.HTR文件不是很熟悉,其实IIS具有让NT用户通过WEB目录/iisadmpwd/更改自己的口令的能力。而这个功能正是由一组.HTR文件和ISAPI的一个扩展DLL:
4%5 + ISM.DLL实现的。当一个完整的URL传递到ISM.DLL时,由于没有适当的大小限制的检查,就会导致溢出产生,从而使得服务器崩溃。HTR/ISM.DLL
k;Ask#rs ISAPI 是IIS4缺省安装。
rT';7>{g {ZKXT8' c|Fu6LF a ?u~?:a@K 解决途径:
@P/6NMjZ^ FY"csZ TV~S#yg+H 91M5F$ 由于目前微软尚未发布可供使用的补丁程序,因此我们只能做一些应急的防范。
]}L tf,9 s3y"y_u S@cKo&^ (lt{$0 ?wREX[Tqs 1、将.HTR扩展名从ISAPI DLL 的列表中删除
Wd?=RO`a s^HI%mdf ]K|td)1X qqSFy>`P 在你的NT桌面上,点击“开始”—>“程序”—>“Windows NT
OPC8fX5. 4.0 Option Pack”—>“Microsoft Internet Information Server”—>“Internet
xM**n3SZ` 服务管理器”;双击“Internet Information Server”;鼠标右键单击计算机名称并选择“属性”;在“主属性”下拉式菜单中选择“WWW服务”并点击“编辑”按钮;选择“主目录”文件夹,并点击“配置”按钮,在“应用程序映射”列表框中选中.HTR的相关映射,选择“删除”,并确定。
gmN$}Gy} t>h:s3c +^ `n- m JzmX~|=Xi <\oD4EE_ 2、安装微软提供的补丁程序,请密切关注以下网址
X9;51JV ;nAI;Qw L > *soc!# Y [Nu py,v http://www.microsoft.com/security nJY3 1(p l`."rei%) ;@H:+R+( c{[ lT2yxU http://www.microsoft.com/security/products/iis/CheckList.asp 75eZhs[b F<