|
最近搞了个服务器,没想到没几天就被攻击了,痛定思痛哇,以前就是研究攻防的,服务器开了也是偷懒,啥也没配置,结果被黑了。因此要把如何设置整理一下,以备配置下一个服务器用。% B3 O: j9 v ]% E; n
一、先关闭不需要的端口
% O1 d1 ?* } s" f$ s$ V) z8 K0 J5 r" \ 我比较小心,先关了端口。只开了3389、21、80、1433,有些人一直说什么默认的3389不安全,对此我不否认,但是利用的途径也只能一个一个的穷举爆破,你把帐号改了密码设置为十五六位,我估计他要破上好几年,哈哈!办法:本地连接--属性--Internet协议(TCP/IP)--高级--选项--TCP/IP筛选--属性--把勾打上,然后添加你需要的端口即可。PS一句:设置完端口需要重新启动!8 C, I$ X. f) j1 Y; U
r% d/ Z7 e4 S) Z 当然大家也可以更改远程连接端口方法:
5 |% p% B% Q6 y. F2 m2 s+ o Windows Registry Editor Version 5.00: Y& {. p/ i1 x: ^' S6 @: @+ L
[HKEY_LOCAL_MACHINE \ SYSTEM\ Current ControlSet \ Control \ Terminal Server\WinStations\RDP-Tcp]' b7 i$ e1 M( U
"PortNumber"=dword:00002683# E) u$ L3 t1 @% s& E
) `4 X; z: P/ K 保存为.REG文件双击即可!更改为9859,当然大家也可以换别的端口,直接打开以上注册表的地址,把值改为十进制的输入你想要的端口即可!重启生效, ~% J/ K0 \: ?5 @( P: Y
还有一点,在2003系统里,用TCP/IP筛选里的端口过滤功能,使用FTP服务器的时候,只开放21端口,在进行FTP传输的时候,FTP 特有的Port模式和Passive模式,在进行数据传输的时候,需要动态的打开高端口,所以在使用TCP/IP过滤的情况下,经常会出现连接上后无法列出目录和数据传输的问题。所以在2003系统上增加的Windows连接防火墙能很好的解决这个问题,不推荐使用网卡的TCP/IP过滤功能。+ p# h4 ]- @3 j0 L/ `4 T
二.关闭不需要的服务打开相应的审核策略
0 s5 {: C7 P- \5 T 我关闭了以下的服务
9 }$ d7 O- E; @, f Computer Browser 维护网络上计算机的最新列表以及提供这个列表% L% B& d" H. Q$ T* q0 d; d) U) @
Task scheduler 允许程序在指定时间运行 g, ?: {* V7 L; z- t+ k5 d: Y( ~
Messenger 传输客户端和服务器之间的 NET SEND 和 警报器服务消息3 R/ p6 X' B- }6 \& W$ D
Distributed File System: 局域网管理共享文件,不需要禁用
3 w$ q0 P+ `8 }, x4 ]- J Distributed linktracking client:用于局域网更新连接信息,不需要禁用/ q+ n3 m# _5 R7 K$ N, S
Error reporting service:禁止发送错误报告
* H+ Z* N7 r: z+ X, [% | Microsoft Serch:提供快速的单词搜索,不需要可禁用
* t2 F% c) {& J6 ?8 Y NTLMSecuritysupportprovide:telnet服务和Microsoft Serch用的,不需要禁用5 A! ^6 G* T/ A: ]% e4 b! F( _/ ~1 \
PrintSpooler:如果没有打印机可禁用
. \& K0 B1 k* e0 T: D$ {7 h& v Remote Registry:禁止远程修改注册表
: W" Z% q% W. {) ]7 @ Remote Desktop Help Session Manager:禁止远程协助
8 m* o4 x) e* d1 g9 t7 G' k# Z. i/ \ Workstation关闭的话远程NET命令列不出用户组3 u- A7 K0 s: @% Y; r
把不必要的服务都禁止掉,尽管这些不一定能被攻击者利用得上,但是按照安全规则和标准上来说,多余的东西就没必要开启,减少一份隐患。7 b3 J. f" D2 B+ A* [
在"网络连接"里,把不需要的协议和服务都删掉,这里只安装了基本的Internet协议(TCP/IP),由于要控制带宽流量服务,额外安装了Qos数据包计划程序。在高级tcp/ip设置里--"NetBIOS"设置"禁用tcp/IP上的NetBIOS(S)"。在高级选项里,使用"Internet连接防火墙",这是windows 2003 自带的防火墙,在2000系统里没有的功能,虽然没什么功能,但可以屏蔽端口,这样已经基本达到了一个IPSec的功能。, d9 f# ^7 z5 q+ r$ B
在运行中输入gpedit.msc回车,打开组策略编辑器,选择计算机配置-Windows设置-安全设置-审核策略在创建审核项目时需要注意的是如果审核的项目太多,生成的事件也就越多,那么要想发现严重的事件也越难当然如果审核的太少也会影响你发现严重的事件,你需要根据情况在这二者之间做出选择。; f W( k2 i3 ?- p0 U
1 T' p4 x( y' r, _: Z 推荐的要审核的项目是:
P& i, R9 o0 \ 登录事件- ^4 [ Y! Y# o' p3 a% j! M
账户登录事件6 E3 }3 k; H$ [/ u
系统事件
! d' D/ J) I$ r, ]$ v 策略更改 k$ u( Q2 p- K: A: y4 ^
对象访问+ d/ x% C" Y( Z: O
目录服务访问" U! b- i* A# v( B1 ~5 Q
特权使用
5 o9 b( \3 M0 W' k! {8 L
7 F9 c( U+ T$ S- e, O( N- E. t* O 三、关闭默认共享的空连接
; N0 b. \6 Y. v" Q/ N) U 地球人都知道,我就不多说了!
: S3 d# C# ?7 \, ~, a; } / `7 p7 q! v: m/ R) ]& \/ ^! o+ l$ f
四、磁盘权限设置4 }$ f! O9 z; Y
C盘只给administrators和system权限,其他的权限不给,其他的盘也可以这样设置,这里给的system权限也不一定需要给,只是由于某些第三方应用程序是以服务形式启动的,需要加上这个用户,否则造成启动不了。
8 ^) }# ` ]6 _ Windows目录要加上给users的默认权限,否则ASP和ASPX等应用程序就无法运行。以前有朋友单独设置Instsrv和temp等目录权限,其实没有这个必要的。; j5 C m8 v0 x, A% Q3 E8 m: J0 |
" Q3 a8 P- R& j9 }0 b. A 另外在c:/Documents and Settings/这里相当重要,后面的目录里的权限根本不会继承从前的设置,如果仅仅只是设置了C盘给administrators权限,而在All Users/Application Data目录下会出现everyone用户有完全控制权限,这样入侵这可以跳转到这个目录,写入脚本或只文件,再结合其他漏洞来提升权限;譬如利用serv-u的本地溢出提升权限,或系统遗漏有补丁,数据库的弱点,甚至社会工程学等等N多方法,从前不是有牛人发飑说:"只要给我一个webshell,我就能拿到system",这也的确是有可能的。在用做web/ftp服务器的系统里,建议是将这些目录都设置的锁死。其他每个盘的目录都按照这样设置,每个盘都只给adinistrators权限。
0 {! e) n- h' ?) E 另外,还将:0 E$ G8 z, Y; Z+ ], v& j h
net.exe NET命令$ C/ h3 u; h$ a: m O
cmd.exe CMD 懂电脑的都知道咯~
1 |+ x3 c8 E# J. r tftp.exe& ~2 ~, m1 O) G$ p2 S
netstat.exe
/ _& ]+ @' r' l$ P o6 R; H2 H regedit.exe 注册表啦大家都知道
% p4 t5 k& |$ J& p" U at.exe
/ H" O# O6 R9 G& f+ K, L attrib.exe$ _$ B2 X( s" D- X# ^: i' C
cacls.exe ACL用户组权限设置,此命令可以在NTFS下设置任何文件夹的任何权限!偶入侵的时候没少用这个....(:
! X: H% D$ J O b format.exe 不说了,大家都知道是做嘛的
, u. ` S" Q1 o: g7 } 大家都知道ASP木马吧,有个CMD运行这个的,这些如果都可以在CMD下运行..55,,估计别的没啥,format下估计就哭料~~~(:这些文件都设置只允许administrator访问。3 |' y; P3 ]. s& E9 o
五、防火墙、杀毒软件的安装
) H; e) C0 {* E, u 关于这个东西的安装其实我也说不来,反正安装什么的都有,建议使用卡巴,卖咖啡。用系统自带的防火墙,这个我不专业,不说了!大家凑合!
1 m1 \1 h r c6 K( t3 t 六、SQL2000 SERV-U FTP安全设置( L. U9 t* E1 a
SQL安全方面
3 u7 N9 B, v( c- R8 O- ~5 _7 D 1、System Administrators 角色最好不要超过两个. S( e1 c. } }- ^( m/ Q1 A
2、如果是在本机最好将身份验证配置为Win登陆+ _( ` Q( Q% j
3、不要使用Sa账户,为其配置一个超级复杂的密码5 L$ \% q0 M* g3 }# X; G( F1 v* A
或修改sa用户名:
8 _; c6 l! K. [& S! }5 N4 _ update sysxlogins set name='xxxx' where sid=0x018 G m+ X2 t* c% o9 b. k5 Q* X
update sysxlogins set sid=0xE765555BD44F054F89CD0076A06EA823 where name='xxxx'
! g# o7 y0 d2 a9 \ 4、删除以下的扩展存储过程格式为:6 J: Y1 X; R, _% d4 J( E+ Z! G
use master
) N1 M( V. S9 `( C2 U sp_dropextendedproc '扩展存储过程名'
) t, L3 v! e: L$ ^ xp_cmdshell:是进入操作系统的最佳捷径,删除/ }: J0 G% D W
访问注册表的存储过程,删除2 Y g9 B' }/ A5 n$ p# a
Xp_regaddmultistringXp_regdeletekeyXp_regdeletevalueXp_regenumvalues5 g% `8 V' n S/ F2 a% e
Xp_regread Xp_regwrite Xp_regremovemultistring. P$ U# `& ?! g( z. l( l4 Z4 p
OLE自动存储过程,不需要,删除
" f, y7 {" x- J( E& K Sp_OACreate Sp_OADestroySp_OAGetErrorInfoSp_OAGetProperty) e/ ?0 _0 d/ j! g6 k3 \9 o
Sp_OAMethodSp_OASetPropertySp_OAStop6 V$ @! M6 s/ e: \% _
5、隐藏 SQL Server、更改默认的1433端口。7 G5 a: ^" }. q5 J( B1 N9 Z, f
右击实例选属性-常规-网络配置中选择TCP/IP协议的属性,选择隐藏 SQL Server 实例,并改原默认的1433端口。
2 v8 _7 m" p; H/ X$ @6 e6 h 6.为数据库建立一个新的角色,禁止改角色对系统表的的select等权限,防止sql注入时利用系统表。
7 |# N, ]: }3 ` @ serv-u的几点常规安全需要设置下:
% A/ i) ?" q7 X: W; K 选中"Block "FTP_bounce"attack and FXP"。什么是FXP呢?通常,当使用FTP协议进行文件传输时,客户端首先向FTP服务器发出一个"PORT"命令,该命令中包含此用户的IP地址和将被用来进行数据传输的端口号,服务器收到后,利用命令所提供的用户地址信息建立与用户的连接。大多数情况下,上述过程不会出现任何问题,但当客户端是一名恶意用户时,可能会通过在PORT命令中加入特定的地址信息,使FTP服务器与其它非客户端的机器建立连接。虽然这名恶意用户可能本身无权直接访问某一特定机器,但是如果FTP服务器有权访问该机器的话,那么恶意用户就可以通过FTP服务器作为中介,仍然能够最终实现与目标服务器的连接。这就是FXP,也称跨服务器攻击。选中后就可以防止发生此种情况。. @2 x, R, ^" D& ~7 S/ ?
七、IIS安全设置
7 k: i9 J$ |. Z1 b# |& P. J IIS的安全:# n( p5 B8 Q8 ~* q" i8 E7 y$ g. r
1、不使用默认的Web站点,如果使用也要将IIS目录与系统磁盘分开。
3 o, p# t8 j+ G 2、删除IIS默认创建的Inetpub目录(在安装系统的盘上)。: N/ Y& m6 q& |4 ]/ [
3、删除系统盘下的虚拟目录,如:_vti_bin、IISSamples、Scripts、IIShelp、IISAdmin、IIShelp、MSADC。+ U" C# c( V2 T6 t/ ?$ A
4、删除不必要的IIS扩展名映射。/ v2 @) X8 q/ `0 C2 G7 \
右键单击“默认Web站点→属性→主目录→配置”,打开应用程序窗口,去掉不必要的应用程序映射。主要为.shtml、.shtm、 .stm。
+ r( Z% ]* F- [: S 5、更改IIS日志的路径- n _1 }/ y+ M& ^
右键单击“默认Web站点→属性-网站-在启用日志记录下点击属性
' ^9 I0 y F" _6 z2 t 6、如果使用的是2000可以使用iislockdown来保护IIS,在2003运行的IE6.0的版本不需要。- ?$ L( H8 q+ p- C9 z: Y M0 T
八、其它
" {- a5 U8 w# \/ ^0 _1 i# s/ f$ z 1、系统升级、打操作系统补丁,尤其是IIS 6.0补丁、SQL SP3a补丁,甚至IE 6.0补丁也要打。同时及时跟踪最新漏洞补丁;
7 q7 F% O9 [4 e% e9 l! `: h/ K9 \; Z 2、停掉Guest 帐号、并给guest 加一个异常复杂的密码,把Administrator改名或伪装!
* p9 E1 n4 S% @- T. x3、隐藏重要文件/目录
# c E! v Q/ A( ]- v 可以修改注册表实现完全隐藏:“HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\ Current-Version\Explorer\Advanced\Folder\Hi-dden\SHOWALL”,鼠标右击 “CheckedValue”,选择修改,把数值由1改为0。* P5 k8 k# p' n6 k' v
4、启动系统自带的Internet连接防火墙,在设置服务选项中勾选Web服务器。5 U c s1 g1 O
5、防止SYN洪水攻击。' M% M+ R4 E1 n1 b1 [+ y( f, j7 r
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters$ v. C0 U; E3 s k- t6 F
新建DWORD值,名为SynAttackProtect,值为2
, W/ w# o7 F4 j7 X) J+ @ c2 F' U7 H 6. 禁止响应ICMP路由通告报文7 J, h3 P- ^1 ^2 C, [; D$ v
HKEY_LOCAL_MACHINE \ SYSTEM \ CurrentControlSet\ Services\Tcpip\Parameters\Interfaces\interface
0 F6 C6 E5 a' J 新建DWORD值,名为PerformRouterDiscovery 值为0。
8 f' _3 r( R$ [, ^4 w- _ 7. 防止ICMP重定向报文的攻击
) Y( m* v" `2 L HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters
4 o8 |' m7 @/ Z* e, u3 ` 将EnableICMPRedirects 值设为0; _. d. q* v% ?+ n
8. 不支持IGMP协议0 W/ @8 o G5 h' q' k
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters: O$ q: C/ C" k$ p7 x1 x
新建DWORD值,名为IGMPLevel 值为0。9 K8 M4 G1 V! I* h# o7 G) `1 i
9、禁用DCOM:2 b- {! s4 f4 N( A+ k D& `2 @8 S3 ?
运行中输入Dcomcnfg.exe。回车,单击“控制台根节点”下的“组件服务”。打开“计算机”子文件夹。
) e( L# k9 Z' J% ]; ~2 d$ a& ~% y6 t, T6 K1 \& W
2 {8 D3 ]: n& x8 f2 J
|
|