news 2026/2/5 4:45:53

【网络安全渗透测试】零基础入门PHP伪协议精讲(文件包含漏洞)零基础入门到精通教程

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【网络安全渗透测试】零基础入门PHP伪协议精讲(文件包含漏洞)零基础入门到精通教程

今天给大家分享一下网络安全渗透测试入门阶段文件包含渗透与防御基础教程,本文主要讲解php伪协议。

喜欢的朋友们,记得给我点赞支持和收藏一下,关注我,学习黑客技术。

1、什么是PHP伪协议PHP伪协议PHP伪协议

PHP伪协议事实上就是支持的协议与封装协议,简单来说就是php定义的一种特殊访问资源的方法,在web渗透漏洞利用中常用于配合文件配合进行web攻击,查询到网站中隐藏的机密文件,造成敏感信息泄露等影响。

2、什么时候用PHP伪协议

文件包含漏洞, 对了,这次改个思路,不用漏洞作为本文章的切入点,而是用开发角度作为切入点。

我们在PHP开发中可能遇到的文件包含函数:

1、include
2、require
3、include_once
4、require_once
5、highlight_file
6、show_source
7、flie
8、readfile
9、file_get_contents
10、file_put_contents
11、fopen (比较常见)

这些函数有潜在的风险,若前后端未对用户输入做安全校验,且用户输入恶意入参,可能导致以上函数与PHP伪协议结合,造成安全风险, 具体PHP开发涉及文件包含函数的用法就不一一列举了,可参考如下文章(大神写的很好,本哥就不自己解释了):

http://t.csdn.cn/7kbXG

3.常见伪协议即其用法

1)php://input

php://input 是个可以访问请求的原始数据的只读流,获取POST请求数据的协议
当enctype=”multipart/form-data” 的时候 php://input 是无效的。

要使php://input 成功使用还需要配置php.ini 中的 allow_url_include设置为On

案例代码
php <?php @include($_GET["file"]); ?>
构造执行的代码,输出结果

2)php://filter

php://filter 是一种元封装器, 设计用于数据流打开时的筛选过滤应用。这对于一体式(all-in-one)的文件函数非常有用,类似 readfile()、 file() 和 file_get_contents(), 在数据流内容读取之前没有机会应用其他过滤器。

在利用上很多都是与包含函数结合使用,读入或者输出获取文件源码然后编码让其不执行从而输出。

php://filter 的使用:如 php://filter/read=convert.base64-encode/resource=index.php php://filter/resource=index.php php://filter 伪协议组成: read=<读链的筛选列表> resource=<要过滤的数据流> write=<写链的筛选列表> php://filter/read=处理方式(base64编码,rot13等等)/resource=要读取的文件 read 对应要设置的过滤器: 常见的过滤器分字符串过滤器、转换过滤器、压缩过滤器、加密过滤器 其中convert.base64-encode ,convert.base64-decode都属于 转换过滤器

例子

<?php $a=($_GET["file"]); echo(file_get_contents($a));//获取文件内容 ?>

访问输出base64编码后的内容

!!!非常重要!!!

转换过滤器,伪协议中的字符被过滤时,convert.*过滤器支持convert.iconv.* 格式,

使用方法:convert.iconv…或convert.iconv./

例如:

convert.iconv.UCS-4*.UCS-4BE ---> 将指定的文件从UCS-4*转换为UCS-4BE 输出

构造url,然后使用bp进行爆破:?filename=php://filter/convert.iconv.a.b/resource=check.php

3)zip:// , bzip2://, zlib:// 协议

zip:// 等属于压缩流的协议,通过直接压缩普通文件为zip文件(绕过文件上传检查用),再通过zip:// 协议读取,可以直接执行php代码。压缩后的zip文件可以随意修改后缀也不影响zip://协议读取。(注意是如phpinfo.txt直接压缩为zip,而不是文件夹压缩zip)

例:

<?php $a=($_GET["file"]); include($a); ?>

压缩及协议访问格式:

压缩文件为.zip后缀 zip://绝对路径/phpinfo.zip%23phpinfo.php 压缩文件为.bz2后缀 compress.bzip2://绝对路径/phpinfo.zip/phpinfo.php 压缩文件为.gz后缀 compress.zlib://绝对路径/phpinfo.zip/phpinfo.php

zip://访问

4)data://

data://协议与php://input 有很点相似的地方。他们都可以通过请求提交的php代码数据配合文件包含函数可以达到代码执行效果,data:// 的成功执行需要php.ini设置allow_url_include 与allow_url_open都为On。

data://协议的格式是: data://数据流封装器,相应格式数据。

常见的用法为 data://,<?php%20phpinfo();?> data://text/plain,<?php%20phpinfo();?> data://text/plain;base64,PD9waHAgcGhwaW5mbygpOz8%2b

例子:

<?php $a=($_GET["file"]); include($a); ?>

构造data:// 访问

5)phar://

phar://伪协议可以对zip格式压缩包进行访问解析。

格式为:phar://绝对路径\phpinfo.zip\phpinfo.php

网络安全学习资源分享:

给大家分享一份全套的网络安全学习资料,给那些想学习 网络安全的小伙伴们一点帮助!

对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。

因篇幅有限,仅展示部分资料,朋友们如果有需要全套《网络安全入门+进阶学习资源包》,请看下方扫描即可前往获取


版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/29 14:06:11

24、高级Kubernetes网络:深入解析与实践

高级Kubernetes网络:深入解析与实践 1. 容器运行时与CNI插件 在容器网络领域,容器网络接口(CNI)定义了用于网络应用容器的插件规范。不过,该插件必须接入能提供某些服务的容器运行时。在CNI的语境中,应用容器是可进行网络寻址的实体,即拥有自己的IP地址。例如,在Dock…

作者头像 李华
网站建设 2026/1/30 17:21:16

WeKnora v2.0全面升级:7大创新功能重塑智能文档理解新体验

在信息爆炸的时代&#xff0c;如何从海量文档中快速获取精准答案成为每个企业和个人面临的共同挑战。WeKnora v2.0作为基于LLM的深度文档理解与智能检索框架&#xff0c;以全新的技术架构和功能特性&#xff0c;为智能文档处理带来了革命性突破。 【免费下载链接】WeKnora LLM-…

作者头像 李华
网站建设 2026/2/4 10:33:54

3个关键步骤完美部署pgvector Docker镜像

3个关键步骤完美部署pgvector Docker镜像 【免费下载链接】pgvector Open-source vector similarity search for Postgres 项目地址: https://gitcode.com/GitHub_Trending/pg/pgvector pgvector是PostgreSQL的开源向量相似度搜索扩展&#xff0c;能够直接在数据库中高效…

作者头像 李华
网站建设 2026/2/2 4:27:20

流量都去哪儿了?拯救APP月活,用FinClip轻松引入第三方生态

数据显示&#xff0c;超过80%的App在用户下载后30天内被遗忘。而企业又苦恼于App用户留存难&#xff0c;获客成本越来越高。 企业App可能一个月只被用户打开一两次&#xff0c;而用户每天在微信、支付宝里要用几十个服务。 为什么&#xff1f; 因为App提供的服务太单一&#xf…

作者头像 李华
网站建设 2026/1/29 11:53:41

终极指南:如何用Avalonia XPF实现WPF应用的革命性跨平台迁移

还在为WPF应用只能在Windows上运行而错失macOS和Linux市场机会吗&#xff1f;还在为每个平台重写UI代码而耗费大量开发资源吗&#xff1f;Avalonia XPF为您提供了完美的跨平台WPF解决方案&#xff0c;让现有的WPF应用程序能够在三大主流操作系统上运行&#xff0c;几乎无需代码…

作者头像 李华