[ACTF2020 新生赛]BackupFile1

打开题目

利用disearch扫描,发现源文件index.php.bak

下载下来

打开文件

代码审计,翻译一下

翻译代码为:

<?php

include_once "flag.php"; //这一行使用 include_once 函数来包含(或插入)另一个 PHP 文件 "flag.php" 的内容。include_once 确保文件只被包含一次,即使它在多个地方被调用。这意味着 "flag.php" 文件中定义的任何变量或函数都将在当前文件中可用。

if(isset(_GET\['key'\])) //这一行检查 GET 请求中是否存在名为 'key' 的参数。_GET 是一个 PHP 超全局变量,用于收集表单数据(HTML 表单)在 URL(地址栏)中发送的变量。isset() 函数检查变量是否设置且不为 NULL。

{

key = _GET['key']; //如果 'key' 参数存在,这行代码将其值赋给 $key 变量。

if(!is_numeric($key))

{

exit("Just num!"); //这两行代码检查 $key 是否为数字。如果不是数字,is_numeric() 函

数返回 false,然后 exit("Just num!") 将终止脚本执行并输出 "Just num!"。

}

key = intval(key); //这行代码使用 intval() 函数将 key 转换为整数。如果 key 是数字

或数字字符串,intval() 将返回该数字的整数形式。

$str = "123ffwsfwefwf24r2f32ir23jrw923rskfjwtsw54w3"; //这行代码定义了一个字符串

$str,它包含数字和字符的组合。

if(key == str)

{

echo flag; //这两行代码检查 key 是否等于 str。如果相等,它将输出 flag 的值。由

str 是一个包含非数字字符的字符串,这意味着只有在 key 也是一个包含

相同字符的字符串时,这个条件才会为真。

}

}

else

{

echo "Try to find out source file!"; //如果 GET 请求中没有 'key' 参数,这个 else 块将

执行,输出 "Try to find out source file!"。

}

然后构造payload得到flag

构造payload url+/?key=123,得到flag

相关推荐
游戏开发爱好者831 分钟前
日常开发与测试的 App 测试方法、查看设备状态、实时日志、应用数据
android·ios·小程序·https·uni-app·iphone·webview
王码码203536 分钟前
Flutter for OpenHarmony 实战之基础组件:第三十一篇 Chip 系列组件 — 灵活的标签化交互
android·flutter·交互·harmonyos
黑码哥1 小时前
ViewHolder设计模式深度剖析:iOS开发者掌握Android列表性能优化的实战指南
android·ios·性能优化·跨平台开发·viewholder
亓才孓1 小时前
[JDBC]元数据
android
独行soc1 小时前
2026年渗透测试面试题总结-17(题目+回答)
android·网络·安全·web安全·渗透测试·安全狮
金融RPA机器人丨实在智能1 小时前
Android Studio开发App项目进入AI深水区:实在智能Agent引领无代码交互革命
android·人工智能·ai·android studio
科技块儿1 小时前
利用IP查询在智慧城市交通信号系统中的应用探索
android·tcp/ip·智慧城市
独行soc2 小时前
2026年渗透测试面试题总结-18(题目+回答)
android·网络·安全·web安全·渗透测试·安全狮
王码码20352 小时前
Flutter for OpenHarmony 实战之基础组件:第二十七篇 BottomSheet — 动态底部弹窗与底部栏菜单
android·flutter·harmonyos
2501_915106322 小时前
app 上架过程,安装包准备、证书与描述文件管理、安装测试、上传
android·ios·小程序·https·uni-app·iphone·webview