Win2000 Server安全配置入门
" T5 H8 s G; W* l# ]8 p! G8 X. r 目前,WIN2000 SERVER是比较流行的服务器操作系统之一,但是要想安全的配置微软的这个操作系统,却不是一件容易的事。本文试图对win2000 SERVER的安全配置进行初步的探讨。
: |5 M+ F# H; {8 h! y一、 定制自己的WIN2000 SERVER 6 y% }- x+ z% [3 o2 j" d
1. 版本的选择:WIN2000有各种语言的版本,对于我们来说,可以选择英文版或简体中文版,我强烈建议:在语言不成为障碍的情况下,请一定使用英文版。要知道,微软的产品是以Bug & Patch而著称的,中文版的Bug远远多于英文版,而补丁一般还会迟至少半个月(也就是说一般微软公布了漏洞后你的机子还会有半个月处于无保护状况) 7 H3 o1 p6 c. k& E0 b* n5 @$ [( s& L
2. 组件的定制:win2000在默认情况下会安装一些常用的组件,但是正是这个默认安装是极度危险的(米特尼科说过,他可以进入任何一台默认安装的服务器,我虽然不敢这么说,不过如果你的主机是WIN2000 SERVER的默认安装,我可以告诉你,你死定了)你应该确切的知道你需要哪些服务,而且仅仅安装你确实需要的服务,根据安全原则,最少的服务+最小的权限=最大的安全。典型的WEB服务器需要的最小组件选择是:只安装IIS的Com Files,IIS Snap-In,WWW Server组件。如果你确实需要安装其他组件,请慎重,特别是:Indexing Service, FrontPage 2000 Server Extensions, Internet Service Manager (HTML)这几个危险服务。 * S. f/ [ f1 M" s+ |* u$ i# n
3. 管理应用程序的选择
8 i9 T% Z! z% b" m0 g# U! Y! J选择一个好的远程管理软件是非常重要的事,这不仅仅是安全方面的要求,也是应用方面的需要。Win2000的Terminal Service是基于RDP(远程桌面协议)的远程控制软件,他的速度快,操作方便,比较适合用来进行常规操作。但是,Terminal Service也有其不足之处,由于它使用的是虚拟桌面,再加上微软编程的不严谨,当你使用Terminal Service进行安装软件或重起服务器等与真实桌面交互的操作时,往往会出现哭笑不得的现象,例如:使用Terminal Service重起微软的认证服务器(Compaq, IBM等)可能会直接关机。所以,为了安全起见,我建议你再配备一个远程控制软件作为辅助,和Terminal Service互补,象PcAnyWhere就是一个不错的选择。 & o5 J9 s! T. P G- _
二、 正确安装WIN2000 SERVER 9 r) T* `. G- g
1.分区和逻辑盘的分配,有一些朋友为了省事,将硬盘仅仅分为一个逻辑盘,所有的软件都装在C驱上,这是很不好的,建议最少建立两个分区,一个系统分区,一个应用程序分区,这是因为,微软的IIS经常会有泄漏源码/溢出的漏洞,如果把系统和IIS放在同一个驱动器会导致系统文件的泄漏甚至入侵者远程获取ADMIN。推荐的安全配置是建立三个逻辑驱动器,第一个大于2G,用来装系统和重要的日志文件,第二个放IIS,第三个放FTP,这样无论IIS或FTP出了安全漏洞都不会直接影响到系统目录和系统文件。要知道,IIS和FTP是对外服务的,比较容易出问题。而把IIS和FTP分开主要是为了防止入侵者上传程序并从IIS中运行。(这个可能会导致程序开发人员和编辑的苦恼,管他呢,反正你是管理员J)
# T; b' A: L% P' c; A2 T2.安装顺序的选择:不要觉得:顺序有什么重要?只要安装好了,怎么装都可以的。错!win2000在安装中有几个顺序是一定要注意的: % l6 m9 I" W. M: {: z3 o
首先,何时接入网络:Win2000在安装时有一个漏洞,在你输入Administrator密码后,系统就建立了ADMIN$的共享,但是并没有用你刚刚输入的密码来保护它,这种情况一直持续到你再次启动后,在此期间,任何人都可以通过ADMIN$进入你的机器;同时,只要安装一完成,各种服务就会自动运行,而这时的服务器是满身漏洞,非常容易进入的,因此,在完全安装并配置好win2000 SERVER之前,一定不要把主机接入网络。 ) }, Y0 }/ W" H# p7 n
其次,补丁的安装:补丁的安装应该在所有应用程序安装完之后,因为补丁程序往往要替换/修改某些系统文件,如果先安装补丁再安装应用程序有可能导致补丁不能起到应有的效果,例如:IIS的HotFix就要求每次更改IIS的配置都需要安装(变不变态?)
" I" h$ r; S& L! W! f) P9 h) H9 J三、 安全配置WIN2000 SERVER + {" [6 H9 X P+ I
即使正确的安装了WIN2000 SERVER,系统还是有很多的漏洞,还需要进一步进行细致地配置。 $ Q0 k) \3 a/ {" Z5 n+ A: o
1.端口:端口是计算机和外部网络相连的逻辑接口,也是计算机的第一道屏障,端口配置正确与否直接影响到主机的安全 / J! ~5 C" X8 N8 P, n
2.IIS:IIS是微软的组件中漏洞最多的一个,平均两三个月就要出一个漏洞,而微软的IIS默认安装又实在不敢恭维,所以IIS的配置是我们的重点,现在大家跟着我一起来:
9 h, X+ B. G5 u0 W0 Z) U* H 首先,把C盘那个什么Inetpub目录彻底删掉,在D盘建一个Inetpub(要是你不放心用默认目录名也可以改一个名字,但是自己要记得)在IIS管理器中将主目录指向D:\Inetpub;其次,那个IIS安装时默认的什么scripts等虚拟目录一概删除(罪恶之源呀,忘了http://www.target.com/scripts/..%c1%1c../winnt/system32/cmd.exe了?我们虽然已经把Inetpub从系统盘挪出来了,但是还是小心为上),如果你需要什么权限的目录可以自己慢慢建,需要什么权限开什么。(特别注意写权限和执行程序的权限,没有绝对的必要千万不要给) / `! ^7 N- ~, {: ~9 a, t' Y2 v
第三,应用程序配置:在IIS管理器中删除必须之外的任何无用映射,必须指的是ASP, ASA和其他你确实需要用到的文件类型,例如你用到stml等(使用server side include),实际上90%的主机有了上面两个映射就够了,其余的映射几乎每个都有一个凄惨的故事:htw, htr, idq, ida……想知道这些故事?去查以前的漏洞列表吧。什么?找不到在哪里删?在IIS管理器中右击主机->属性->WWW服务 编辑->主目录 配置->应用程序映射,然后就开始一个个删吧(里面没有全选的,嘿嘿)。接着在刚刚那个窗口的应用程序调试书签内将脚本错误消息改为发送文本(除非你想ASP出错的时候用户知道你的程序/网络/数据库结构)错误文本写什么?随便你喜欢,自己看着办。点击确定退出时别忘了让虚拟站点继承你设定的属性。
! W- }6 P6 ~5 V! @4 O# n; C& G 为了对付日益增多的cgi漏洞扫描器,还有一个小技巧可以参考,在IIS中将HTTP404 Object Not Found出错页面通过URL重定向到一个定制HTM文件,可以让目前绝大多数CGI漏洞扫描器失灵。其实原因很简单,大多数CGI扫描器在编写时为了方便,都是通过查看返回页面的HTTP代码来判断漏洞是否存在的,例如,著名的IDQ漏洞一般都是通过取1.idq来检验,如果返回HTTP200,就认为是有这个漏洞,反之如果返回HTTP404就认为没有,如果你通过URL将HTTP404出错信息重定向到HTTP404.htm文件,那么所有的扫描无论存不存在漏洞都会返回HTTP200,90%的CGI扫描器会认为你什么漏洞都有,结果反而掩盖了你真正的漏洞,让入侵者茫然无处下手(武侠小说中常说全身漏洞反而无懈可击,难道说的就是这个境界?)不过从个人角度来说,我还是认为扎扎实实做好安全设置比这样的小技巧重要的多。
s, U6 E! G4 O. O- \+ Z 最后,为了保险起见,你可以使用IIS的备份功能,将刚刚的设定全部备份下来,这样就可以随时恢复IIS的安全配置。还有,如果你怕IIS负荷过高导致服务器满负荷死机,也可以在性能中打开CPU限制,例如将IIS的最大CPU使用率限制在70%。 " r) P# y1 p) |2 ~+ t
3.账号安全: 7 n f& H9 K; B3 Q8 z- k! D. D) ?1 ]
Win2000的账号安全是另一个重点,首先,Win2000的默认安装允许任何用户通过空用户得到系统所有账号/共享列表,这个本来是为了方便局域网用户共享文件的,但是一个远程用户也可以得到你的用户列表并使用暴力法破解用户密码。很多朋友都知道可以通过更改注册表Local_Machine\System\CurrentControlSet\Control\LSA-RestrictAnonymous = 1来禁止139空连接,实际上win2000的本地安全策略(如果是域服务器就是在域服务器安全和域安全策略中)就有这样的选项RestrictAnonymous(匿名连接的额外限制),这个选项有三个值: & O; M3 N. y9 d; |, B5 ~' J* Y
0:None. Rely on default permissions(无,取决于默认的权限) ; z0 K7 C7 Y/ t# B8 V8 `
1:Do not allow enumeration of SAM accounts and shares(不允许枚举SAM帐号和共享)
( T. H8 |# V: |5 @" d$ W0 V( U5 I2:No access without explicit anonymous permissions(没有显式匿名权限就不允许访问)
; I9 g& n5 f6 @* T7 |0这个值是系统默认的,什么限制都没有,远程用户可以知道你机器上所有的账号、组信息、共享目录、网络传输列表(NetServerTransportEnum等等,对服务器来说这样的设置非常危险。 4 r* n4 }% k* ~; e1 q( ?
1这个值是只允许非NULL用户存取SAM账号信息和共享信息。
' Q& @* x/ s( q9 p3 N4 V4 Y2这个值是在win2000中才支持的,需要注意的是,如果你一旦使用了这个值,你的共享估计就全部完蛋了,所以我推荐你还是设为1比较好。
3 D' K1 j! `5 Y. V# x1 A9 d6 o 好了,入侵者现在没有办法拿到我们的用户列表,我们的账户安全了……慢着,至少还有一个账户是可以跑密码的,这就是系统内建的administrator,怎么办?我改改改,在计算机管理->用户账号中右击administrator然后改名,改成什么随便你,只要能记得就行了。
, Q6 |' t- f( w9 \2 h9 k 不对不对,我都已经改了用户名了,怎么还是有人跑我管理员的密码?幸好我的密码够长,但是这也不是办法呀?嗯,那肯定是在本地或者Terminal Service的登录界面看到的,好吧,我们再来把HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\WindowsNT\CurrentVersion\winlogon项中的Don';t Display Last User Name串数据改成1,这样系统不会自动显示上次的登录用户名。
; [, ^: S+ G* S! G! B) v 将服务器注册表HKEY_LOCAL_ MACHINE\SOFTWARE\Microsoft\ WindowsNT\CurrentVersion\Winlogon项中的Don';t Display Last User Name串数据修改为1,隐藏上次登陆控制台的用户名。(哇,世界清静了) ?3 A) {- r1 L2 ?0 @' V
2 s- |8 z4 H5 m1 r9 ^3 o/ h+ y
5.安全日志:我遇到过这样的情况,一台主机被别人入侵了,系统管理员请我去追查凶手,我登录进去一看:安全日志是空的,倒,请记住:Win2000的默认安装是不开任何安全审核的!那么请你到本地安全策略->审核策略中打开相应的审核,推荐的审核是:
7 @+ k ~, P" A7 q( y1 J4 z ` p2 _账户管理 成功 失败 ' H2 r: n, _3 p A$ }
登录事件 成功 失败 # t% @, @9 J! p* w* n( B" g
对象访问 失败
( ]' e. Z$ d) w' f/ a' j. L& [策略更改 成功 失败
, D& q- l( F6 ~6 t" S. g# q特权使用 失败
' q( |! V3 a5 Q$ y系统事件 成功 失败 - B1 W0 _+ U7 D, w
目录服务访问 失败 - E, g2 n# V i5 m; X
账户登录事件 成功 失败 : P0 l4 w0 w f
审核项目少的缺点是万一你想看发现没有记录那就一点都没辙;审核项目太多不仅会占用系统资源而且会导致你根本没空去看,这样就失去了审核的意义。
. Q. d) s9 s: ?3 Q* V+ c与之相关的是:
9 I& V5 c2 \. _- A- x在账户策略->密码策略中设定: # D+ E* Y$ y( ? {% n
密码复杂性要求 启用
/ A. Z( a" s( `( e) B' I密码长度最小值 6位 ' Q' c' J) Z7 E1 }% f/ Y
强制密码历史 5次
* o. D3 f1 G3 J! @1 r最长存留期 30天 4 q3 _ C9 ~2 s, v/ j9 T) J3 O
在账户策略->账户锁定策略中设定: - g- L- |% B9 J; f$ \: S
账户锁定 3次错误登录 - H5 R) Z) G9 ]1 A, P" O' ]
锁定时间 20分钟 / A9 f& r2 F' T1 g6 v S! G# T
复位锁定计数 20分钟 2 |- b7 ^2 E! R' Z7 o" O
同样,Terminal Service的安全日志默认也是不开的,我们可以在Terminal Service Configration(远程服务配置)-权限-高级中配置安全审核,一般来说只要记录登录、注销事件就可以了。 . P" a5 D$ u3 t% n" \6 M
7.目录和文件权限:
. v4 N: L& K9 e+ T2 { 为了控制好服务器上用户的权限,同时也为了预防以后可能的入侵和溢出,我们还必须非常小心地设置目录和文件的访问权限,NT的访问权限分为:读取、写入、读取及执行、修改、列目录、完全控制。在默认的情况下,大多数的文件夹对所有用户(Everyone这个组)是完全敞开的(Full Control),你需要根据应用的需要进行权限重设。
w6 D) z& I* P( X在进行权限控制时,请记住以下几个原则:
& y- d. A4 D& ^2 ^4 f1、 权限是累计的:如果一个用户同时属于两个组,那么他就有了这两个组所允许的所有权限;
; c9 S; C/ ]5 S# f0 a2、 拒绝的权限要比允许的权限高(拒绝策略会先执行)如果一个用户属于一个被拒绝访问某个资源的组,那么不管其他的权限设置给他开放了多少权限,他也一定不能访问这个资源。所以请非常小心地使用拒绝,任何一个拒绝; 4 Q/ h2 x# |; e% L
3、 文件权限比文件夹权限高(这个不用解释了吧?) 3 @9 e; w! h2 ^* F# j1 |" q1 p+ h6 Y7 U
4、 利用用户组来进行权限控制是一个成熟的系统管理员必须具有的优良习惯之一;
7 Z- ^3 U0 a- h4 g' m" }# r5、 仅给用户真正需要的权限,权限的最小化原则是安全的重要保障;
, h% k3 t4 h" `6、 .预防DoS: ! e3 J$ I' ?8 l( Z
在注册表HKLM\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters中更改以下值可以帮助你防御一定强度的DoS攻击 : ^: D4 ?8 k5 o, y( H
SynAttackProtect REG_DWORD 2 - c3 G2 H. y3 x5 o7 L6 q
EnablePMTUDiscovery REG_DWORD 0
! I% e' b) X G& D( sNoNameReleaseOnDemand REG_DWORD 1
- ?6 v* k. G6 N8 ZEnableDeadGWDetect REG_DWORD 0 ) s8 r9 M" F7 P; c
KeepAliveTime REG_DWORD 300,000
" }* T; f7 ?/ J6 ^5 b. h7 k! NPerformRouterDiscovery REG_DWORD 0
* Z9 x+ q8 {0 I" s6 F4 [EnableICMPRedirects REG_DWORD 0 - A" R4 g+ ?# l! H. T: B* ]- h
ICMP攻击:ICMP的风暴攻击和碎片攻击也是NT主机比较头疼的攻击方法,其实应付的方法也很简单,win2000自带一个Routing & Remote Access工具,这个工具初具路由器的雏形(微软真是的,什么都要做?听说最近又要做防火墙了)在这个工具中,我们可以轻易的定义输入输出包过滤器,例如,设定输入ICMP代码255丢弃就表示丢弃所有的外来ICMP报文(让你炸?我丢、丢、丢)
( C( G# D' g4 @& f4 v! g: n四、 需要注意的一些事: 3 M% E9 Q5 H# ^9 y: J
实际上,安全和应用在很多时候是矛盾的,因此,你需要在其中找到平衡点,毕竟服务器是给用户用而不是做OPEN HACK的,如果安全原则妨碍了系统应用,那么这个安全原则也不是一个好的原则。 ' O4 U! S' \. h7 J* _ I
网络安全是一项系统工程,它不仅有空间的跨度,还有时间的跨度。很多朋友(包括部分系统管理员)认为进行了安全配置的主机就是安全的,其实这其中有个误区:我们只能说一台主机在一定的情况一定的时间上是安全的,随着网络结构的变化、新的漏洞的发现,管理员/用户的操作,主机的安全状况是随时随地变化着的,只有让安全意识和安全制度贯穿整个过程才能做到真正的安全。 # q/ l, \! V4 e* z- {
本文在撰写过程中参阅了大量Win2000安全的文章,在此向这些作者表示感谢。 |