当客户端从服务器收第一个SYN/ACK包时便把开关掷向ESTABLISHED(已创建)状态,黑客的成功依赖于为CLT_TO_SVR_OFFSET造取了正确的数值,选取错误的数值将使客户端的包和黑客的包不能被接受,而且这样可能产生意想不到的结果,包括连接的终止。 % V6 m3 c) s. O' m' u) J" D0 l
" y2 ^/ Z3 S( ?. x3 O8 Y e 4.空数据非同步入侵 ' R3 P$ B- u/ m# d9 F7 T- y' X' T, r& V7 b% D
在前面部分里,您已了解了黑客如何利用在连接的早期阶段截获一个TCP连接来实施一次前期非同步入侵,非同步一个TCP连接后,黑客能实施一次空数据非同步入侵。空数据指不会影晌服务器的任何东西,不会改变TCP 认证号,黑客通过同时向服务器和客户端发送大量数据来实施一次空数据入侵。 1 L6 A2 H! }. X+ v . \% P7 ~6 O" N* L! F 黑客发送的数据对客户端来说是不可见的。相反,空数据迫使TCP会话中连接的两台计算机切换到非同步状态,因为纯粹的空数据干预到了计算机维护TCP连接的能力。 * A a6 i: s, p: W* y/ Z5 t; X& ^8 r
4 W$ P" J* E$ t) @2 m
5.Telnet会话入侵 4 m( R7 ^3 C" D$ J' t 8 }7 C! X# i) r; k 前面部分已详述了黑客能在一个已存在的或新运行的TCP连接上实施的各种入侵。然而,黑客也可以干预到几乎任何网络通讯。例如,黑客可以用TELNET会话实施以下截获方案: 5 K' @6 g2 w: a# K 5 l3 W1 F3 G4 T1 s0 M- `% W (1)在入侵之前,黑客通常先观察网上的传送,而不进行任何干预。 - O% P9 Q/ e+ ?. D5 K
, C; w7 |7 U# r( d" o( q* T
(2)适当时候,黑客向服务器发送一大批空数据。在被截获的TELNET会话上,黑客发送一个含扩展字号IAC NOP LAC NOP 的ATK_SVR_OFFSET字。TELNET协议将NOP命令定义为"空操作",换句话说,不做任何操作且忽视这一对中的字。由于此空操作,服务器的TELNET的后台驻留程序将把每个字都解释为空数值,因为这一点,后台驻留程序将数据流中的每个对删掉。然而,服务器对扩展空传送的接收将扰乱正进行工作的TELNET会话,在此步之后,服务器接收以下命令: 1 C) L4 w6 a# |4 u1 c. b
5 c- d7 j" L1 x* s" }
SVR_ACK = CLT_SEQ+ATK_SVR_OFFSET ! }2 B) E! s( C$ I! ^: ~$ o; C5 M* p/ `+ y9 @* Q4 A) o
(3)服务器对黑客命令的接收将创建一个非同步TELNET的连接。 2 J$ w0 G+ ]0 l7 l 6 D5 b" y7 g$ M8 O* u5 V$ X& q/ a (4)为了迫使客户机转换到非同步状态,黑客向客户端实施一个与服务器相同的步骤(如图13)。 / b) B- J4 d5 i' T0 M m X; [2 T5 u- L3 N
图13 黑客如何向客户端和服务发送空数据 (5)为完成TELNET会话入侵,黑客实施前面详述的步骤,直到黑客成为TELNET会话连接的中间人(如图14)。 3 z9 H4 ?) y6 Y4 z; P/ ]1 M & c! `( T1 V: q* E0 y5 r7 Q图2-14 如果Telnet 会话可以传送空数据的话,黑客只能利用前面详述的五个步骤的TELNET截获方式。纵使如此,黑客对于选择合适时间发送空数据仍有困难。如果时间不正确,入侵将很容易破坏Telnet会话,或者会引起会话干扰,而不能让黑客控制会话。当您参与TELNET会话,预料不到的结果将表明黑客正在截获会话。 6 H: U4 T( d& v5 ^) d( \, i! T6 k % K$ u3 s. u" J! l* ^# { 6.对ACK风暴的了解 : w2 H. Y- Z7 {( |/ z% x# t6 [8 F1 A' C
在TCP连接内,几乎所有含ACK设定标识而不带数据的包都是未接收包的确认信息。在任何网上,特别是在INTERNET通讯中,将发生大量的转送。在一个遭受了前面详述的各种入侵的网上,会发生更多的转送。转送的号码将依据网上的负荷和引起风暴的黑客主机而定,一个服务器登录能包含多达300多个空包。特别地,在一个实际入侵中传送的数据包可能产生10至30个ACK空包。 # x) I* W! Q1 y 7 ^5 u! d, [" p$ ` 7.检测及其副作用 % T5 _% m$ y( ?& i$ ^% ?; Q% @
/ r0 B; r3 \* Q* t 您可以利用ACK入侵的各种缺陷来检测入侵,这部分将描述三种检测方式,但记住仍有其他方法。 ! A# C. y- H5 a0 N
, c0 n* @5 x# U t! P
非同步状态检测。您可以利用TCP包来观察连接双方的顺序号。根据顺序号。您可以判断出连接是否处于非同步状态。然而,仅当假定您在连接上传送顺序号时没有黑客改变它,您才可以在连接的双方阅读包--这是一个一般的安全假定。 ' i6 q+ g; J$ ?4 q: n; H( _1 i0 g3 I) _1 O6 y
ACK风暴检测:些局域以太网的TCP交通在入侵前的统计表明,总的TELNET包的无数据包率为三分之一,而当一个黑客入侵时,为1/300。 " _* p2 J; c& ^9 W) g3 b% T- j1 O- p+ L% k! a5 n
包百分率记数:您可以通过对包的百分率记数来监视连接的状态。通过对有入侵时的包百分率和普通数据包百分率的对比,可以提醒您存在非同步入侵。表1显示了通常连接中数据包和ACK包每分钟的数目。 ' T% j3 P6 V6 q; x2 w
5 } A# B0 }5 B 表1 普通传送中,ACK包每分钟传送的数目 $ x0 K" q; E, H6 t
包的类型 本地 以太网传输 : d6 b' k& S0 r/ Q1 q. x$ Q: s
Total TCPs 80-100 1400 - {2 [/ `( h6 t# z Total ACK 25-75 500 # C7 s3 |- D5 E4 H; y& r) y- ~
Total Telnet 10-20 1400 " d# E+ X* v! a! j" C" F Total Telnet ACK 5-10 45 ) W- D! s, Z0 U9 [
1 g( J% J1 S! i) x TCP包和 ACK包的数目在本地以太网上变化很大。一个常规连接上的ACK TELNET包的百分率一般稳定在45%左右,Telnet会话是一种交互式会话,服务器必须对用户敲入的每一个字母进行响应和认证。事实上这正是Telnet包计数稳定性的原因所在。在TELNET会话中,基于降低包丢失率的考虑,每个包通常仅含一个字母或一行正文,所以数据交换量较小。正如TELNET数据流,流向远程以太网的数据与其是一致的。因为它的高数据负荷,接收主机可能丢失一些包。 # j8 C- o. w& _+ j$ i; I( w
9 ~8 e: m8 O6 e( L
相对地,当黑客入侵时,真正的包与ACK包的比值会发生改变。表2显示了黑客入侵时包的计数。 / T+ Q h* i3 x/ d! Y 5 a" T7 V6 [& V7 y9 D Y 表2 遭入侵时,ACK包的计数情况 . |; w L3 a f) Y
包的类型 本地连接 + B0 z4 {& y, i. U. x
Total Telnet 80-400 0 O; i' ~1 o5 N, q Total Telnet ACK 75-400 8 ^( W. H5 `1 q7 E # a/ s1 P. O; _$ w' s8 S% L/ I7 g0 G 在表2中,本地连接是指只有少数来自客户端的IP跳跃的一个主机的通讯会话。通讯会话的往返延迟(RTD)大约在3毫秒。例如,通讯会话可能跨越客户机与主机间的4个局域服务器。正如您所知,在黑客入侵时包计数器的改变很明显。就算它变化较为轻微,ACK计数与总包计数几乎是一致的,则交通量基本都是指认证包,意味着几乎不包括数据包