|
一位高手整理的IIS FAQ
* K5 l* H3 A3 e3 @% ]下面是一位高手整理的问题精华,大家好好看看吧,收获肯定很大的! 6 l# q& b1 M- Q) m3 X+ p& B
1.如何让asp脚本以system权限运行 8 Y Y. x7 x& `; ~; ~
修改你asp脚本所对应的虚拟目录,把"应用程序保护"修改为"低".... " M+ }2 q+ H; w: j! Z- P3 o4 }
2.如何防止asp木马 5 r- y# V" D4 [$ x5 q
基于FileSystemObject组件的asp木马 cacls %systemroot%\system32\scrrun.dll /e /d guests //禁止guests使用 7 F. {& D6 t' }" l3 | D- y
regsvr32 scrrun.dll /u /s //删除
* j b3 }& l% {: S4 A 基于shell.application组件的asp木马
" |. f W/ N: L) I cacls %systemroot%\system32\shell32.dll /e /d guests //禁止guests使用 # m- X9 W$ B$ R/ B8 d& B
regsvr32 shell32.dll /u /s //删除
+ ^+ n! |7 U# C/ z3.如何加密asp文件 8 e( ~& B2 N4 j& d' a
从微软免费下载到sce10chs.exe 直接运行即可完成安装过程。 ' ~. Q* `2 |. ?, ^6 p8 l% |- x& @
安装完毕后,将生成screnc.exe文件,这是一个运行在DOS PROMAPT的命令工具。
: S4 v& \% S5 R 运行screnc - l vbscript source.asp destination.asp
6 [( Y2 y! |; x2 @ 生成包含密文ASP脚本的新文件destination.asp 9 G& Y; w. t, [, L/ B/ Z8 I3 z
用记事本打开看凡是""之内的,不管是否注解,都变成不可阅读的密文了
1 i z0 {' y" i0 V/ C 但无法加密中文。
9 e3 f6 B8 G7 v3 B; ~1 Q4.如何从IISLockdown中提取urlscan ( K( x5 L5 G7 p, H/ g
iislockd.exe /q /c /t:c:\urlscan + L7 h( u7 Y& {3 [; w0 {
5.如何防止Content-Location标头暴露了web服务器的内部IP地址
( x) i$ H. b6 } |5 z 执行 * X g+ h9 N4 r8 ~: S0 p
cscript c:\inetpub\adminscripts\adsutil.vbs set w3svc/UseHostName True ; a: p) ]! ]! T* O; O
最后需要重新启动iis m9 z* @8 K' e9 l7 x
6.如何解决HTTP500内部错误
, u* D7 J# ^- D# `6 R$ C iis http500内部错误大部分原因
% o& p+ ^! {. W" b 主要是由于iwam账号的密码不同步造成的。
! g, J) n# u) ~; q7 ? 我们只要同步iwam_myserver账号在com+应用程序中的密码即可解决问题。
5 M+ c% V' h! D4 I 执行 1 R7 U- X$ \: p% G& W
cscript c:\inetpub\adminscripts\synciwam.vbs -v
7 m' k9 T* x2 h0 @7.如何增强iis防御SYN Flood的能力
, ^# C& j4 T9 p3 R6 J; | Windows Registry Editor Version 5.00 , w8 z' D) E8 M2 \! s
[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters] ; K7 o+ b8 |1 B2 x" L9 n4 ^& K" Z
启动syn攻击保护。缺省项值为0,表示不开启攻击保护,项值为1和2表示启动syn攻击保护,设成2之后 2 S2 R# X7 t7 C0 G
安全级别更高,对何种状况下认为是攻击,则需要根据下面的TcpMaxHalfOpen和TcpMaxHalfOpenRetried值 设定的条件来触发启动了。这里需要注意的是,NT4.0必须设为1,设为2后在某种特殊数据包下会导致系统重启。 , n* e* {! Z; U2 c3 n
"SynAttackProtect"=dword:00000002 同时允许打开的半连接数量。所谓半连接,表示未完整建立的TCP会话,用netstat命令可以看到呈SYN_RCVD状态的就是。这里使用微软建议值,服务器设为100,高级服务器设为500。建议可以设稍微小一点。
6 R0 P# Z% I4 J! j8 t9 P "TcpMaxHalfOpen"=dword:00000064
( }9 @: Q8 a3 i( L+ a 判断是否存在攻击的触发点。这里使用微软建议值,服务器为80,高级服务器为400。
8 w& l+ i$ q) S) T# m2 q "TcpMaxHalfOpenRetried"=dword:00000050 - W1 F- b& b Z" f
设置等待SYN-ACK时间。缺省项值为3,缺省这一过程消耗时间45秒。项值为2,消耗时间为21秒。 6 y8 L& w& i1 J2 E& G6 [
项值为1,消耗时间为9秒。最低可以设为0,表示不等待,消耗时间为3秒。这个值可以根据遭受攻击规模修改。 * }4 _ ^8 @5 }
微软站点安全推荐为2。
- ^7 f) Y4 K0 w, [; Y "TcpMaxConnectResponseRetransmissions"=dword:00000001
1 I+ {: v6 F; r 设置TCP重传单个数据段的次数。缺省项值为5,缺省这一过程消耗时间240秒。微软站点安全推荐为3。
# U2 F- B6 Z, q2 z. W+ p8 Y "TcpMaxDataRetransmissions"=dword:00000003 0 | e' j4 U9 z2 b* x1 L
设置syn攻击保护的临界点。当可用的backlog变为0时,此参数用于控制syn攻击保护的开启,微软站点安全推荐为5。
7 v3 M0 ~4 K# r# ?& \1 P "TCPMaxPortsExhausted"=dword:00000005
% t0 ? A5 m2 }9 v 禁止IP源路由。缺省项值为1,表示不转发源路由包,项值设为0,表示全部转发,设置为2,表示丢弃所有接受的源路由包,微软站点安全推荐为2。
& r, c6 i r* u p+ t "DisableIPSourceRouting"=dword:0000002 0 W( ]5 J# x. L- ?8 K
限制处于TIME_WAIT状态的最长时间。缺省为240秒,最低为30秒,最高为300秒。建议设为30秒。
' d% m9 ~0 w% a7 Q7 J$ o "TcpTimedWaitDelay"=dword:0000001e , z" w, L: y( l( u$ n- s
8.如何避免*mdb文件被下载
) m! {- Q/ C- |- X7 B' x# t( | 安装ms发布的urlscan工具,可以从根本上解决这个问题。 J: W/ k/ B- G6 S. h5 M9 O
同时它也是一个强大的安全工具,你可以从ms的网站上获取更为详细的信息。
1 X" d3 X3 O! n K$ o: [9.如何让iis的最小ntfs权限运行 , U) ^9 p7 P2 y! B7 M( H/ T
依次做下面的工作:
% B; g! x5 y3 n' C1 C% W9 R a.选取整个硬盘: 2 D4 C3 ?: z5 |9 U1 O% I( Q
system:完全控制 ' b8 A- v2 M T, B
administrator:完全控制 ; C* L' Y: }8 Z$ C) @6 p
(允许将来自父系的可继承性权限传播给对象) Q' j8 C z$ S
b.\program files\common files:
, u& m. K$ l! k everyone:读取及运行 # X! f7 j0 n( K1 K
列出文件目录
* t& f2 h0 X- T. G! d7 c6 s$ h 读取
2 g! t% o+ Z0 |2 y" l (允许将来自父系的可继承性权限传播给对象) + d; w6 |: v) ^( r0 w: v
c.\inetpub\wwwroot: 8 x! |7 e3 E6 M; F: a
iusr_machine:读取及运行 1 m' m: ]; C6 [8 I: }8 s
列出文件目录
1 a' C* L& B! w5 L8 a/ C. F! D% c 读取
! L! r. t9 h) | R1 Y! C (允许将来自父系的可继承性权限传播给对象)
& }5 x6 |( w0 n; @# b8 @2 _ e.\winnt\system32: * F$ R4 ^. \& c5 n2 E/ I; E- x
选择除inetsrv和centsrv以外的所有目录,
( b1 q4 G' |( Q4 E8 z! X 去除“允许将来自父系的可继承性权限传播给对象”选框,复制。 4 Q/ b8 b) [$ H" Y
f.\winnt:
& } ]7 c# K% D* ~) A" w 选择除了downloaded program files、help、iis temporary compressed files、 ( C- u, A# ]# \+ C# s9 I I& i
offline web pages、system32、tasks、temp、web以外的所有目录
5 s8 n& |6 x/ Y4 t 去除“允许将来自父系的可继承性权限传播给对象”选框,复制。
# }1 P! f/ ?, r1 ^9 d. A g.\winnt: + c$ o; ~' _& D& v& F
everyone:读取及运行
" Y1 U( c) }2 b4 n# a1 L x 列出文件目录
% A) S) _% s! j 读取 " [; Q; C! U3 H
(允许将来自父系的可继承性权限传播给对象) , o* X0 e/ m4 g2 F: `# \
h.\winnt\temp:(允许访问数据库并显示在asp页面上) . V6 E) M' j |/ D. f
everyone:修改
# F* g, ^! p6 e3 m2 N (允许将来自父系的可继承性权限传播给对象)
$ [$ V' s3 V* w& s5 o+ {10.如何隐藏iis版本
1 |$ S7 p; t6 b* Q2 m) W2 M/ q 一个黑客可以可以轻易的telnet到你的web端口,发送get命令来获取很多信息 # y. k. Y& P. b0 x" v" y J
iis存放IIS BANNER的所对应的dll文件如下: ! E) Z5 b# J$ g
WEB:C:\WINNT\SYSTEM32\INETSRV\W3SVC.DLL
( j8 A' g" ~2 z7 B" a FTP:C:\WINNT\SYSTEM32\INETSRV\FTPSVC2.DLL
, P! Q4 x4 E/ W2 @0 H# S5 m2 S SMTP:C:\WINNT\SYSTEM32\INETSRV\SMTPSVC.DLL 8 z0 T4 L0 R9 E
你可以用16进制编辑器去修改那些dll文件的关键字,比如iis的Microsoft-IIS/5.0
; U0 d- B/ ]3 I; A+ O7 k t( q 具体过程如下:
! w8 z ^% Z" Q/ t; e7 @1 z 1.停掉iis iisreset /stop 6 t6 Q9 T4 I/ W4 c
2.删除%SYSTEMROOT%\system32\dllcache目录下的同名文件
" z1 A3 K1 f0 E/ g; x) c' g. M 3.修改 |