; A( h ~, Z, |# ~1 s; {8 A0 s
! O' S3 D* J2 T
1 c* F9 U. ^$ j7 q3 p本文中提供的例子均来自网络已公开测试的例子,仅供参考。
j/ z. p8 Y9 J/ e
6 b- M" s7 o5 G! x" e1 o本期带来绕过验证漏洞。为了保障业务系统的安全,几乎每个系统都会存在各种各样的验证功能。常见的几种验证功能就包括账号密码验证、验证码验证、JavaScript数据验证及服务端数据验证等等,但程序员在涉及验证方法时可能存在缺陷导致被绕过,于是斗哥总结了以下几种绕过验证的姿势和大家一起讨论讨论~
. E k6 y+ a8 _. a& ? j2 {+ R
& c' `3 a N4 p1 N
, K, ?) n- i+ G0 N
* t' R; g n) Z' L# H- T' _
9 n9 z. x" f& ]" s0 ]$ ^2 F
( f% d: L+ v' z( ~9 |3 [; L5 |
. R$ y% _* b' p" @) T( e
8 c0 x! k/ k8 S2 J0 M a) g8 ?
8 }+ z& j6 J" x7 X
客户端校验绕过
, a) k4 b' E9 N Z
' i0 ~4 ^( i7 w* }. r6 B; B- P1 y
客户端校验是常见的一种校验方式,也就是在客户端校验用户的输入,将校验结果作为参数发送至服务端,或利用前端语言限制用户的非法输入和操作。面对此类的校验方法可以通过修改前端语言或者在传输中对参数进行篡改来绕过验证。
( K& h0 q( P( o ], o. [; G" b
) N5 L) B9 _( e8 ~9 Z4 S举个栗子:
- E/ l, h0 A7 s7 Q3 L
" \! O- l2 z% Ja). 某系统需要购买才能观看视频,不同的课程以ID划分。
) `0 w1 k+ A, j. Y; M4 ]4 A
4 K# _ z. o$ w+ x
" _' D, `1 I/ Z4 u
/ n5 U. l* {% x( d& I
/ _' q+ `' `! O/ t- A( r/ p
( e: R+ @" K/ e! K, R e6 k! f
. z$ c) ?% ~: ~
% U6 d! I7 D4 k- E4 V' `- \
: n# q5 H( P0 P) U7 {: Q+ Tb). 发现是否付费只靠前端js控制,更改courseID就可以看到不同的课程,recordURL就是视频播放的链接,无需登录即可播放。
1 y2 u4 E7 W+ A5 d6 U3 c
( k- K# i) m4 G' S8 l6 b1 R: m3 b * W4 f; ]1 F; V2 L# ^9 u% `' g L
) M8 a: i @. Q
. f# q, m+ W/ q2 x# X9 h' Y8 r9 p
+ F9 T1 `5 d8 D- @
, ?- n# l2 d/ i: Y6 b2 S8 ]+ n7 }. g
4 N! x; l; B6 @" C+ m5 [& q6 B) @0 S$ I/ \
2 p1 E- V4 F1 f: [$ g
c). 根据播放地址中的videoCode,可获取视频下载地址:
0 F' T& L5 i8 Y# d
+ P9 Z+ K% q. p B; d( h: x0 whttp://*.*.*.*/v3/resource/video/queryurl?jsoncallback=cb&quality=3&audioIndex=0&types=1&videoCode={videoCode}
7 H$ ]4 d5 X( q; m1 ~* ~& b
7 W: n y" K3 [9 w* a
所得urls为视频下载地址。
8 L% v" x5 c; W9 y5 A
1 X: R; }9 |2 g' l
: f: e5 X3 Q' t: c) d
; g) `- a* D- Z: t* x1 i) ~
+ ?& r+ o- ^( U) v5 Z5 J2 Q }
: R$ H% A) n' p' y& B0 F
2 H& E5 w4 E2 S5 q/ v
5 [8 j [) J$ n- \- s! u
7 S: Z* n+ a) R7 j) S) A2 M
d). 通过脚本,可将全站视频下载下来。
. s% F% d2 _: J$ ~7 N
\+ x5 a& O( f5 z) N- b6 z% d
( K1 B/ F2 I1 Q6 r/ m) l
+ l/ o; t/ L% j# g
2 ?0 \8 T# a+ S6 R# l( C, p
; O! ~' \# t2 Y$ a9 J+ E1 k
' d- C3 U7 ?) B- x) S7 N' t( I% ?
' i3 B: K+ v0 C3 l3 ^) D5 C
8 Y+ h$ P( m5 ^ G) g, M }. D
客户端验证信息泄露
& q" x! Z, |3 v3 i( E. L( J
5 j1 o$ T2 H' X% q程序员在编写验证程序时有可能会将验证信息直接泄露到客户端,攻击者就可以通过分析服务端的返回数据直接获得关键的验证信息从而完成验证。
$ Y/ B/ Q Q3 s, B
$ J$ n$ x$ k0 F举个栗子:
; \5 t4 d& i$ S. H# G2 u
9 T) \0 O& h& `5 i0 E" }
某免费wifi连接时需要使用发送到手机的密码进行验证,抓取发送密码的数据包时,发现密码返回客户端,导致任意全网账号可以登录联网。
4 v5 y2 l5 \1 _2 {) X; {
" P2 V( A+ C" M) s1 q- X. ~ c1 u
( b& N9 |6 W9 s9 a! F% f# l- G
7 Y' X% q7 l9 O8 l! U* h( v# @4 x) }
4 m! |9 G. f8 a, z
# D9 H- b% e( o6 ]1 u5 e% u8 `
/ t; N7 M: z5 B5 X
/ r$ [8 j; q- H/ t( I+ X
1 H! _. G. `6 n5 }6 n T9 ]
客户端流程控制绕过
9 _7 j9 d. X( ~
$ l% y9 k; Q. O# J6 [* @3 r
程序员在编写验证程序时有可能会验证结果返回到客户端,由客户端根据服务端提供的验证结果进行下一步操作,攻击者可以通过篡改验证结果或直接执行下一步操作实现绕过。
: S7 q& s6 q1 C& R6 Z
- @0 y" z! c2 w
举个栗子:
J! j7 y F: H9 B% R" g7 r
+ y' d! _) Z! ?: A( d; X5 ^, b. H9 m
a). 某系统重置密码需要三个步骤,首先要输入图片验证码。
. R0 L$ K* L: o6 ]- ?) k
0 a' a9 V3 d* n4 h1 q8 [ - l) \; |* J9 j7 P- _- [
; [! W/ F. S& N5 }
{8 v; P# v' R5 Q! A
$ z+ Y/ n, B3 _/ `3 e
o% O! y1 r5 s' S 2 }' ~" c- Z- m2 j* y6 F
0 L8 ~% X: ` n4 V' n
b). 然后需要通过短信验证码验证身份。
& }: N% K8 l( V4 V+ }
5 b3 _* W; A" H1 G& Q
) c% M8 b p: F8 W1 X, M! {& J
; }3 T! K G; {9 L3 {6 e
. v7 B7 ~, `' c2 `
+ N, U1 O3 U7 D2 C- H$ P+ I
5 n7 r$ @' z6 R; o0 V* w
) M) s2 h2 ~4 G0 O. M
5 R' W. l4 y. Oc).访问http://*.*.*.*/a/user/findPasswordSetp 直接跳到重置密码的页面。
3 j7 s) j3 j( i1 i
& g: ^ ~ ~" z/ _+ j
1 Q, @$ H9 d4 [
+ }* D. w, q, ^7 @( _
1 s7 B! g$ u2 Q0 i3 F- f) @$ T9 ~( ~
8 H+ S* t9 ^' _! j
5 D6 W d! D, a0 v ^% g6 F7 t1 W
+ [8 {& |! p$ l# m( l* i1 ?
% T* @6 B% j5 K& }) rd). 可成功修改密码密码。
) d. ]0 k4 b. }% @* O( @8 G
3 |% v* B; C& ~9 h
/ g3 i! q7 d5 }9 u1 E
! T0 I3 D- Q7 m c % ^" a6 N m6 O
/ |! {3 B- B$ C; Z$ }
/ Y* C/ r! y$ z |8 f, @5 A( w; Q 9 n# X! l$ |3 k' R0 K$ _- N
- F, K H& p8 a2 ~5 e$ ^# I操作目标篡改绕过
" L" b, p) ^: t2 Z
}( j: K( @" i3 V" p: U9 R, L
如果某操作采用了连续身份校验机制或身份校验过程与操作过程分离,可以尝试在身份验证过程中替换身份校验对象或操作对象实现绕过验证。
/ E# C" T7 a. v. i
6 b, O: U6 ^. F举个栗子:
+ R1 \* }% O4 h5 Y% S& y1 q
% K0 `* R2 p+ N& n0 P
a). 修改某系统的绑定手机。
0 ]! R" Z3 _* K$ r+ K
: P# [: ~' f7 {# F w, e
7 o! j% q" I' k. `5 ]1 G" h
C% H ]+ G# G* e1 a) t- K, r
2 f! S5 S- c" A0 n! Y3 s
. o: V! e B2 m
$ a1 U* M# z: m7 M+ J0 e& x
; \" J9 E& r3 G8 m; A
: X C" Y! W* C! _, m' j7 a: I
b). 选择免费接收短信校验码修改。
& V# Z P4 Z) F, a" K
9 A5 o6 |9 |- e" F2 }. h3 E7 L + |' o( z- v C% l) J- [0 Q& O
* O1 M! i% d, g$ q+ i* ^
( q1 B/ \1 b( @
i e; K7 Q# c6 w
6 P) V; Z& I+ s
4 H1 d5 a7 S& L9 |: W
& N3 w+ H P3 P& X! d6 G0 jc). 将修改的手机号改为自己的手机号码。
$ z$ G8 ~9 S: W; f. _* N
. T, U4 [+ Q3 E
7 _/ I- ]6 G) N# V, X+ ]6 H
! ~# G; E9 e: y" [, }
6 j! V! o! a# [5 _
+ a; W! A( N4 w" E
! @0 [8 C8 e. z1 V. c$ Q & V" w( S, e V( S4 Z6 ~, c0 Z
$ Q. R! ?( `4 ?3 L/ S2 G
d). 通过修改的手机号码收到的校验码修改手机号。
5 { i T, F i0 R, _- R
2 X+ O+ }7 y0 a! d& v+ D
4 C! h: c4 ^- w+ P8 Z. ?7 }! x
; v$ W3 S4 P; _4 K2 h
) u$ n/ q6 b! X
/ K) m. ~0 G3 x" }- P: |: Y
4 p/ k! }) K; U5 z0 w2 t
, _1 } i+ N# }7 y- p/ T2 O
$ H# ~- w" p3 j* e# Q& f- Z0 ^
, v; C' X; j+ t7 ~3 Z, P: De). 发现可以成功修改成新的手机号。
0 i9 q6 T0 [( i, d ]
& ]1 s( a2 c) {0 m) ~- O+ i- _
( f7 C% R; y! U. x$ v. K
; Q9 \/ \, K' Z& f- a9 S" S0 v& }
; A$ }# p5 }( e B! k' {6 p- y
3 U: L8 F8 i1 {- a4 l, I
5 j" x$ N0 N# E
+ q7 H+ x$ L. `/ Q. K1 m& C$ |
8 x* v+ v. q& `. B1 ]2 T8 W参数篡改
" Q' \% Y' w9 p k9 `
: P0 {6 z% S/ j% Y2 C程序猿小哥哥在编写验证程序时有可能会对验证码字段进行正确性校验,但当验证码字段不存在或为空时就直接通过校验。
3 {, s7 J( O- O) R3 [7 g
" ^$ M) e0 i: E4 M7 y* h举个栗子:
: R! N! K6 \5 J. [6 O2 _
0 v2 T5 q0 k K6 ?6 t. i7 [
a).某系统存在绕过验证漏洞,抓取登录的数据包。
9 P* \9 q! \6 u" D3 G
9 Q. H R% C. `9 S1 j6 x 0 r. y2 I) m2 ^6 v; w
7 \& r* f4 b# h% u/ R # n1 f: E; T! K& T$ a+ h
& i) r" i8 v; X6 t" N3 |
* k3 D4 H# |- N7 r' w% _5 y* _
# G+ F! D, j$ c/ p
# a8 j9 h3 F m
b).删除验证码字段(securityCode)进行爆破。
$ [( Z: f8 d8 _' s- c
$ G3 p$ R" m4 Q! A
) m( A+ `. |; U. p* i2 B2 g
8 K: q3 a+ Y4 r! `# W
* s- i: u4 @& ?1 X( u6 z, I5 z! D% x, K( ^
% N) M1 q% [- k* I
( ]6 B$ M6 Y @
. {! `: L' K0 K6 Q A
+ M, S3 @( C3 l; [
c). 爆破成功,并可以使用爆破出来的账号密码进行登录。
5 u7 n! d; m* ~8 L
( m( `" ^2 y# z p; ^
" S# P4 c a; ]) e
4 Z$ P! l8 d" }& G0 S
3 A0 r S. ~: G. ~/ H% u
( j1 J) P/ x! R& W
% ~: ^; h* W* Z1 X: ?
- g1 y6 I/ W+ @- e
! }' u. P9 c; A: z% F2 ~6 Y
, k" B7 y# N! d 6 Z# U, Y3 v- D
- x8 \8 x/ l( C7 y" V1 w4 j
7 x; V+ Z: O- Y2 S
' A, H5 ^ p$ i. ~" l1 G& J0 k8 z2 m
/ a9 Z, J* u3 w, y: v辅助验证功能绕过
3 o0 \# t0 w( O% Y
) f- p3 o6 T+ q
为了验证用户身份或者避免攻击者使用自动化工具进行批量操作,应用程序可能会采用辅助验证功能,常见的辅助验证功能包括图片验证码、短信验证码、邮箱验证,这些功能在设计时如果存在缺陷则可以被绕过,导致辅助验证功能失效。
& g( r6 j( A" D3 P" [1 o8 U# l
) J/ ^6 `- p) _9 {7 M w' b, I0 b举个栗子:
8 V9 }1 q% ~/ J* k2 y r
/ M) a$ V. Y$ o5 u( x: w8 M6 H2 D; K
a). 访问某系统,一开始页面无验证码。
$ X0 M; q$ u J* O: W o
6 K2 p/ ?0 Q5 v$ v 2 w! H. \" n0 ?+ C" F, C
* A7 j: V* G% c% N7 I7 g 1 O5 t+ a$ @- i$ A3 H
" |" E% o2 w! X
2 K' l" z4 j2 @+ T$ `
8 Z0 \: ^' v/ W
9 k0 |- m2 O" G
b). 输错一次之后,出现验证码。
5 \7 H6 I: K% B
0 v: N8 w* A: ^! N0 P6 o W1 \+ D% P2 x3 I
6 W- K* q8 ]7 B4 w0 G8 L
/ R" p" W ]0 T& K
, L/ u ]& m, c8 L
3 h' E: ]6 Y6 @) F+ n% }
7 R6 R/ ~/ h" @0 ^; w7 r& _8 Q% {
" }% u7 D( l h5 x1 q
. m, y) Q* H. L8 ]0 n- pc). 尝试进行爆破,抓取第一次无验证码的数据包,发现会提示需要验证码。
( z) R+ Y: F3 E
& i! Q2 O% M4 X" V" d
# q- `- r% R+ d" O4 {# V
. ~7 z/ H5 r$ u; C) K
% h3 z n. z8 V9 o( Y
+ M5 N% y+ E. J( S
) R3 m: X8 `1 D: ]' Z# E3 J
' Y; S; J7 `2 u. G8 V
+ w) X* [. f; q- ^( C+ g7 K
d). 多次尝试之后发现,验证码是通过cookie中的PHPSESSID来判断的。
7 A4 |9 o/ q5 R0 t
2 w" N5 P$ m& M$ C& [3 q: n. g, F' N + d- [* I4 T. H7 _. r/ T1 d! j
+ k8 U; w- n# I6 {7 P0 o6 Z
; R$ @0 c- d y6 I. P' [
8 Y4 ?9 c8 V0 J# w) n( p0 K2 f7 `
7 h& _* r7 ^6 m" \3 |. q/ G
/ C! g4 g% Y( R( }) a% t. f
5 p& _6 U6 I8 h0 X& g$ b W! a
e). 修改PHPSESSID后成功绕过验证码限制。
( r/ o7 I/ S2 ^' |- j
9 g4 [- ^9 i+ m
5 G8 A4 }+ Q) R7 w# x( _
4 p9 q$ Q* k/ d& _6 O# O
- m& o4 W& U7 K: _( a8 [% ]
& O9 a6 a& u2 y2 B) g
: x4 N" N/ M# }4 Z; f7 S 8 K; F+ I2 L: r$ x9 k1 {% F
& `5 U9 n. ^9 X3 I
. J5 t$ ?4 x) Jf). 成功爆出账号。
7 n* O/ m- E. V) c/ V& a& ^
( I2 x( x- v: d ^: |
& e+ w4 q8 _6 H
b9 x. J5 C% p' y( `4 P
1 Q- D- p$ e6 `3 d8 U7 r$ ]7 z; n
3 l1 \8 f5 Q% N4 [6 o# F7 q
1 [- X) P V/ S7 }4 l 1 Q# u1 @0 q' ^0 G
5 Q) k. X3 V8 q6 @0 O
; t2 b* }+ v" k; P2 g
好啦,斗哥对于绕过验证的总结就到这里啦,对于绕过验证的修复斗哥有一点点建议:
3 W% S9 K" a. s+ t2 g2 W) C
2 ^( \% X* S% G9 z$ L
1.所有验证在服务端进行,验证问题的答案不能以任何形式返回客户端中(如图片验证码答案、短信验证码、验证问题答案等)。
* }7 V5 E x# R: a& D7 o
( [. A# _/ |! h- M T2 R3 ^3 o
2.验证结果及下一步跳转操作由服务端直接进行。
( e; s5 u5 n4 b5 I
% D' K: B1 p: l. d1 p$ w( K
3.应尽可能避免采用连续身份验证机制,无论采用何种验证机制,只有当所有的数据输入以后,才进行身份验证数据的验证。 / A) T9 S' [, i* D6 a" n$ |
' C2 O+ I$ E1 T6 k2 [