曲径通幽论坛

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

[PHP+MYSQL] 判断数据库版本的 ord(mid(version(),1,1))

[复制链接]

4918

主题

5880

帖子

3万

积分

GROAD

曲径通幽,安觅芳踪。

Rank: 6Rank: 6

积分
34395
跳转到指定楼层
楼主
发表于 2013-9-7 21:17:41 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
在对 MYSQL 进行注入时,一开始往往会判断 mysql 的版本,一般方法是在注入点加入 and ord(mid(version(),1,1))>51 语句,如果返回正常,那么数据库版本大于 4.0,并支持 union 查询。下面分析 ord(mid(version(),1,1)) 的含义:

首先 version() 函数,它以字串形式返回数据库的版本号,如:


得到的版本号字串是 5.1.69 ,接着考虑 mid(version(),1,1) 的结果,mid() 是个字符串处理函数,它和 SUBSTRING() 函数是同义函数,mid() 的原形为 mid(str, pos, len) ,它相当于 substring(str, pos, len) (实际上,substring() 有多种参数应用形式)。它的意思是,从字符串 str 中返回一个长度同 len 字符相同的子串,起始位置为 pos 。这样一来,mid(version(),1,1) 得到的字串为 5 。

ord() 也是个字串处理函数,其原形为 ord(str),它的作用是返回字符串的第一个字符的数值 。如果字符串 str 由多个字符组成,那么取第一个字符,若该字符是个多字节字符(比如 UTF8,3个字节表示一个汉字)那么它会取这 3 个字节中的第一个字节作为输出结果;如果是单字节,那么直接输出该字符的 ASCII 码。因此上面的字符 '5' ,输出的就是其对应的 ASCII 码值 53。所以,大于 51 (对应字符为 '3'),那么说明该 mysql 数据库版本为 4.x 及以上。这说明了我们可以利用 union 这样的联合查询以及一些高级特性。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

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

本版积分规则

小黑屋|手机版|Archiver|曲径通幽 ( 琼ICP备11001422号-1|公安备案:46900502000207 )

GMT+8, 2025-5-3 12:38 , Processed in 0.120226 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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