标题:
学会十个“如何”打造安全IIS服务器
[打印本页]
作者:
admin
时间:
2008-1-25 02:15
标题:
学会十个“如何”打造安全IIS服务器
1、如何让asp脚本以system权限运行
k& p8 K" C) u, ?2 T7 M
修改你asp脚本所对应的虚拟目录,把"应用程序保护"修改为"低"....
2 D1 @5 D: p; y; ]. q
2、如何防止asp木马
' T4 L, |6 L6 C
基于FileSystemObject组件的asp木马
! \0 W9 Z2 {5 ~) O" H+ m! V
cacls %systemroot%/system32/scrrun.dll /e /d guests //禁止guests使用
' g6 A) N. X; P8 P. Y
regsvr32 scrrun.dll /u /s //删除
5 f3 T0 ]# u+ h1 x" m2 L t7 _
基于shell.application组件的asp木马
6 D0 v8 y( r- c
cacls %systemroot%/system32/shell32.dll /e /d guests //禁止guests使用
' B6 f. K; a' T F
regsvr32 shell32.dll /u /s //删除
) y F7 [7 t9 B4 A' G9 O" _- N
3、如何加密asp文件
' w( y. C6 p5 A6 @7 W' e) |( R
从微软免费下载到sce10chs.exe 直接运行即可完成安装过程。
5 B5 [! y) Z7 Y0 N) i# K8 Y
安装完毕后,将生成screnc.exe文件,这是一个运行在DOS PROMAPT的命令工具。
7 ]7 G. s( J) _# D8 y& `- g* W1 c
运行screnc - l vbscript source.asp destination.asp
% Y+ D# ~, {/ Q
生成包含密文ASP脚本的新文件destination.asp
8 m/ R/ @, s* x1 w" H
用记事本打开看凡是""之内的,不管是否注解,都变成不可阅读的密文了
) {4 m( L& W s. b; Z' y% D
但无法加密中文。
0 h( d, s# l9 M9 H- e- F- Y
4、如何从IISLockdown中提取urlscan
& l9 n" \5 r. Q8 R
iislockd.exe /q /c /t:c:/urlscan
: i* F( e5 Y3 z3 J9 f
5、如何防止Content-Location标头暴露了web
服务器
的内部IP地址
4 U' X& {# } h' U. G
执行
! r8 s E5 G2 z* z4 z
cscript c:/inetpub/adminscripts/adsutil.vbs set w3svc/UseHostName True
* \5 R* H3 i; N" k) l% k
最后需要重新启动iis
! w' S/ P) y5 L1 Z1 n
6、如何解决HTTP500内部错误
3 r& M6 T0 k4 w* s% \' n
iis http500内部错误大部分原因
' T% e+ q7 H$ ^) _
主要是由于iwam账号的密码不同步造成的。
- n! q0 k; W. q/ n
我们只要同步iwam_myserver账号在com+应用程序中的密码即可解决问题。
. b; }- T7 C- ^2 O+ h$ g
执行
$ k! U$ `8 N0 }# C: F$ Q
cscript c:/inetpub/adminscripts/synciwam.vbs -v
6 Z' d# t$ _3 V& c% c
7、如何增强iis防御SYN Flood的能力
* a% h% g* W/ [0 w5 z' T- T
Windows Registry Editor Version 5.00 [HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/Tcpip/Parameters]
& Q) G% h8 p+ }4 B5 r9 y- v
启动syn攻击保护。缺省项值为0,表示不开启攻击保护,项值为1和2表示启动syn攻击保护,设成2之后 安全级别更高,对何种状况下认为是攻击,则需要根据下面的TcpMaxHalfOpen和TcpMaxHalfOpenRetried值 设定的条件来触发启动了。这里需要注意的是,NT4.0必须设为1,设为2后在某种特殊数据包下会导致系统重启。
: }; B- W7 |2 z, |+ F
"SynAttackProtect"=dword:00000002 同时允许打开的半连接数量。所谓半连接,表示未完整建立的TCP会话,用netstat命令可以看到呈SYN_RCVD状态的就是。这里使用微软建议值,服务器设为100,高级服务器设为500。建议可以设稍微小一点。
# ?; T9 n+ J6 d% l# D$ G) { e
"TcpMaxHalfOpen"=dword:00000064 判断是否存在攻击的触发点。这里使用微软建议值,服务器为80,高级服务器为400。 "TcpMaxHalfOpenRetried"=dword:00000050
) U6 q7 d: T1 R
设置等待SYN-ACK时间。缺省项值为3,缺省这一过程消耗时间45秒。项值为2,消耗时间为21秒。
: t9 A9 n9 L8 d1 R1 C
项值为1,消耗时间为9秒。最低可以设为0,表示不等待,消耗时间为3秒。这个值可以根据遭受攻击规模修改。
: L% y: X; R' R" A# R
微软站点安全推荐为2。
3 E. i0 q T! S; J% D
"TcpMaxConnectResponseRetransmissions"=dword:00000001
. Q) K4 B+ T2 W0 ^/ ?" B0 z
设置TCP重传单个数据段的次数。缺省项值为5,缺省这一过程消耗时间240秒。微软站点安全推荐为3。
( o0 [* z" B& J, S7 g; w: p
"TcpMaxDataRetransmissions"=dword:00000003
# N7 [- y5 U) v- O& u7 s) b
设置syn攻击保护的临界点。当可用的backlog变为0时,此参数用于控制syn攻击保护的开启,微软站点安全推荐为5。
; M0 j: G# k# T: k; m
"TCPMaxPortsExhausted"=dword:00000005
$ s6 A' y/ }1 d E4 h' |: g' o$ E
禁止IP源路由。缺省项值为1,表示不转发源路由包,项值设为0,表示全部转发,设置为2,表示丢弃所有接受的源路由包,微软站点安全推荐为2。
2 x0 |% m/ ?0 N
"DisableIPSourceRouting"=dword:0000002
/ {9 D) s& }1 P; v- G# M1 r
限制处于TIME_WAIT状态的最长时间。缺省为240秒,最低为30秒,最高为300秒。建议设为30秒。
4 q9 z$ O \ D) J/ n
"TcpTimedWaitDelay"=dword:0000001e
9 Q3 k2 x2 S+ |$ d* B# W
( n) ?/ G& b! b2 D7 D+ D _$ {" y
8、如何避免*mdb文件被下载
, q. X' o2 d1 B0 `* T* y0 }; O1 m0 m
安装ms发布的urlscan工具,可以从根本上解决这个问题。
0 f; `1 c- V) o. E7 o
同时它也是一个强大的安全工具,你可以从ms的网站上获取更为详细的信息。
- I F* f$ J6 A2 C
9、如何让iis的最小ntfs权限运行
8 P0 W$ A6 j! Z$ ^
依次做下面的工作:
" t2 C% P$ D8 \' i- w9 i
a、选取整个硬盘:
% ` k! h9 K! }( b" j, ^& z
system:完全控制
- I9 Q5 g' K- |9 B
administrator:完全控制
& {0 l6 \! K+ y
(允许将来自父系的可继承性权限传播给对象) b、/program files/common files:
9 `& a9 M: c" `& u. U& E
everyone:读取及运行列出文件目录读取
N% {4 D, L9 U4 O! L+ A
(允许将来自父系的可继承性权限传播给对象)
- O* A4 k4 o$ i
c、/inetpub/wwwroot:
1 d& l" j' D8 k* M
iusr_machine:读取及运行列出文件目录读取
: D# R0 b8 I$ Z/ \/ ?3 u
(允许将来自父系的可继承性权限传播给对象)
( X I0 f3 a& ^$ Q" N Y( t
e、/winnt/system32:
, |: V6 h" r6 h% D$ L
选择除inetsrv和centsrv以外的所有目录,去除“允许将来自父系的可继承性权限传播给对象”选框,复制。
* O0 J) C. d4 H+ s
f、/winnt:
) }& m, m4 W w) @* l3 ?7 R
选择除了downloaded program files、help、iis temporary compressed files、offline web pages、system32、tasks、temp、web以外的所有目录去除“允许将来自父系的可继承性权限传播给对象”选框,复制。
* P, a# e _9 {" a
g、/winnt:
# q& `. N3 k7 ? C$ n* V5 m. e, i
$ g- B3 M8 Z6 m/ `+ B' L
everyone:读取及运行列出文件目录读取
3 X* s- j2 b1 A! y; D- u
(允许将来自父系的可继承性权限传播给对象)
5 l- D/ I, {* C! M4 r* T; p
h、/winnt/temp:(允许访问数据库并显示在asp页面上)
& h. p8 c. G) a7 X' ~4 p4 J
everyone:修改
6 L3 A. D# ]8 x- ~1 x
(允许将来自父系的可继承性权限传播给对象)
" R, o( X6 o5 o4 ]6 D2 P8 Q
10、如何隐藏iis版本
" z3 I% }6 ]2 p) d
一个黑客可以可以轻易的telnet到你的web端口,发送get命令来获取很多信息
: R- F0 V4 e1 E) I/ g+ h. t
iis存放IIS BANNER的所对应的dll文件如下:
( J5 R% |( o* a* W
WEB:C:/WINNT/SYSTEM32/INETSRV/W3SVC.DLL
" c) f" `* p E1 o6 ~% j
FTP:C:/WINNT/SYSTEM32/INETSRV/FTPSVC2.DLL
1 y0 ^0 {2 u3 B+ ]
SMTP:C:/WINNT/SYSTEM32/INETSRV/SMTPSVC.DLL
0 R( Z% `& O: n" { ^$ R( c
你可以用16进制编辑器去修改那些dll文件的关键字,比如iis的Microsoft-IIS/5.0
) I1 w6 k& k' `: u. a& h
具体过程如下:
0 F: U) w3 D0 q2 c7 t
1、停掉iis iisreset /stop
^, w0 N* e# @
2、删除%SYSTEMROOT%/system32/dllcache目录下的同名文件
& O9 o3 Q3 m0 K: l6 l
3、修改
欢迎光临 捌玖网络工作室 (http://89w.org/)
Powered by Discuz! 7.2