a我考网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 123|回复: 1

[其他] 思科认证:cisco路由器如何关闭一些不必要的服务

[复制链接]
发表于 2012-8-3 10:16:48 | 显示全部楼层 |阅读模式
一、Cisco发现协议7 b% x$ Z+ V, ?* \- F+ h
    CDP是一个Cisco专用协议,运行在所有Cisco产品的第二层,用来和其他直接相连的Cisco设备共享基本的设备信息。独立于介质和协议。
: }' g! L: j% k8 d' v( |/ E$ s    黑客再勘测攻击中使用CDP信息,这种可能性是比较小的。因为必须在相同的广播域才能查看CDP组播帧。所以,建议在边界路由器上关闭CDP,或至少在连接到公共网络的接口上关闭CDP.
* ]3 u: g8 Q- j8 q" u* w    缺省情况下是启用的。全局关闭CDP,使用no cdp run命令,关闭之后,应该使用show cdp验证CDP是否已被关闭。
+ _! N* b  G1 O0 S: ]" f/ h4 `    二、TCP和UDP低端口服务
) @4 X3 x# s7 o& @& M    TCP和UDP低端口服务是运行在设备上的端口19和更低端口的服务。所有这些服务都已经过时:如日期和时间(daytime,端口13),测试连通性(echo,端口7)和生成字符串(chargen,端口19)。9 G' A! W* r7 w" i/ Q9 `/ F
    下面显示了一个打开的连接,被连接的路由器上打开了chargen服务:Router#telnet 192.168.1.254 chargen
/ B1 u0 ?* w; |8 a. \    要在路由器上关闭这些服务,使用下面的配置:Router(config)#no service tcp-small-serversRouter(config)#no service udp-small-servers
4 Z2 l3 u! z* z# H    关闭了这些服务之后,用下面方法进行测试,如:Router(config)#telnet 192.168.1.254 daytime; [! j* I; q6 l! y- _% E0 Q
    三、Finger( _5 a5 u" X4 p7 F) c- A" c) ^
    Finger协议(端口79)允许网络上的用户获得当前正在使用特定路由选择设备的用户列表,显示的信息包括系统中运行的进程、链路号、连接名、闲置时间和终端位置。通过show user命令来提供的。, r6 A2 W  E5 P. \9 N, |  ~4 [
    Finger是一个检测谁登录到一台主机的UNIX程序,而不用亲自登录到设备来查看。
5 O' ?! `' \, B0 b    下面显示了一个验证finger服务被打开和如何关闭的例子:Router#telnet 192.168.1.254 finger
3 G: r1 i' T* D8 m8 B; ^4 m    (connect 192.168.1.254 finger)Router(config)#no ip fingerRouter(config)#no service finger$ o0 C6 Z' P8 O" t7 X% y
    当对路由器执行一个finger操作时,路由器以show users命令的输出来作为响应。要阻止响应,使用no ip finger命令,将关闭finger服务。在较老的版本中,使用no service finger命令。在较新版本中,两个命令都适用。5 H3 \! ]6 H/ |" |* n
    四、IdentD: p  W! P  a- ?9 [" ?) U9 b8 D/ K
    IP鉴别支持对某个TCP端口身份的查询。能够报告一个发起TCP连接的客户端身份,以及响应该连接的主机的身份。5 Z3 U, r- l& u( B
    IdentD允许远程设备为了识别目的查询一个TCP端口。是一个不安全的协议,旨在帮助识别一个想要连接的设备。一个设备发送请求到Ident端口(TCP 113),目的设备用其身份信息作为响应,如主机和设备名。
1 G2 b1 H* {. K- L& M9 m: Q5 F    如果支持IP鉴别,攻击者就能够连接到主机的一个TCP端口上,发布一个简单的字符串以请求信息,得到一个返回的简单字符串响应。6 [3 R- k5 U% a1 u. g7 H' t
    要关闭IdentD服务,使用下面的命令:Router(config)#no ip identd" ~+ i6 {+ K: l- n- O  c4 D
    可以通过Telnet到设备的113端口来进行测试。( V& s6 {  v" r) e
    五、IP源路由
; S& A$ W$ n6 ]# y  F( v    应该在所有的路由器上关闭,包括边界路由器。可以使用下面的命令:Router(config)#no ip source-route禁止对带有源路由选项的IP数据包的转发。    六、FTP和TFTP* p9 |3 ]7 }! j1 u0 H# y
    路由器可以用作FTP服务器和TFTP服务器,可以将映像从一台路由器复制到另一台。建议不要使用这个功能,因为FTP和TFTP都是不安全的协议。( c) B# B0 _. |) E1 R8 R6 o$ R# u
    默认地,FTP服务器在路由器上是关闭的,然而,为了安全起见,仍然建议在路由器上执行以下命令:Router(config)#no ftp-server write-enable (12.3版本开始)Router(config)#no ftp-server enable8 a; C* ?; }' R7 R% F
    可以通过使用一个FTP客户端从PC进行测试,尝试建立到路由器的连接。
8 q8 O, |# h5 r% p) m    七、HTTP
/ |& U: ?' f  ^: J$ `5 G8 w    测试方法可以使用一个Web浏览器尝试访问路由器。还可以从路由器的命令提示符下,使用下面的命令来进行测试:Router#telnet 192.168.1.254 80Router#telnet 192.168.1.254 443
* ]" W) ?7 q9 G- P  _$ f    要关闭以上两个服务以及验证,执行以下的步骤:Router(config)#no ip http serverRouter(config)#no ip http secure-serverRouter#telnet 192.168.1.254 80Router#telnet 192.168.1.254 443  h4 E4 q7 [" \. i$ K! R( P
    Cisco安全设备管理器(Security Device Manager,SDM)用HTTP访问路由器,如果要用SDM来管理路由器,就不能关闭HTTP服务。9 ^7 R2 B, y* a( Y' K
    如果选择用HTTP做管理,应该用ip http access-class命令来限制对IP地址的访问。此外,也应该用ip http authentication命令来配置认证。对于交互式登录,HTTP认证最好的选择是使用一个TACACS+或RADIUS服务器,这可以避免将enable口令用作HTTP口令。5 L) V1 d1 h  X4 W# I/ {
    八、SNMP
+ f+ B; {7 \3 A* I    SNMP可以用来远程监控和管理Cisco设备。然而,SNMP存在很多安全问题,特别是SNMP v1和v2中。要关闭SNMP服务,需要完成以下三件事:
7 u. m2 n( W& R0 b: Z5 W    *从路由器配置中删除默认的团体字符串;
) W6 f% L" ^; W; p' C- U    *关闭SNMP陷阱和系统关机特征;+ L, f3 z( x) k
    *关闭SNMP服务。
) j* o- o. \$ i# J/ L7 O* M    要查看是否配置了SNMP命令,执行show running-config命令。
回复

使用道具 举报

 楼主| 发表于 2012-8-3 10:16:49 | 显示全部楼层

思科认证:cisco路由器如何关闭一些不必要的服务

下面显示了用来完全关闭SNMP的配置:Router(config)#no snmp-server community public RORouter(config)#no snmp-server community private RWRouter(config)#no snmp-server enable trapsRouter(config)#no snmp-server system-shutdownRouter(config)#no snmp-server trap-authRouter(config)#no snmp-server; j% }1 o7 v& y- l$ h
    前两个命令删除了只读和读写团体字符串(团体字符串可能不一样)。接下来三个命令关闭SNMP陷阱、系统关机和通过SNMP的认证陷阱。最后在路由器上关闭SNMP服务。关闭SNMP服务之后,使用show snmp命令验证。! ?$ I0 D7 b$ {$ e! B  Y- A
    九、域名解析
. P5 I* f, P% D2 o    缺省情况下,Cisco路由器DNS服务会向255.255.255.255广播地址发送名字查询。应该避免使用这个广播地址,因为攻击者可能会借机伪装成一个DNS服务器。
$ c1 D" d" x9 s% `5 `& }    如果路由器使用DNS来解析名称,会在配置中看到类似的命令:Router(config)#hostname santaRouter(config)#ip domain-name claus.govRouter(config)#ip name-server 200.1.1.1 202.1.1.1Router(config)#ip domain-lookup6 _& ]6 H; l+ R+ u
    可以使用show hosts命令来查看已经解析的名称。
* q  }/ L7 Y& ^( n  x. ^+ [    因为DNS没有固有的安全机制,易受到会话攻击,在目的DNS服务器响应之前,黑客先发送一个伪造的回复。如果路由器得到两个回复,通常忽略第二个回复。" L/ C: O/ |; ]0 o: e
    解决这个问题,要么确保路由器有一个到DNS服务器的安全路径,要么不要使用DNS,而使用手动解析。使用手动解析,可以关闭DNS,然后使用ip host命令静态定义主机名。如果想阻止路由器产生DNS查询,要么配置一个具体的DNS服务器(ip name-server),要么将这些查询作为本地广播(当DNS服务器没有被配置时),使用下面的配置:Router#telnetwww.quizware.com80  (测试)Router(config)#no ip domain-lookupRouter#telnetwww.cisco.com80     十、BootP- @; w% q$ ~3 q
    BootP是一个UDP服务,可以用来给一台无盘工作站指定地址信息,以及在很多其他情况下,在设备上加载操作系统(用它来访问另一个运行有BOOTP服务的路由器上的IOS拷贝,将IOS下载到BOOTP客户端路由器上)。: Y: C$ C% w3 W8 H
    该协议发送一个本地广播到UDP端口67(和DHCP相同)。要实现这种应用,必须配置一个BootP服务器来指定IP地址信息以及任何被请求的文件。# u/ t8 g, y9 m% F3 Y- @# I
    Cisco路由器能作为一台BootP服务器,给请求的设备提供闪存中的文件,因为以下3个原因,应该在路由器闪关闭BootP:*不再有使用BootP的真正需求;*BootP没固有的认证机制。任何人都能从路由器请求文件,无论配置了什么,路由器都将作出回复;*易受DoS攻击。1 r8 @5 ^$ K( L+ g% X6 @% F+ f' Z4 C
    默认地,该服务是启用的。要关闭BootP,使用下面的配置:Router(config)#no ip bootp server0 b  \4 m; h" w3 r6 W# G0 c. t
    十一、DHCP
& D9 z& o& g, {+ Z1 P    DHCP允许从服务器获取所有的IP地址信息,包括IP地址、子网掩码、域名、DNS服务器地址、WINS服务器地址哈、TFTP服务器地址和其他信息。Cisco路由器既能作为DHCP客户端,也能作为服务器。  @. o+ {* u0 ]/ y. F. Y
    在将Cisco路由器作为边界路由器时,应该设置该路由器为DHCP客户端的唯一的情形是,如果是通过DSL和线缆调制解调器连接到ISP,而ISP使用DHCP指定地址信息。否则,决不要将路由器设置为DHCP客户端。
; S! H+ `7 y& y! i    同样地,应该设置路由器为一台DHCP服务器地唯一的情形是,当在一个SOHO环境中使用路由器,在这种小型的网络中基本上这台路由器是可以给PC指定地址的唯一设备。如果这样做,确保在路由器外部接口上过滤UDP端口67,这将阻止来自外部的DHCP和BootP请求。/ L+ j- ?& |5 D
    一般DHCP服务器是默认打开的。使用下面的配置关闭:Router(config)#no service dhcp这阻止路由器成为一台DHCP服务器或者中继代理。0 d- y- m% [; B  ^9 c. \7 \  h
    十二、PAD  [, T3 V3 C2 K4 ?- n# S
    数据包组合/分拆(packet assembler/disassembler,PAD)用在X.25网络上。以提供远程站点间的可靠连接。
% a& l, U/ t/ G8 S+ r; @    PAD能给黑客提供有用的功能。假设黑客能获得直接连接在路由器上的设备的控制权,而如果路由器在运行PAD服务,它将接受任何PAD连接。
7 t' c! V1 b$ O! j2 D- p: d    要关闭这个服务,使用下面的命令:Router(config)#no service pad1 l) [1 |6 j" o' W
    十三、配置自动加载
4 Q3 Z( v/ e9 W    Cisco路由器启动时,在出现CLI提示符之前,将经历几个测试阶段、发现Cisco IOS和配置文件。路由器启动时,通常会经过以下5个步骤:*加载并执行POST,发现ROM,测试硬件组件,如闪存和接口;*加载并执行引导自举程序;*引导自举程序发现并加载Cisco IOS映像文件。这些映像文件可以来自闪存、TFTP服务器或者闪存;*加载了Cisco IOS之后,发现并执行一个配置文件:配置文件储存在NVRAM中,但如果NVRAM是空的,系统配置对话框开始,或者路由器使用TFTP来获取一个配置文件;*给用户CLI EXEC提示符。
8 _, j. Q# z, p! U    在发现一个Cisco IOS文件时,假定在NVRAM中没有boot system命令,路由器首先在闪存中寻找有效的Cisco IOS映像文件。如果闪存中没有IOS映像文件,路由器执行TFTP启动,或者网络启动;发送本地广播请求从TFTP服务器上获取操作系统文件。如果这个过程也失败了,路由器从内存中加载IOS映像文件。
; J3 u, w6 @  w* H0 r0 [% h    因为启动过程中用到TFTP,而对加载过程没有安全保护。所以,不应该允许路由器使用该功能。要阻止该功能,使用下面的配置:
/ |4 h, k. x" ?/ ?/ `! r    Router(config)#no boot network remote-url-ftp:/ Q3 N4 H( Z' [8 q5 N2 d# g
    [[[//[username:[:password]@]location]/directory]/filename]-rcp:
  }  a4 m- d$ U# e) c    [[[//[username@]/location]/directory]/filename]-tftp:, E- x, |: x* h) t
    [[[//location]/directory]/filename
+ ~2 q$ c; T. q& M; p    加载了IOS映像之后,开始发现一个配置文件。如果在NVRAM中没有配置文件,路由器会使用系统配置对话框来建立配置文件,或使用网路配置选项:使用TFTP广播来发现配置文件。所以,应该使用以下的命令关闭该特性:Router(config)#no service config  T$ [' }0 \( Q( ]4 X" E8 a# E
    十四、关闭无根据ARP
7 s& z* t* f) \% i( q: G    大多数Cisco路由器(缺省情况下)都会向外发送无根据的ARP消息,无论客户端何时连接并基于PPP连接协商一个IP地址。ARP毒害攻击主要利用的就是这种ARP消息。' l4 f, l, ~! ~# A4 K
    即使客户端从一个本地地址池收到地址,Cisco路由器也会生成一个无根据的ARP传送。; j# |# ]" X" M: p
    禁止无根据ARP传送,使用下面的命令:Router(config)#no ip gratuitous-arps 十五、关闭IP无类别路由选择服务
( |4 t/ m6 R) B6 w    路由器可能会收到一些发往一个没有网络缺省路由的子网的数据包,如果启用了IP无类别服务时,会将这些数据包转发给最有可能路由的超网。
2 T( r0 b( C9 p; i    要关闭IP无类别路由选择,在全局配置模式下使用no ip classless命令。
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|Woexam.Com ( 湘ICP备18023104号 )

GMT+8, 2024-5-17 05:06 , Processed in 0.298136 second(s), 23 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表