一位高手整理的IIS FAQ
" K I# h3 r6 i: S( v' i4 B( o下面是一位高手整理的问题精华,大家好好看看吧,收获肯定很大的!
( J: f' ^6 E2 v8 r* f' R1.如何让asp脚本以system权限运行
- \& n' E" t h" R# Y6 R" T' H 修改你asp脚本所对应的虚拟目录,把"应用程序保护"修改为"低"....
- I8 r' G7 C0 a* A- N2.如何防止asp木马 + x6 v" _9 [& g" G5 \$ D
基于FileSystemObject组件的asp木马 cacls %systemroot%\system32\scrrun.dll /e /d guests //禁止guests使用 1 K$ y y+ u) e }" g: h
regsvr32 scrrun.dll /u /s //删除
* k) i; O5 u5 P 基于shell.application组件的asp木马
! k" \1 S2 u) J3 v: U cacls %systemroot%\system32\shell32.dll /e /d guests //禁止guests使用 9 S! q( V5 v+ v) L5 r, _+ x! f
regsvr32 shell32.dll /u /s //删除 8 ?) c5 E+ n) E q
3.如何加密asp文件 8 G$ f' ~" ]2 Q. Y7 [
从微软免费下载到sce10chs.exe 直接运行即可完成安装过程。 4 N; ?$ E3 R U; [
安装完毕后,将生成screnc.exe文件,这是一个运行在DOS PROMAPT的命令工具。
4 {! v n# H" a 运行screnc - l vbscript source.asp destination.asp 1 F9 Z! e. d) ^3 w+ r. c: D
生成包含密文ASP脚本的新文件destination.asp 5 _+ ^$ N2 k1 F3 D
用记事本打开看凡是""之内的,不管是否注解,都变成不可阅读的密文了 ) f/ S- \- _; l
但无法加密中文。
' H; e$ M( ?- }" w* g4.如何从IISLockdown中提取urlscan 5 R: ]: w: e1 B* |( ^; X; {3 f
iislockd.exe /q /c /t:c:\urlscan
' ^, ]2 p! @6 z: M5.如何防止Content-Location标头暴露了web服务器的内部IP地址 . ]# d4 q: V: v8 n& O: _
执行
+ O( F o! {* p$ o2 o. W: [$ v cscript c:\inetpub\adminscripts\adsutil.vbs set w3svc/UseHostName True 8 }- ~& {# m8 ?; Z
最后需要重新启动iis
0 f$ j. o% e1 J' e6.如何解决HTTP500内部错误
* ~6 F/ S g9 g6 c8 N* o# s6 a iis http500内部错误大部分原因 - j, m0 O& q4 ~: v& `
主要是由于iwam账号的密码不同步造成的。 , f& m9 V0 l9 T; ~- n1 T \
我们只要同步iwam_myserver账号在com+应用程序中的密码即可解决问题。
0 F, q G' E% g( ]- }1 |: j, @ 执行 3 O8 o5 g6 \( \- j" z
cscript c:\inetpub\adminscripts\synciwam.vbs -v
( |8 W7 ?9 z7 C) q7.如何增强iis防御SYN Flood的能力
2 |7 R" F; }4 x5 d, o Windows Registry Editor Version 5.00
; U f# f: h8 @# I: q2 w [HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters]
1 {- o" H9 _. b& d' I 启动syn攻击保护。缺省项值为0,表示不开启攻击保护,项值为1和2表示启动syn攻击保护,设成2之后 : p! {. l4 J* `9 Z
安全级别更高,对何种状况下认为是攻击,则需要根据下面的TcpMaxHalfOpen和TcpMaxHalfOpenRetried值 设定的条件来触发启动了。这里需要注意的是,NT4.0必须设为1,设为2后在某种特殊数据包下会导致系统重启。 5 o5 }8 m. O0 z% Q/ P. |- q: d
"SynAttackProtect"=dword:00000002 同时允许打开的半连接数量。所谓半连接,表示未完整建立的TCP会话,用netstat命令可以看到呈SYN_RCVD状态的就是。这里使用微软建议值,服务器设为100,高级服务器设为500。建议可以设稍微小一点。
( }: J2 c- r. m "TcpMaxHalfOpen"=dword:00000064
! f9 |2 n5 p& ]5 D 判断是否存在攻击的触发点。这里使用微软建议值,服务器为80,高级服务器为400。 , n/ y @) s8 k: n; e# m
"TcpMaxHalfOpenRetried"=dword:00000050 0 P: r& ~9 q- Y* _; x
设置等待SYN-ACK时间。缺省项值为3,缺省这一过程消耗时间45秒。项值为2,消耗时间为21秒。
, o5 w/ G, I7 O5 R0 u7 ? 项值为1,消耗时间为9秒。最低可以设为0,表示不等待,消耗时间为3秒。这个值可以根据遭受攻击规模修改。
' Q7 m, H0 F( l# ~; j2 {9 R( G 微软站点安全推荐为2。
7 [6 ?( x- }* h# ~. S+ |( M9 j "TcpMaxConnectResponseRetransmissions"=dword:00000001
: F% p+ ~$ G0 F9 R 设置TCP重传单个数据段的次数。缺省项值为5,缺省这一过程消耗时间240秒。微软站点安全推荐为3。 7 L. j/ w* ?7 J4 `
"TcpMaxDataRetransmissions"=dword:00000003 1 @( E+ R* a( }4 R
设置syn攻击保护的临界点。当可用的backlog变为0时,此参数用于控制syn攻击保护的开启,微软站点安全推荐为5。 9 [; j; s' w- A: E
"TCPMaxPortsExhausted"=dword:00000005 9 s2 P( B% w$ _0 Y( ]0 q
禁止IP源路由。缺省项值为1,表示不转发源路由包,项值设为0,表示全部转发,设置为2,表示丢弃所有接受的源路由包,微软站点安全推荐为2。
" Y- V$ c! w" R0 H/ z- C "DisableIPSourceRouting"=dword:0000002 5 w0 f, \8 q1 m
限制处于TIME_WAIT状态的最长时间。缺省为240秒,最低为30秒,最高为300秒。建议设为30秒。 K t9 h6 h6 Q( }
"TcpTimedWaitDelay"=dword:0000001e ! S( W- M1 m' d0 X7 z
8.如何避免*mdb文件被下载
& |3 S8 L; C- ]2 G 安装ms发布的urlscan工具,可以从根本上解决这个问题。
& Y! d* g( J1 F! P, r0 C 同时它也是一个强大的安全工具,你可以从ms的网站上获取更为详细的信息。 2 d' D. K- f( q' w% H% C7 B' n
9.如何让iis的最小ntfs权限运行
. x( g, ~0 B6 Y$ M' C5 {7 g 依次做下面的工作: - _3 |+ h. z) r; t# o' M- s7 H
a.选取整个硬盘: 2 L% C# G2 b" _4 B
system:完全控制 % V: K6 K) N# Z9 e6 x% k6 Y
administrator:完全控制
( k) w/ A) p! h$ Y. |! A9 h (允许将来自父系的可继承性权限传播给对象)
+ b! E( M" F, X* D) z ^3 b B* y b.\program files\common files: % n8 H" m: h& H' F
everyone:读取及运行 3 X1 J+ y# Z8 }& \( f
列出文件目录 + l2 d. e! f# Q, e* q
读取
9 J% L* { d. Q k9 } (允许将来自父系的可继承性权限传播给对象) 7 f4 |+ j' I% i% C1 J. G
c.\inetpub\wwwroot: 5 M% H" Q/ S4 k. Z0 W b) W
iusr_machine:读取及运行 ' Q/ @( K9 z% F1 A* R# _; r5 p0 Z
列出文件目录
2 e* X# ^! d& g* S* F b# i 读取 / U. m) J6 _( o" ]7 n
(允许将来自父系的可继承性权限传播给对象)
+ E& x; ]4 S6 R' `$ u" q e.\winnt\system32: 8 E6 i) W9 e/ {4 g1 f
选择除inetsrv和centsrv以外的所有目录,
- P; v0 D4 G; y" S8 e" w. A 去除“允许将来自父系的可继承性权限传播给对象”选框,复制。 1 p Z# K0 w8 @. f! E" G
f.\winnt: 2 m! n0 O* E0 A" P5 J2 k
选择除了downloaded program files、help、iis temporary compressed files、 & y7 U* f% h: M0 @9 T$ k
offline web pages、system32、tasks、temp、web以外的所有目录
5 ^& y. d( [4 ~% H& M 去除“允许将来自父系的可继承性权限传播给对象”选框,复制。
$ r- z6 j4 L7 q, v+ ]6 D# S( [ g.\winnt: 0 W- Z, P& S) }- ?$ w
everyone:读取及运行
( b4 {5 ? S# |4 t5 |; R' R+ C 列出文件目录 % j' G* }2 G5 f. F7 C
读取
4 [2 t8 ~! ]5 U% w (允许将来自父系的可继承性权限传播给对象)
/ \( n) [+ B' g4 j" P. x" p h.\winnt\temp:(允许访问数据库并显示在asp页面上) 1 X. Z' ?2 z4 J
everyone:修改
6 e |7 L `: j9 o! U4 A! }9 k (允许将来自父系的可继承性权限传播给对象) 1 y- N9 l9 V4 O) c, @
10.如何隐藏iis版本
% ^8 Q; R3 U' N) a/ }' N: E 一个黑客可以可以轻易的telnet到你的web端口,发送get命令来获取很多信息
& J4 P4 B# Q/ f! T- ] [ iis存放IIS BANNER的所对应的dll文件如下:
: f& C, ^ K6 Z$ i7 N2 g7 G/ Q E WEB:C:\WINNT\SYSTEM32\INETSRV\W3SVC.DLL
' U% v' r0 F, c+ a2 v3 Q9 E FTP:C:\WINNT\SYSTEM32\INETSRV\FTPSVC2.DLL
& N' M- T, {2 C( }+ z3 L SMTP:C:\WINNT\SYSTEM32\INETSRV\SMTPSVC.DLL 0 N. c) e1 ]* K3 ^! H# e+ ^
你可以用16进制编辑器去修改那些dll文件的关键字,比如iis的Microsoft-IIS/5.0
p2 U0 Q" c, [+ d9 g2 }5 a/ V 具体过程如下: ( @" U3 J8 a4 M( t# i$ }' f
1.停掉iis iisreset /stop 5 j& L4 |: _+ M- Z9 G
2.删除%SYSTEMROOT%\system32\dllcache目录下的同名文件
# T+ B% _$ k. u2 m. L! O* g8 M 3.修改 |