Web Security Academy 第二关:SQL 注入登录绕过

前言

本篇为 PortSwigger Web Security Academy 通关系列 WP,手把手带你完成 SQL 注入登录绕过 实验。全程图文对照、零基础可复现,适合 Web 安全入门学习。

一、实验信息

实验名称:Lab: SQL injection vulnerability allowing login bypass
实验难度:入门级
实验目标:利用 SQL 注入漏洞,无需密码直接登录管理员账户
测试工具:浏览器、Burp Suite

二、进入实验页面

打开实验链接后,进入商品展示首页。页面包含商品列表、Home、My account 等导航栏,实验状态显示 Not solved。

三、寻找并验证 SQL 注入点

首先访问商品详情页:

/product?productId=3

通过 Burp Suite 抓包查看请求,正常响应只是普通页面,看不出明显疑点。

为了判断是否存在注入,我们在参数后添加单引号测试:

/product?productId=3' 页面返回:invalid product ID

继续尝试 'or 1=1 -- 测试,页面依旧返回 invalid product ID,确认此处不存在注入点。

四、寻找登录入口

返回主页面,点击 My account 进入个人中心,发现是登录界面。

五、尝试弱口令登录(失败)

输入: 用户名:admin 密码:123456

页面提示:Invalid username or password.

六、测试登录框注入点

在用户名后加一个单引号测试:admin' ,密码随意填写。提交后页面直接返回:Internal Server Error

不是常规的用户名密码错误,说明登录框存在 SQL 注入!用 Burp 抓包确认,响应为 500 服务器错误。

七、构造 Payload 实现登录绕过

使用经典 SQL 注入登录绕过 Payload:admin' or 1=1-- ,密码任意填写。

点击登录后,页面直接提示:Congratulations, you solved the lab!实验状态变为 Solved,成功绕过登录!

八、验证管理员权限

登录后跳转到管理员页面:/my-account?id=administrator

页面显示:Your username is: administrator

九、成功请求包分析

Burp 抓到的成功登录请求如下:username=admin'+or+1%3D1+--&password=123456

服务器返回 302 重定向,跳转到管理员后台。

十、Payload 原理解析

admin' or 1=1--

admin':闭合后台 SQL 中的单引号

or 1=1:构造永真条件,登录判断永远成立

--:注释掉后面多余的 SQL 代码,避免语法错误

后台执行逻辑:

sql

SELECT * FROM users WHERE username='admin' or 1=1--' AND password='xxx'

十一、知识点总结

注入点判断:单引号触发 500 错误,说明存在注入

登录绕过核心:构造永真条件 + 注释后续语句

万能 Payload:admin' or 1=1--

防护建议:

使用预编译 SQL(Prepared Statement)

对用户输入严格过滤

数据库权限最小化

避免直接拼接 SQL 语句

结语

本篇实验是 SQL 注入最基础的登录绕过,非常适合新手入门理解注入原理。后续会继续更新 Web Security Academy 全系列通关 WP,欢迎关注~

相关推荐
Nturmoils6 小时前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波10 小时前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
倔强的石头_1 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
zzzzzz3102 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
倔强的石头_4 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
云技纵横4 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
冬奇Lab5 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence5 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神5 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据6 天前
数据服务化时代:企业数据能力输出的核心路径
数据库