标题:
学会十个“如何”打造安全IIS服务器
[打印本页]
作者:
admin
时间:
2008-1-25 02:15
标题:
学会十个“如何”打造安全IIS服务器
1、如何让asp脚本以system权限运行
" P# G# x3 W* ^9 R; X- Z
修改你asp脚本所对应的虚拟目录,把"应用程序保护"修改为"低"....
. Q+ @' e( c+ [2 a* Y% ?
2、如何防止asp木马
9 H; K+ q! Q5 O7 f- W
基于FileSystemObject组件的asp木马
0 u- [$ Z: Z9 N, s
cacls %systemroot%/system32/scrrun.dll /e /d guests //禁止guests使用
! S' X5 E) z4 K* ~
regsvr32 scrrun.dll /u /s //删除
$ P0 i( Y6 X' I, l, K
基于shell.application组件的asp木马
8 P4 x, H6 u6 W* f g; b: D4 k" D+ N
cacls %systemroot%/system32/shell32.dll /e /d guests //禁止guests使用
# W+ ?" L5 y; G& _; C+ Q
regsvr32 shell32.dll /u /s //删除
4 s/ Z; { h6 F) I$ n+ b
3、如何加密asp文件
. k9 g$ ` O- }( [ A
从微软免费下载到sce10chs.exe 直接运行即可完成安装过程。
$ L0 c. v+ ^' I, ]3 |: J2 |2 H
安装完毕后,将生成screnc.exe文件,这是一个运行在DOS PROMAPT的命令工具。
/ c* e# e/ `# d5 G1 x/ D! ^8 ]
运行screnc - l vbscript source.asp destination.asp
; ~9 K/ {# f7 i6 y% F! `$ l" F# B
生成包含密文ASP脚本的新文件destination.asp
3 l, C/ R) m% U2 K
用记事本打开看凡是""之内的,不管是否注解,都变成不可阅读的密文了
+ k. c/ m8 b! W' U8 X' v
但无法加密中文。
1 w& n8 T6 _8 ~- {
4、如何从IISLockdown中提取urlscan
5 i, J% s# e1 \+ E* Y/ h
iislockd.exe /q /c /t:c:/urlscan
* _% b; C" E: h! h v& L6 ~4 a
5、如何防止Content-Location标头暴露了web
服务器
的内部IP地址
/ D( a% K6 |$ `: Z. ^
执行
- D8 y5 ^( H. K% H \
cscript c:/inetpub/adminscripts/adsutil.vbs set w3svc/UseHostName True
f" O/ ^5 \- d7 {, Z2 \
最后需要重新启动iis
' _7 G( p- M X7 w6 q
6、如何解决HTTP500内部错误
$ D( y# K" f7 ]5 L# i& {
iis http500内部错误大部分原因
0 E3 S" R- H- A% T$ l- L
主要是由于iwam账号的密码不同步造成的。
) A! P& v! ~! a1 b
我们只要同步iwam_myserver账号在com+应用程序中的密码即可解决问题。
& K1 {: J. j' K( t4 I
执行
+ }% D) R$ C0 M, C
cscript c:/inetpub/adminscripts/synciwam.vbs -v
S# a2 J# A9 [8 H
7、如何增强iis防御SYN Flood的能力
! @ n, j0 @( V' I B8 I1 B
Windows Registry Editor Version 5.00 [HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/Tcpip/Parameters]
1 D! ?* N& e* g8 k# o" h
启动syn攻击保护。缺省项值为0,表示不开启攻击保护,项值为1和2表示启动syn攻击保护,设成2之后 安全级别更高,对何种状况下认为是攻击,则需要根据下面的TcpMaxHalfOpen和TcpMaxHalfOpenRetried值 设定的条件来触发启动了。这里需要注意的是,NT4.0必须设为1,设为2后在某种特殊数据包下会导致系统重启。
8 o. o X' k1 M; c0 e. H0 q
"SynAttackProtect"=dword:00000002 同时允许打开的半连接数量。所谓半连接,表示未完整建立的TCP会话,用netstat命令可以看到呈SYN_RCVD状态的就是。这里使用微软建议值,服务器设为100,高级服务器设为500。建议可以设稍微小一点。
! y2 G1 q- H, U0 p$ Q A. A6 W+ _) {
"TcpMaxHalfOpen"=dword:00000064 判断是否存在攻击的触发点。这里使用微软建议值,服务器为80,高级服务器为400。 "TcpMaxHalfOpenRetried"=dword:00000050
" H! k% U; {* P# ]: R0 N' @
设置等待SYN-ACK时间。缺省项值为3,缺省这一过程消耗时间45秒。项值为2,消耗时间为21秒。
; v- w' E& c+ x% l, L& [% N3 b
项值为1,消耗时间为9秒。最低可以设为0,表示不等待,消耗时间为3秒。这个值可以根据遭受攻击规模修改。
0 j/ ]. m* E2 c$ U( O# T$ A
微软站点安全推荐为2。
' C4 n8 V7 v& i6 O' X
"TcpMaxConnectResponseRetransmissions"=dword:00000001
" l# `. D. S* `7 K/ y
设置TCP重传单个数据段的次数。缺省项值为5,缺省这一过程消耗时间240秒。微软站点安全推荐为3。
' m3 H! i( P0 S5 t( ~
"TcpMaxDataRetransmissions"=dword:00000003
5 Y6 Q' W/ u( |! B" p0 p
设置syn攻击保护的临界点。当可用的backlog变为0时,此参数用于控制syn攻击保护的开启,微软站点安全推荐为5。
5 e: ^$ j9 }: W. N
"TCPMaxPortsExhausted"=dword:00000005
+ g" K5 k/ O+ S* |
禁止IP源路由。缺省项值为1,表示不转发源路由包,项值设为0,表示全部转发,设置为2,表示丢弃所有接受的源路由包,微软站点安全推荐为2。
1 C5 k( q! w% |9 d4 d
"DisableIPSourceRouting"=dword:0000002
; C. h& |& H; O& {7 ?6 v
限制处于TIME_WAIT状态的最长时间。缺省为240秒,最低为30秒,最高为300秒。建议设为30秒。
7 b: A/ Z) j; R" ^% C$ ~1 K
"TcpTimedWaitDelay"=dword:0000001e
8 f2 w: ~) r0 g
, t0 t7 I; G/ c8 |: z Y9 T
8、如何避免*mdb文件被下载
! g. X* g4 d5 Q9 O8 a' i
安装ms发布的urlscan工具,可以从根本上解决这个问题。
8 g/ q" J$ c* c$ n! H
同时它也是一个强大的安全工具,你可以从ms的网站上获取更为详细的信息。
B4 z& E1 ]" B& S* d2 J' c Q
9、如何让iis的最小ntfs权限运行
7 h% z: Z+ r: N9 Y
依次做下面的工作:
+ T; p0 o# M4 @- X5 i S
a、选取整个硬盘:
$ k$ @" H; f: D+ l8 V
system:完全控制
) H3 I" b2 M( b- R, }# U
administrator:完全控制
) j6 R' i! ~ P# j- A& Q# y2 O, N3 l
(允许将来自父系的可继承性权限传播给对象) b、/program files/common files:
- W( d# e( F0 W* C0 e6 {# i
everyone:读取及运行列出文件目录读取
! ^8 D7 t9 h- C$ Z
(允许将来自父系的可继承性权限传播给对象)
$ y9 `/ y* M5 C2 m. n6 U
c、/inetpub/wwwroot:
. g( v& k* d6 `
iusr_machine:读取及运行列出文件目录读取
& w( k6 h, @; `) \4 {. ~& \8 n, T
(允许将来自父系的可继承性权限传播给对象)
5 j) X b, T }
e、/winnt/system32:
& Z8 }, n! y! o: |1 c; b% C$ c
选择除inetsrv和centsrv以外的所有目录,去除“允许将来自父系的可继承性权限传播给对象”选框,复制。
! [; Q9 m9 `$ L
f、/winnt:
: M' x) z0 h: O* I4 o
选择除了downloaded program files、help、iis temporary compressed files、offline web pages、system32、tasks、temp、web以外的所有目录去除“允许将来自父系的可继承性权限传播给对象”选框,复制。
$ Q) T2 d( b4 a3 S
g、/winnt:
+ W7 I5 {- L1 Y+ q
8 p4 ?% ?7 p3 D& ?' R
everyone:读取及运行列出文件目录读取
7 e r- ], G8 `: { Y3 y
(允许将来自父系的可继承性权限传播给对象)
' ] w, R# N/ ~4 p4 N, @+ ^7 @9 e
h、/winnt/temp:(允许访问数据库并显示在asp页面上)
0 z! ]0 P$ O+ C5 s% q- C( [
everyone:修改
; b; g4 Y) D$ t# ]& N" f& g" d
(允许将来自父系的可继承性权限传播给对象)
& m" {& B* U) j, {) P% J6 p
10、如何隐藏iis版本
; u- ~7 f7 d' d$ P* H
一个黑客可以可以轻易的telnet到你的web端口,发送get命令来获取很多信息
& t0 f& R4 M p$ `
iis存放IIS BANNER的所对应的dll文件如下:
. G9 z! U- D8 b# n, @- ^
WEB:C:/WINNT/SYSTEM32/INETSRV/W3SVC.DLL
5 R7 I2 g. H; _' E
FTP:C:/WINNT/SYSTEM32/INETSRV/FTPSVC2.DLL
. Y+ E: i; }/ D3 y$ a' ~
SMTP:C:/WINNT/SYSTEM32/INETSRV/SMTPSVC.DLL
9 M. V: |6 C. f! I) u, `! S7 S
你可以用16进制编辑器去修改那些dll文件的关键字,比如iis的Microsoft-IIS/5.0
* i: X j/ L; G1 r7 `
具体过程如下:
) J4 t* R9 V5 V/ B) v9 |$ a
1、停掉iis iisreset /stop
$ ^1 h2 l6 s! C, K$ q- P! F L3 M
2、删除%SYSTEMROOT%/system32/dllcache目录下的同名文件
) m: ^ x& A. n6 T+ R
3、修改
欢迎光临 捌玖网络工作室 (http://www.89w.org/)
Powered by Discuz! 7.2