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

12,攻防世界simple_php

simple_php

题目来源:Cyberpeace-n3k0

题目描述:

小宁听说php是最好的语言,于是她简单学习之后写了几行php代码。

2320669e196e4ae6a1042a6e48fdf351.png

进入靶场

666c6864f465438fbc3af17a3290b495.png

这段PHP代码是一个简单的web应用示例,让我们逐步分析这段代码:


show_source(__FILE__);:这行代码会显示当前文件的源代码。这通常用于调试目的,但在生产环境中暴露源代码可能会泄露敏感信息。


include("config.php");:这行代码包含了一个名为config.php的文件


$a=@$_GET['a']; 和 $b=@$_GET['b'];:这两行代码从URL的查询字符串中获取a和b参数的值,并使用@运算符抑制错误信息的显示。


第一个if语句:if($a==0 and $a){...} 检查$a是否既等于0又在某种逻辑上被视为真(truthy)。


第二个if语句:if(is_numeric($b)){...} 检查$b是否为数字。如果是,脚本将执行exit();并终止。这意味着,为了使代码继续执行到打印$flag2的部分,$b必须是非数字的值。


第三个if语句:if($b>1234){...} 检查$b是否大于1234。如果是,将打印$flag2。由于前面的is_numeric($b)检查,这个条件只有在$b是非数字但能以某种方式被PHP解释为大于1234的值时才会为真。这通常涉及到字符串到数字的强制转换,例如,字符串"12345abc"会被转换为数字12345,因为它以数字开头。

分析结束

既然知道了一个文件名,就去试着访问一下,发现访问不了

弱类型语言:弱类型语言在进行变量比较时,通常不会严格地要求变量的类型必须一致。这种比较方式允许不同类型的变量之间进行转换和比较,从而提高了编程的灵活性和便利性。

构造的payload中a=a或a==0都可

861642bc72a34e36ba1f79ecbbdc521b.png

 

 

 

http://www.lryc.cn/news/497462.html

相关文章:

  • 解决Jupyter Notebook无法转化为Pdf的问题(基于Typora非常实用)
  • 齐护机器人ModbusRTU RS485转TTL通信模块与ESP32 Arduino通信可Mixly的图形化编程Scratch图形化编程
  • python学习笔记15 python中的类
  • PMP–一、二、三模、冲刺–分类–10.沟通管理
  • android-studio开发第一个项目,并在设备上调试
  • springboot/ssm线上教育培训办公系统Java代码web项目在线课程作业源码
  • Spring 依赖 详解
  • 千益畅行,旅游卡有些什么优势?
  • Ubuntu24 cgroupv2导致rancher(k3s)启动失败的处理
  • 学习CSS第二天
  • 2021数学分析【南昌大学】
  • 单端和差分信号的接线法
  • 力扣-图论-2【算法学习day.52】
  • MySQL如何区分幻读和不可重复读
  • 界面控件Syncfusion Essential Studio®现在已完全支持 .NET 9
  • openEuler安装lsb_release
  • 统计数字字符个数
  • 44页PDF | 信息化战略规划标准框架方法论与实施方法(限免下载)
  • 计算机网络期末复习-part1-概述
  • A1228 php+Mysql旅游供需平台的设计与实现 导游接单 旅游订单 旅游分享网站 thinkphp框架 源码 配置 文档 全套资料
  • RabbitMQ消息可靠性保证机制5--消息幂等性处理
  • Claude3.5如何使用?
  • 力扣刷题TOP101:14.BM16 删除有序链表中重复的元素-II
  • 解决github网络慢的问题
  • docker及docker exec命令学习笔记
  • linux环境宝塔服务部署安装及介绍
  • 充分统计量(Sufficient Statistic)概念与应用: 中英双语
  • 基于Matlab计算机视觉的车道线识别与前车检测系统研究
  • 模糊测试中常见的10种变异mutation策略
  • opencv-android编译遇到的相关问题处理