>백엔드 개발 >PHP 튜토리얼 >PHP의 Streams 및 래퍼 래퍼를 사용하는 방법

PHP의 Streams 및 래퍼 래퍼를 사용하는 방법

php中世界最好的语言
php中世界最好的语言원래의
2017-12-20 18:52:441600검색

오늘은 PHP 스트림과 래퍼의 개념과 사용법에 대해 말씀드리겠습니다. 모두를 위해 요약해 보겠습니다.

우리는 스트림의 개념이 php4.3에서 도입되었다는 것을 알고 있습니다. 이는 스트리밍 데이터의 추상화이며 파일 데이터, 네트워크 데이터, 압축 데이터 등과 같은 데이터 작업을 통합하는 데 사용됩니다. php 파일 시스템 함수는 공유가 가능합니다. 예를 들어 file_get_contents() 함수는 로컬 파일을 열고 URL에 액세스할 수 있습니다. 간단히 말해서 스트림은 스트리밍 데이터 동작을 나타내는 리소스 개체입니다.

선형 방식으로 읽고 쓰며 스트림 내 어디에서나 검색할 수 있습니다.

스트림은 데이터베이스 추상화 계층과 다소 유사합니다. 데이터베이스 추상화 계층에서는 어떤 종류의 데이터베이스를 사용하든 추상화 계층 위에서 데이터가 동일한 방식으로 작동합니다. 로컬 파일이든 원격 파일이든 압축 파일이든 데이터가 스트리밍되는 한 작업 방법은 동일합니다.

스트림의 개념으로 래퍼의 개념이 파생되는데, 각각의 스트림은 래퍼에 해당합니다. 스트림은 통합 작업의 관점에서 생성된 개념인 반면 래퍼는 스트림 데이터의 내용을 이해하는 것에서 시작됩니다. 즉, 이 통합된 운영 방식으로 다른 콘텐츠를 어떻게 운영하거나 구성할 수 있는지

이러한 콘텐츠는 모두 스트림으로 표시되지만 콘텐츠 규칙은 다릅니다. 예를 들어 http 프로토콜로 전송되는 데이터는 스트리밍 방식이지만 http 래퍼는 http 프로토콜이 전송하는 데이터의 의미를 이해합니다. 스트림은 물이 흐르는 파이프이지만 흘러나오는 것은 데이터이며 래퍼는 스트림 파이프의 외부 레이어에 배치됩니다. . 스트리밍 데이터의 의미를 이해하고 조작할 수 있는 인터프리터입니다.

공식 매뉴얼에는 "래퍼는 스트림에 특수 프로토콜이나 인코딩을 처리하는 방법을 알려주는 추가 코드입니다."라고 나와 있습니다.

Wrapper는 래퍼로 래핑된 후 외부 레이어에 래핑될 수도 있습니다. 이때 내부 래퍼는 외부 래퍼에 대한 흐름의 역할을 합니다.
PHP 하단에 있습니다. 구현된 C 언어 개발 문서에는 다음과 같은 설명이 있습니다.

스트림 API는 한 쌍의 서로 다른 수준으로 작동합니다. 기본 수준에서 API는 스트리밍 데이터 소스를 나타내는 php_stream 개체를 정의합니다. 약간 더 높은 수준에서 API는 정의합니다. php_stream_wrapper 객체.

URL의 콘텐츠와 메타데이터를 검색하고, 상황에 맞는 매개변수를 추가하고, 래퍼 동작을 조정하는 기능을 제공하기 위해 하위 수준 php_stream 개체를 래핑합니다.

스트림이 열린 후 각 스트림에 원하는 수의 필터를 적용할 수 있습니다. 위의 스트리밍 데이터는 필터에 의해 처리됩니다. 필터라는 단어가 약간 부정확하고 오해의 소지가 있는 것 같습니다.

문자 그대로의 의미는 일부 데이터를 제거하고 추가하고 수정할 수 있으므로 데이터 조정자라고 해야 합니다. 그러나 역사적인 이유로 필터라고도 합니다. 모두가 그것을 이해하는 한.

우리는 차이점을 설명하기 위해 다음 단어를 자주 봅니다.

리소스 및 데이터: 리소스는 일반적으로 데이터를 포함하는 비교적 거시적인 용어인 반면, 데이터는 보다 구체적인 용어로 프로그램을 개발할 때 자주 사용됩니다. 소프트웨어 계획에서 소프트웨어 설계와 프로그램 개발의 차이와 마찬가지로 동의어입니다.

컨텍스트 및 매개변수: 컨텍스트는 통신에 자주 사용되는 상대적으로 거시적인 용어입니다. 특히 통신 자체의 매개변수이며, 매개변수라는 용어는 위에서 설명한 함수

와 같은 보다 구체적인 항목에 자주 사용됩니다. , 구체적인 내용을 살펴보겠습니다.

php에서 지원하는 프로토콜 및 래퍼는 여기를 참조하세요: http://php.net/manual/zh/wrappers.php:
(저자 주: 원래 제목은 다음과 같습니다. 지원되는 프로토콜 및 패키징 프로토콜, 중국어 번역은 약간 오해의 소지가 있습니다. 정확하게 말하면 지원되는 프로토콜 및 래퍼이며 영어 페이지에서 매우 명확합니다.)
일부 프로토콜 및 래퍼는 기본적으로 지원됩니다. stream_get_wrappers( ) 함수를 사용하여 래퍼를 사용자 정의하고 stream_wrapper_register()로 등록할 수 있습니다
RFC 3986에서는 구분 기호로 다음을 사용할 수 있지만 PHP는 ://만 허용하므로 "scheme://target" 형식을 사용하세요. the url

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:// — 处理交互式的流

사용자 정의 래퍼 구현 방법:

fopen, fwrite, fread, fgets, feof, rewind, file_put_contents, file_get_contents 등과 같은 파일 시스템 함수를 사용하여 스트림을 작동할 때 데이터가 먼저 전달됩니다. 정의된 래퍼 클래스 객체와 래퍼가 다시 작업 흐름으로 이동합니다.
사용자 정의 스트림 래퍼를 구현하는 방법은 무엇입니까? PHP는 인터페이스나 클래스가 아닌 단순한 프로토타입이며 상속에 사용할 수 없는 클래스 프로토타입을 제공합니다.

streamWrapper {
/* 属性 */
public resource $context ;
/* 方法 */
__construct ( void )
__destruct ( void )
public bool dir_closedir ( void )
public bool dir_opendir ( string $path , int $options )
public string dir_readdir ( void )
public bool dir_rewinddir ( void )
public bool mkdir ( string $path , int $mode , int $options )
public bool rename ( string $path_from , string $path_to )
public bool rmdir ( string $path , int $options )
public resource stream_cast ( int $cast_as )
public void stream_close ( void )
public bool stream_eof ( void )
public bool stream_flush ( void )
public bool stream_lock ( int $operation )
public bool stream_metadata ( string $path , int $option , mixed $value )
public bool stream_open ( string $path , string $mode , int $options , string &$opened_path )
public string stream_read ( int $count )
public bool stream_seek ( int $offset , int $whence = SEEK_SET )
public bool stream_set_option ( int $option , int $arg1 , int $arg2 )
public array stream_stat ( void )
public int stream_tell ( void )
public bool stream_truncate ( int $new_size )
public int stream_write ( string $data )
public bool unlink ( string $path )
public array url_stat ( string $path , int $flags )
}

在这个原型里面定义的方法,根据自己需要去定义,并不要求全部实现,这就是为什么不定义成接口的原因,因为有些实现根本用不着某些方法,
这带来很多灵活性,比如包装器是不支持删除目录rmdir功能的,那么就不需要实现streamWrapper::rmdir
由于未实现它,如果用户在包装器上调用rmdir将有错误抛出,要自定义这个错误那么也可以实现它并在其内部抛出错误
streamWrapper也不是一个预定义类,测试class_exists("streamWrapper")就知道,它只是一个指导开发者的原型

官方手册提供了一个例子:http://php.net/manual/zh/stream.streamwrapper.example-1.php

本博客提供一个从drupal8系统中抽取修改过的包装器例子,请看drupal8源码分析关于流那一部分

流系列函数,官方手册:http://php.net/manual/zh/ref.stream.php

常用的函数如下:

stream_bucket_append函数:为队列添加数据 
stream_bucket_make_writeable函数:从操作的队列中返回一个数据对象
stream_bucket_new函数:为当前队列创建一个新的数据
stream_bucket_prepend函数:预备数据到队列 
stream_context_create函数:创建数据流上下文
stream_context_get_default函数:获取默认的数据流上下文
stream_context_get_options函数:获取数据流的设置
stream_context_set_option函数:对数据流、数据包或者上下文进行设置
stream_context_set_params函数:为数据流、数据包或者上下文设置参数
stream_copy_to_stream函数:在数据流之间进行复制操作
stream_filter_append函数:为数据流添加过滤器
stream_filter_prepend函数:为数据流预备添加过滤器
stream_filter_register函数:注册一个数据流的过滤器并作为PHP类执行
stream_filter_remove函数:从一个数据流中移除过滤器
stream_get_contents函数:读取数据流中的剩余数据到字符串
stream_get_filters函数:返回已经注册的数据流过滤器列表
stream_get_line函数:按照给定的定界符从数据流资源中获取行
stream_get_meta_data函数:从封装协议文件指针中获取报头/元数据
stream_get_transports函数:返回注册的Socket传输列表
stream_get_wrappers函数:返回注册的数据流列表
stream_register_wrapper函数:注册一个用PHP类实现的URL封装协议
stream_select函数:接收数据流数组并等待它们状态的改变
stream_set_blocking函数:将一个数据流设置为堵塞或者非堵塞状态
stream_set_timeout函数:对数据流进行超时设置
stream_set_write_buffer函数:为数据流设置缓冲区
stream_socket_accept函数:接受由函数stream_ socket_server()创建的Socket连接
stream_socket_client函数:打开网络或者UNIX主机的Socket连接
stream_socket_enable_crypto函数:为一个已经连接的Socket打开或者关闭数据加密
stream_socket_get_name函数:获取本地或者网络Socket的名称
stream_socket_pair函数:创建两个无区别的Socket数据流连接
stream_socket_recvfrom函数:从Socket获取数据,不管其连接与否
stream_socket_sendto函数:向Socket发送数据,不管其连接与否
stream_socket_server函数:创建一个网络或者UNIX Socket服务端
stream_wrapper_restore函数:恢复一个事先注销的数据包
stream_wrapper_unregister函数:注销一个URL地址包


相信看了这些案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

相关阅读:

php使用git部署环境

Git的一些使用案例

javascript数据类型和git使用代码详解

위 내용은 PHP의 Streams 및 래퍼 래퍼를 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.