0x00 相关背景介绍( V" j- w2 L! @
! f. \2 d9 {- G+ g由于应用越来越多的需要和其他的第三方应用交互,以及在自身应用内部根据不同的逻辑将用户引向到不同的页面,譬如一个典型的登录接口就经常需要在认证成功之后将用户引导到登录之前的页面,整个过程中如果实现不好就可能导致一些安全问题,特定条件下可能引起严重的安全漏洞。
4 B9 j5 h* R: `5 E" O$ V% @5 ~+ [; P/ F' |, _ F
0x01 成因5 y4 Q* n( U* _5 S- s/ a
$ ]* {+ {- z! O" C$ j& o9 G
对于URL跳转的实现一般会有几种实现方式:
_( g2 h, `# e2 z8 T+ z. u" \! s0 i; C8 u+ `, v! u9 a
META标签内跳转
. H0 m5 q! \5 ~$ i" ujavascript跳转 7 u. k8 i1 h2 {9 I. W
header头跳转 * t6 U( D# T0 M$ ~ ~, N
4 m4 z" o( m0 E2 M/ H1 a+ Q
@2 f$ e8 C/ f( m4 a通过以GET或者POST的方式接收将要跳转的URL,然后通过上面的几种方式的其中一种来跳转到目标URL。一方面,由于用户的输入会进入 Meta,javascript,http头所以都可能发生相应上下文的漏洞,如xss等等,但是同时,即使只是对于URL跳转本身功能方面就存在一个缺 陷,因为会将用户浏览器从可信的站点导向到不可信的站点,同时如果跳转的时候带有敏感数据一样可能将敏感数据泄漏给不可信的第三方。7 W% h$ A- R3 {; s6 z
1 J+ q8 w2 J; a; L( W' } n3 A譬如一个典型的登录跳转如下:
( d/ }$ c8 a6 K/ S! n
5 o8 g3 j7 }% E<?php $url=$_GET['jumpto']; header("Location: $url"); ?>如果jumpto没有任何限制,所以恶意用户可以提交- w+ ~( s4 O8 _7 |
% a9 J& R2 w3 Y9 c; }" ?
http://www.xxx.net/login.php?jumpto=http://www.evil.com来生成自己的恶意链接,安全意识较低的用户很可能会以为该链接展现的内容是www.wooyun.org从而可能产生欺诈行为,同时由于QQ,淘宝 旺旺等在线IM都是基于URL的过滤,同时对一些站点会一白名单的方式放过,所以导致恶意URL在IM里可以传播,从而产生危害,譬如这里IM会认为 www.wooyun.org都是可信的,但是通过在IM里点击上述链接将导致用户最终访问evil.com。6 H8 a9 Y4 J6 m& ]+ {
9 D. d/ V A b% V8 N0x02 攻击方式及危害
5 k# I4 F g c7 b) X. M o' U4 Q/ q3 c; m* p% g
恶意用户完全可以借用URL跳转漏洞来欺骗安全意识低的用户,从而导致“中奖”之类的欺诈,这对于一些有在线业务的企业如淘宝等,危害较大,同时借 助URL跳转,也可以突破常见的基于“白名单方式”的一些安全限制,如传统IM里对于URL的传播会进行安全校验,但是对于大公司的域名及URL将直接允 许通过并且显示会可信的URL,而一旦该URL里包含一些跳转漏洞将可能导致安全限制被绕过。9 [& U$ e0 D- Q
( v6 I! Y* `% B$ F
如果引用一些资源的限制是依赖于“白名单方式”,同样可能被绕过导致安全风险,譬如常见的一些应用允许引入可信站点如youku.com的视频,限 制方式往往是检查URL是否是youku.com来实现,如果youku.com内含一个url跳转漏洞,将导致最终引入的资源属于不可信的第三方资源或 者恶意站点,最终导致安全问题。6 h/ L- j" B. k( C# l5 v; y
. V( @8 b" \& A. w! o& j+ n0x03 实际案例
$ d+ h' R$ s' \. V0 `! t
X, o, f- v: C+ x: E" x3 p. Ka WooYun: 百度一个URL跳转漏洞
7 T' ]3 |, V- d8 }+ o. x1 K) f, _2 T" a' ^1 u$ w7 [+ `
通过url跳转突破IM的安全校验,从而传播恶意URL4 G0 ?, ]# x: Y/ b$ h3 Z1 _5 M0 f1 k4 }
+ O4 }# O# b6 |: K [3 Y1 {( H4 O
b WooYun: 第五次遇到利用淘宝网网址跳转的网钓
0 V1 d0 T* S$ d2 f1 P5 c: }8 ]0 j0 D( e. f, g1 z
通过url跳转欺骗交易用户对URL的信任,从而实现欺诈
7 M" ?+ Q. W' K" a9 K; H
* O2 a/ R; o8 T" T3 [c http://hi.baidu.com/rayh4c/blog/ ... a2045e9822edb9.html
8 D) W. Y: M5 o! |) M
7 f1 q% {6 r1 B1 F通过URL跳转绕过应用程序对引用资源的限制,从而导致安全漏洞
! W& A7 X) z& W6 j
; W( K+ d2 @+ S, Z, z# od WooYun: 豆瓣电台认证绕过及csrf防范策略绕过漏洞
, Y1 y8 i8 X; w5 }" m9 m
! ^- W0 u, ^. y" _/ G, Y, ^0 L- b借助未验证的URL跳转,可以将应用程序内部敏感的数据传递到不安全的第三方区域
7 ?2 ^9 o) J B. s: I5 o# S3 S
: ^6 R! T$ G0 I$ [) @; y6 d0x04 修复方案
4 Z7 W2 M. i, b# d1 W' G6 q6 g
$ e) m$ o& X" D% _) T6 n理论上讲,url跳转属于CSRF的一种,我们需要对传入的URL做有效性的认证,保证该URL来自于正确的地方,限制的方式同防止csrf一样可以包括:
. z6 v8 n- B0 h. O
, Z+ z- v( q8 R6 @0 f1 referer的限制$ E* X6 l A+ P: y B
; F; A9 b3 G) ~9 R' _7 c3 P
如果确定传递URL参数进入的来源,我们可以通过该方式实现安全限制,保证该URL的有效性,避免恶意用户自己生成跳转链接5 u! Z& ]6 D( r6 Y" l+ P
: D7 ~1 X7 p' X
2 加入有效性验证Token+ n) [" @# _! o U, Q! Q
2 k7 L1 j( A, x3 [, j5 F5 l
我们保证所有生成的链接都是来自于我们可信域的,通过在生成的链接里加入用户不可控的Token对生成的链接进行校验,可以避免用户生成自己的恶意链接从而被利用,但是如果功能本身要求比较开放,可能导致有一定的限制。: ~1 R: Z( I: E9 J' Q0 Y7 ^& F/ Z
7 F- c0 A4 r, ]" x |