Heim > Backend-Entwicklung > PHP-Tutorial > Detaillierte Erklärung des PHP-Streams-Streams

Detaillierte Erklärung des PHP-Streams-Streams

*文
Freigeben: 2023-03-18 14:44:02
Original
2338 Leute haben es durchsucht

In diesem Artikel wird hauptsächlich die detaillierte Einführung und Verwendung von PHP Streams (Stream) vorgestellt. PHP Streams ist eine integrierte Kernoperation und wird von normalen Entwicklern möglicherweise selten verwendet. Es wird zur Vereinheitlichung von Datei-, Netzwerk-, Datenkomprimierungs- und anderen dateiähnlichen Vorgängen verwendet und bietet eine Reihe gemeinsamer Funktionsschnittstellen für diese dateiähnlichen Vorgänge. Ich hoffe, es hilft allen.

PHP Streams ist eine integrierte Kernoperation, die von normalen Entwicklern möglicherweise selten verwendet wird. Sie wird zur Vereinheitlichung von Datei-, Netzwerk-, Datenkomprimierungs- und anderen dateiähnlichen Vorgängen verwendet und bietet eine Reihe allgemeiner Funktionen diese dateiähnlichen Operationen.

Ein Stream ist ein Ressourcenobjekt mit Streaming-Verhalten. Jedes Stream-Objekt verfügt über eine Wrapper-Klasse. Der Stream kann über :// referenziert werden. Unter ihnen ist der Name der Verpackungsklasse, und der Inhalt in wird durch die Syntax der verschiedenen Verpackungsklassen angegeben.
Werfen wir einen Blick auf die integrierten Verpackungsklassen, die PHP standardmäßig hat:


print_r(stream_get_wrappers());
/*
Array
(
  [0] => php
  [1] => file
  [2] => glob
  [3] => data
  [4] => http
  [5] => ftp
  [6] => zip
  [7] => compress.zlib
  [8] => https
  [9] => ftps
  [10] => phar
)
*/
Nach dem Login kopieren


Sehen Sie sich die an PHP-Handbuch zum PHP-Unterstützungsprotokoll und Wrapper-Klassen.
Sehen Sie sich den folgenden Code an, der file_get_contents() verwendet, um Daten abzurufen:


/* Read local file from /home/bar */
 $localfile = file_get_contents ( "/home/bar/foo.txt" );
 
 /* Identical to above, explicitly naming FILE scheme */
 $localfile = file_get_contents ( "file:///home/bar/foo.txt" );
 
 /* Read remote file from www.example.com using HTTP */
 $httpfile  = file_get_contents ( "http://www.example.com/foo.txt" );
 
 /* Read remote file from www.example.com using HTTPS */
 $httpsfile = file_get_contents ( "https://www.example.com/foo.txt" );
 
 /* Read remote file from ftp.example.com using FTP */
 $ftpfile  = file_get_contents ( "ftp://user:pass@ftp.example.com/foo.txt" );
 
 /* Read remote file from ftp.example.com using FTPS */
 $ftpsfile  = file_get_contents ( "ftps://user:pass@ftp.example.com/foo.txt" );
Nach dem Login kopieren


In fact readfile('/ path/ to/somefile.txt') oder readfile('file:///path/to/somefile.txt') sind diese beiden Methoden gleichwertig. Weil die Standardverpackungsklasse von PHP file:// ist.

Im Handbuch heißt es eindeutig, dass Sie Ihren eigenen Wrapper über stream_register_wrapper() registrieren können. Sie können sich die Beispiele im Handbuch ansehen.
OK, hier ist eine kurze Einführung in PHP://, eine Wrapper-Klasse, die von PHP zur Verarbeitung von E/A-Streams verwendet wird (klicken Sie hier, um ein Beispiel zu sehen). Auf leistungsfähigere Eingabe- und Ausgabestreams kann über PHP:// zugegriffen werden:

php://stdin: Greifen Sie auf den entsprechenden Eingabestream des PHP-Prozesses zu, der beispielsweise verwendet wird, um Tastatureingaben zu erhalten, wenn CLI Skripte ausführt.
php://stdout: Greifen Sie auf den entsprechenden Ausgabestream des PHP-Prozesses zu.
php://stderr: Greifen Sie auf die entsprechende Fehlerausgabe des PHP-Prozesses zu.
php://input: Ein schreibgeschützter Stream, der auf die angeforderten Rohdaten zugreift.
php://output: ein schreibgeschützter Datenstrom, der auf die gleiche Weise wie print und echo in den Ausgabebereich geschrieben wird.
php://fd: ermöglicht den direkten Zugriff auf den angegebenen Dateideskriptor. Beispiel: php://fd/3 bezieht sich auf Dateideskriptor 3.
php://memory: ermöglicht das Lesen und Schreiben temporärer Daten. Speichern Sie Daten im Speicher.
php://temp: Wie oben, es wird in einer temporären Datei gespeichert, nachdem der Speicher das vordefinierte Limit erreicht hat (Standard ist 2 MB).
php://filter: Filter.

PHP kann Verpackungsklassen auch durch Kontext und Filter ändern und verbessern.
(1) Was den Kontext betrifft, verwendet PHP beispielsweise stream_context_create(), um das Timeout für den Erhalt von Dateien festzulegen. Sie müssen diesen Code verwendet haben:


$opts = array(
  'http'=>array(
    'method'=>"GET",
    'timeout'=>60,
  )
);
$context = stream_context_create($opts);
$html =file_get_contents('http://www.jb51.net', false, $context);
Nach dem Login kopieren


(2) Was Filter betrifft, schauen wir uns zunächst an, welche integrierten Filter PHP hat:


print_r(stream_get_filters());
/*
Array
(
  [0] => convert.iconv.*
  [1] => mcrypt.*
  [2] => mdecrypt.*
  [3] => string.rot13
  [4] => string.toupper
  [5] => string.tolower
  [6] => string.strip_tags
  [7] => convert.*
  [8] => consumed
  [9] => dechunk
  [10] => zlib.*
)
*/
Nach dem Login kopieren



Benutzerdefinierte Filter können über stream_filter_register() und den integrierten php_user_filter wie folgt erstellt werden:


/* Define our filter class */
class strtoupper_filter extends php_user_filter {
  function filter ( $in , $out , & $consumed , $closing )
  {
    while ( $bucket = stream_bucket_make_writeable ( $in )) {
      $bucket -> data = strtoupper ( $bucket -> data );
      $consumed += $bucket -> datalen ;
      stream_bucket_append ( $out , $bucket );
    }
    return PSFS_PASS_ON ;
  }
}
 
/* Register our filter with PHP */
stream_filter_register ( "strtoupper" , "strtoupper_filter" )
or die( "Failed to register filter" );
 
$fp = fopen ( "foo-bar.txt" , "w" );
 
/* Attach the registered filter to the stream just opened */
stream_filter_append ( $fp , "strtoupper" );
 
fwrite ( $fp , "Line1\n" );
fwrite ( $fp , "Word - 2\n" );
fwrite ( $fp , "Easy As 123\n" );
 
fclose ( $fp );
 
 
readfile ( "foo-bar.txt" );
/*
结果如下:
LINE1
WORD - 2
EASY AS 123
*/
Nach dem Login kopieren


stellt die folgende Liste von Stream-Funktionen in PHP bereit:


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地址包
Nach dem Login kopieren


Verwandte Empfehlungen:

Aufteilen und Zusammenführen von PHP-Dateien (fortsetzbarer Upload)

Verwenden Sie nginx+ nginx-rtmp – Hinweise zum Aufbau eines Streaming Media-Servers mit module+ffmpeg (5)

Xiaowan Streaming Media Playback – HLS Streaming Media On-Demand-System

Das obige ist der detaillierte Inhalt vonDetaillierte Erklärung des PHP-Streams-Streams. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage