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

攻防世界WEB(新手模式)18-easyphp

打开题目,直接开始代码审计

  • 条件1$a 必须存在,且 intval($a) 必须大于 6000000,同时 strlen($a) 必须小于等于 3。

    • 这意味着 $a 必须是一个字符串,且它的整数值大于 6000000,但字符串长度不能超过 3。这看起来是不可能的,因为一个长度不超过3的字符串,其整数值不可能大于6000000。

    • 这里可能存在一个漏洞:intval() 函数在处理字符串时,会从字符串的开头解析数字,直到遇到非数字字符为止。因此,我们可以利用科学计数法来绕过这个限制。例如,$a = "1e9",它的整数值是1,但 intval("1e9") 会返回1,而 strlen("1e9") 是3。

  • 条件2$b 必须存在,且 md5($b) 的最后6个字符必须是 8b184b

    • 我们需要找到一个字符串 $b,使得 md5($b) 的最后6个字符是 8b184b。这可以通过暴力破解或使用彩虹表来实现。

 

  • 条件1$c 必须是一个数组,且 $c["m"] 必须存在,不能是数字,且必须大于2022。

    • 这里的关键是 !is_numeric(@$c["m"]) 和 $c["m"] > 2022。我们需要一个非数字的值,但它仍然可以比较大小。PHP中的字符串比较是按字典序进行的,因此我们可以使用一个字符串,比如 "2023a",它大于 2022,但不是数字。

  • 条件2$c["n"] 必须是一个数组,且长度为2,且第一个元素也是一个数组。

    • 我们需要构造一个数组 $c["n"],其中包含两个元素,第一个元素是一个数组。

  • 条件3array_search("DGGJ", $c["n"]) 必须返回一个非 false 的值,但在遍历 $c["n"] 时,不能有任何元素等于 "DGGJ"

    • 这里的关键是 array_search 返回的是键名,而不是值。因此,我们可以构造一个数组,其中 "DGGJ" 是键名而不是值。例如:

 

  1. 设置 $a 为 "1e9",使得 intval($a) 大于6000000且 strlen($a) 小于等于3。

  2. 找到一个字符串 $b,使得 md5($b) 的最后6个字符是 8b184b

  3. 设置 $c 为一个JSON字符串,解码后满足以下条件:

    • $c["m"] 是一个非数字的字符串,且大于2022。

    • $c["n"] 是一个包含两个元素的数组,第一个元素是一个数组,且 "DGGJ" 是第一个元素的键名。

最终的GET请求可能类似于:

?a=1e9&b=53724&c={"m":"2023C","n":[[],0]}

得到flag

相关文章:

  • Vue打包(webpack)缓存
  • DCDC60V电源ic,支持48V降压5V、36V降压5V,SL3037B替换TPS54362
  • final 关键字在不同上下文中的用法及其名称
  • Spring Data JPA 中的分页实现:从 BasePage 到 Pageable
  • Dify使用和入门
  • 浮点数在内存中的存储
  • 使用Spring Data Redis操作Redis
  • 学习threejs,使用ShaderMaterial自定义着色器材质
  • wps角标快速生成
  • 2025全开源Java多语言跨境电商外贸商城/Tk/FB内嵌商城I商家入驻I批量下单I完美运行
  • Vue前端项目构建教程
  • 自动化测试无法启动(java.net.SocketException)
  • Linux常用命令大全
  • ONLYOFFICE + Ollama,本地AI模型的高效集成方案
  • (0)阿里云大模型ACP-考试回忆
  • 中科大 计算机网络 第一章 1.3 网络核心笔记
  • 【内存仅用50%】如何跑满
  • spring注解开发(Spring整合MyBatis——Mapper代理开发模式、(Spring、MyBatis、Jdbc)配置类)(6)
  • 《Canvas修仙传·第二重天灵动境》 ——让图形学会七十二变的时空法则
  • c#实现485协议
  • 政府网站建设及信息公开/2022年大事热点新闻
  • 网站栏目做ip地址访问限制/优秀的软文广告欣赏
  • 丰都专业网站建设公司/手机优化大师
  • 后台管理网站开发/中国婚恋网站排名
  • 崇明建设镇乡镇府网站/哈尔滨seo网站管理
  • 有什么网站可以做六级题目嘛/优化推广公司哪家好