PHP伪协议基本原理介绍

 更新时间:2022年11月11日 11:22:08   作者:隐形卟  
这篇文章主要介绍了PHP伪协议,php中有很多封装协议,最常见的如file协议,php协议,data协议,zip和phar协议等等

前言

引用一张比较清晰易懂的图

php伪协议是php自己支持的一种协议与封装协议,简单来说就是php定义的一种特殊访问资源的方法。

常见的php伪协议

php://input

php://input 是个可以访问请求的原始数据的只读流,获取POST请求数据的协议

当enctype=”multipart/form-data” 的时候 php://input 是无效的。

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

案例代码

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

构造执行的代码,输出结果

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编码后的内容

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://访问

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:// 访问

phar://

phar://伪协议在前面phar反序列化的时候学习过,phar也可以对zip格式压缩包进行访问解析。

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

到此这篇关于PHP伪协议基本原理介绍的文章就介绍到这了,更多相关PHP伪协议内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:

相关文章

  • php中运用http调用的GET和POST方法示例

    php中运用http调用的GET和POST方法示例

    调用的GET和POST方法,使用到的函数是curl_init, curl_setopt, curl_exec,curl_close,默认是GET方法
    2014-09-09
  • php开发时容易忘记的一些技术细节

    php开发时容易忘记的一些技术细节

    本文给大家分享的是在使用PHP做开发的时候,比较容易忽视的2个小细节,分别是empty和in_array,有需要的小伙伴可以来参考下。
    2016-02-02
  • PHP 中执行排序与 MySQL 中排序

    PHP 中执行排序与 MySQL 中排序

    这篇文章是dragon 朋友来邮探讨后他做的一个总结。在 DB 中排序还是在 应用程序中排序是个很有趣的话题,dragon 第一份邮件中其实已经总结的很好了,我添加了一点建议而已。
    2009-04-04
  • Session服务器配置指南与使用经验的深入解析

    Session服务器配置指南与使用经验的深入解析

    本篇文章是对Session服务器配置指南与使用经验进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • 关于js与php互相传值的介绍

    关于js与php互相传值的介绍

    本篇文章是对js与php互相传值的问题进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • PHP延迟静态绑定的深入讲解

    PHP延迟静态绑定的深入讲解

    这篇文章主要给大家介绍了关于PHP延迟静态绑定的相关资料,这是最近工作中遇到的一个功能,通过查找相关的资料整理了这篇文章,分享出来供大家参考学习,需要的朋友们下面随着小编来一起学习学习吧。
    2018-04-04
  • php封装的pdo数据库操作工具类与用法示例

    php封装的pdo数据库操作工具类与用法示例

    这篇文章主要介绍了php封装的pdo数据库操作工具类与用法,结合实例形式分析了php封装的pdo数据库连接、增删改查、错误处理、关闭连接等操作及相关使用技巧,需要的朋友可以参考下
    2019-05-05
  • Windows2003下php5.4安装配置教程(Apache2.4)

    Windows2003下php5.4安装配置教程(Apache2.4)

    这篇文章主要为大家详细介绍了在Windows2003下Apache2.4与php5.4配置教程,感兴趣的小伙伴们可以参考一下
    2016-06-06
  • PHP设计模式之单例模式定义与用法分析

    PHP设计模式之单例模式定义与用法分析

    这篇文章主要介绍了PHP设计模式之单例模式定义与用法,结合实例形式较为详细的分析了单例模式的概念、特点、优缺点,并结合php实例形式分析了单例模式的定义与使用方法,需要的朋友可以参考下
    2019-03-03
  • php 使用ActiveMQ发送消息,与处理消息操作示例

    php 使用ActiveMQ发送消息,与处理消息操作示例

    这篇文章主要介绍了php 使用ActiveMQ发送消息,与处理消息操作,结合实例形式分析了php使用ActiveMQ实现消息的发送与接收处理相关操作技巧,需要的朋友可以参考下
    2020-02-02

最新评论