关于php支持的协议与封装协议总结(推荐)


Posted in PHP onNovember 17, 2017

前言

当今web程序的开发技术真是百家争鸣,ASP.NET, PHP, JSP,Perl, AJAX 等等。 无论Web技术在未来如何发展,理解Web程序之间通信的基本协议相当重要, 因为它让我们理解了Web应用程序的内部工作。

PHP 带有很多内置 URL 风格的封装协议,可用于类似 fopen()、 copy()、 file_exists() 和 filesize() 的文件系统函数。 除了这些封装协议,还能通过 stream_wrapper_register() 来注册自定义的封装协议。

Note: 用于描述一个封装协议的 URL 语法仅支持 scheme://... 的语法。 scheme:/ 和 scheme: 语法是不支持的。

php协议类型

  • file:// — 访问本地文件系统
  • http:// — 访问 HTTP(s) 网址
  • ftp:// — 访问 FTP(s) URLs
  • php:// — 访问各个输入/输出流(I/O streams)
  • zlib:// — 压缩流
  • data:// — 数据(RFC 2397)
  • glob:// — 查找匹配的文件路径模式
  • phar:// — PHP 归档
  • ssh2:// — Secure Shell 2
  • rar:// — RAR
  • ogg:// — 音频流
  • expect:// — 处理交互式的流

PHP.ini

  • allow_url_fopen :on 默认开启 该选项为on便是激活了 URL 形式的 fopen 封装协议使得可以访问 URL 对象文件等。
  • allow_url_include:off 默认关闭,该选项为on便是允许 包含URL 对象文件等

file://协议

file:// — 访问本地文件系统,不受allow_url_fopen与allow_url_include的影响

关于php支持的协议与封装协议总结(推荐)

使用方法

file:// [文件的绝对路径和文件名]

http://127.0.0.1/code/1.php?file=file:///E:\phpStudy\WWW\code\phpinfo.php

关于php支持的协议与封装协议总结(推荐)

php://协议

php:// — 访问各个输入/输出流(I/O streams)

不需要开启allow_url_fopen,仅php://input、 php://stdin、 php://memory 和 php://temp 需要开启allow_url_include。

php://stdin, php://stdout 和 php://stderr

php://stdin、php://stdout 和 php://stderr 允许直接访问 PHP 进程相应的输入或者输出流。

php://stdin 是只读的, php://stdout 和 php://stderr 是只写的。

php://stdin

<?php
 while($line = fopen('php://stdin','r'))
 {//open our file pointer to read from stdin
 echo $line."\n";
 echo fgets($line);//读取
 }
?>

关于php支持的协议与封装协议总结(推荐)

php://stdout

<?php
 $fd = fopen('php://stdout', 'w');
 if ($fd) {
 echo $fd."\n";
 fwrite($fd, "test");
 fwrite($fd, "\n");
 fclose($fd);
 }
?>

关于php支持的协议与封装协议总结(推荐)

php://stderr

<?php
 $stderr = fopen( 'php://stderr', 'w' );
 echo $stderr."\n";
 fwrite($stderr, "uknow" );
 fclose($stderr);
?>

关于php支持的协议与封装协议总结(推荐)

php://filter

最常使用的一个伪协议,一般可以利用进行任意文件读取。

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

参数

名称 描述
resource= 这个参数是必须的。它指定了你要筛选过滤的数据流。
read= 该参数可选。可以设定一个或多个过滤器名称,以管道符分隔。
write= 该参数可选。可以设定一个或多个过滤器名称,以管道符分隔。
任何没有以 read= 或 write= 作前缀 的筛选器列表会视情况应用于读或写链。
<?php
	include($_GET['file'])
?>
http://127.0.0.1/code/1.php?file=php://filter/read=convert.base64-encode/resource=./phpinfo.php

关于php支持的协议与封装协议总结(推荐)

关于php支持的协议与封装协议总结(推荐)

php://input

php://input 可以访问请求的原始数据的只读流, 将post请求中的数据作为PHP代码执行。

  • allow_url_fopen :off/on
  • allow_url_include:on

关于php支持的协议与封装协议总结(推荐)

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

zip://, bzip2://, zlib://协议在双off的情况下也可以正常使用;

zip://, bzip2://, zlib:// 均属于压缩流,可以访问压缩文件中的子文件,更重要的是不需要指定后缀名。

  • allow_url_fopen :off/on
  • allow_url_include:off/on

使用方法

zip://archive.zip#dir/file.txt

zip:// [压缩文件绝对路径]#[压缩文件内的子文件名]

测试

先将要执行的PHP代码写好文件名为phpcode.txt,将phpcode.txt进行zip压缩,压缩文件名为file.zip,如果可以上传zip文件便直接上传,若不能便将file.zip重命名为file.jpg后在上传,其他几种压缩格式也可以这样操作。

由于#在get请求中会将后面的参数忽略所以使用get请求时候应进行url编码为%23,且此处经过测试相对路径是不可行,所以只能用绝对路径。

http://127.0.0.1/code/1.php?file=zip://E:\phpStudy\WWW\code/1.zip%231.txt

关于php支持的协议与封装协议总结(推荐)

data://协议

data://协议必须双在on才能正常使用;

  • allow_url_fopen :on
  • allow_url_include:on
http://127.0.0.1/code/1.php?file=data://text/plain,<?php phpinfo()?>
http://127.0.0.1/code/1.php?file=data://text/plain;base64,PD9waHAgcGhwaW5mbygpPz4=

关于php支持的协议与封装协议总结(推荐)

关于php支持的协议与封装协议总结(推荐)

glob://协议

glob:// — 查找匹配的文件路径模式

<?php
$it = new DirectoryIterator($_GET['file']);
foreach($it as $f) {
 printf("%s", $f->getFilename());
	echo'</br>'; 
}
?>

关于php支持的协议与封装协议总结(推荐)

expect://协议

expect:// — 处理交互式的流

该封装协议默认未开启

为了使用 expect:// 封装器,你必须安装 » PECL 上的 » Expect 扩展。

用法

expect://command

附:HTTP协议是无状态的和Connection: keep-alive的区别

无状态是指协议对于事务处理没有记忆能力,服务器不知道客户端是什么状态。从另一方面讲,打开一个服务器上的网页和你之前打开这个服务器上的网页之间没有任何联系

HTTP是一个无状态的面向连接的协议,无状态不代表HTTP不能保持TCP连接,更不能代表HTTP使用的是UDP协议(无连接)

从HTTP/1.1起,默认都开启了Keep-Alive,保持连接特性,简单地说,当一个网页打开完成后,客户端和服务器之间用于传输HTTP数据的TCP连接不会关闭,如果客户端再次访问这个服务器上的网页,会继续使用这一条已经建立的连接

Keep-Alive不会永久保持连接,它有一个保持时间,可以在不同的服务器软件(如Apache)中设定这个时间

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Reference

  • PHP
  • php伪协议实现命令执行的七种姿势
PHP 相关文章推荐
php UTF8 文件的签名问题
Oct 30 PHP
PHP生成UTF8文件的方法
May 15 PHP
php flv视频时间获取函数
Jun 29 PHP
PHP的一个基础知识 表单提交
Jul 04 PHP
PHP mail()函数使用及配置方法
Jan 14 PHP
php阻止页面后退的方法分享
Feb 17 PHP
php显示时间常用方法小结
Jun 05 PHP
非常全面的php日期时间运算汇总
Nov 04 PHP
php基于mcrypt_encrypt和mcrypt_decrypt实现字符串加密解密的方法
Jul 12 PHP
PHP正则表达式匹配替换与分割功能实例浅析
Feb 04 PHP
Swoole4.4协程抢占式调度器详解
May 23 PHP
详解no input file specified 三种解决方法
Nov 29 PHP
PHP实现绘制二叉树图形显示功能详解【包括二叉搜索树、平衡树及红黑树】
Nov 16 #PHP
PHP实现链式操作的三种方法详解
Nov 16 #PHP
thinkphp5.0自定义验证规则使用方法
Nov 16 #PHP
PHP实现验证码校验功能
Nov 16 #PHP
学习thinkphp5.0验证类使用方法
Nov 16 #PHP
thinkPHP中钩子的使用方法实例分析
Nov 16 #PHP
php表单处理操作
Nov 16 #PHP
You might like
隐性调用php程序的方法
2009/03/09 PHP
PHP安全配置详细说明
2011/09/26 PHP
使用php将某个目录下面的所有文件罗列出来的方法详解
2013/06/21 PHP
php中用socket模拟http中post或者get提交数据的示例代码
2013/08/08 PHP
php下载excel无法打开的解决方法
2013/12/24 PHP
php动态读取数据清除最右边距的方法
2017/04/12 PHP
JQuery textlimit 显示用户输入的字符数 限制用户输入的字符数
2009/05/14 Javascript
JS 对象介绍
2010/01/20 Javascript
理解Javascript_12_执行模型浅析
2010/10/18 Javascript
JS对select控件option选项的增删改查示例代码
2013/10/21 Javascript
javascript实现复选框选中属性
2015/03/25 Javascript
JQuery radio(单选按钮)操作方法汇总
2015/04/15 Javascript
基于jQuery实现页面搜索功能
2020/03/26 Javascript
JS求解三元一次方程组值的方法
2017/01/03 Javascript
原生JS实现图片懒加载(lazyload)实例
2017/06/13 Javascript
JavaScript实现三级联动菜单效果
2017/08/16 Javascript
vue-router 源码实现前端路由的两种方式
2018/07/02 Javascript
浅谈vue单页面中有多个echarts图表时的公用代码写法
2020/07/19 Javascript
Vue时间轴 vue-light-timeline的用法说明
2020/10/29 Javascript
原生js实现无缝轮播图效果
2021/01/28 Javascript
[04:00]DOTA2解说界神雕侠侣 CJ第四天谷子现场过生日
2013/07/30 DOTA
[02:18]《我与DAC》之工作人员:为了热爱DOTA2的玩家们
2018/03/28 DOTA
[01:02:32]DOTA2-DPC中国联赛 正赛 iG vs PSG.LGD BO3 第二场 2月26日
2021/03/11 DOTA
python实现TF-IDF算法解析
2018/01/02 Python
Python Pandas找到缺失值的位置方法
2018/04/12 Python
对Python中的条件判断、循环以及循环的终止方法详解
2019/02/08 Python
pytorch 修改预训练model实例
2020/01/18 Python
Python对Tornado请求与响应的数据处理
2020/02/12 Python
Python 保存加载mat格式文件的示例代码
2020/08/04 Python
python3字符串输出常见面试题总结
2020/12/01 Python
专注澳大利亚特产和新西兰特产的澳洲中文网:0061澳洲制造
2019/03/24 全球购物
String和StringBuffer的区别
2015/08/13 面试题
应届生财务管理求职信
2013/11/06 职场文书
电力培训心得体会
2014/09/02 职场文书
写给老师的保证书
2015/05/09 职场文书
《围炉夜话》110句人生箴言,精辟有内涵,引人深思
2019/10/23 职场文书