php接收流數據處理 php輸入流

PHP流(Stream)的概述與使用詳解

在現代 PHP 特性中,流或許是最出色但使用率最低的。雖然 PHP 4.3 就引入了流,但是很多開發者并不知道流的存在,因為人們很少提及流,而且流的文檔也很匱乏。PHP 官方文檔對流的解釋如下:

10年的銅鼓網站建設經驗,針對設計、前端、開發、售后、文案、推廣等六對一服務,響應快,48小時及時工作處理。營銷型網站建設的優勢是能夠根據用戶設備顯示端的尺寸不同,自動調整銅鼓建站的顯示方式,使網站能夠適用不同顯示終端,在瀏覽器中調整網站的寬度,無論在任何一種瀏覽器上瀏覽網站,都能展現優雅布局與設計,從而大程度地提升瀏覽體驗。成都創新互聯公司從事“銅鼓網站設計”,“銅鼓網站推廣”以來,每個客戶項目都認真落實執行。

可能看完這段解釋后還是云里霧里,我們簡化一下,流的作用是在出發地和目的地之間傳輸數據。出發地和目的地可以是文件、命令行進程、網絡連接、ZIP 或 TAR 壓縮文件、臨時內存、標準輸入或輸出,或者是通過 PHP 流封裝協議實現的任何其他資源。

如果你讀寫過文件,就用過流;如果你從 php://stdin 讀取過數據,或者把輸入寫入 php://stdout ,也用過流。流為 PHP 的很多 IO 函數提供了底層實現,如 file_get_contents、fopn、fread 和 fwrite 等。PHP 的流函數提供了不同資源的統一接口。

我們可以把流比作管道,把水(資源數據)從一個地方引到另一個地方。在水從出發地到目的地的過程中,我們可以過濾水,可以改變水質,可以添加水,也可以排出水。

流式數據的種類各異,每種類型需要獨特的協議,以便讀寫數據,我們稱這些協議為 流封裝協議 。例如,我們可以讀寫文件系統,可以通過 HTTP、HTTPS 或 SSH 與遠程 Web 服務器通信,還可以打開并讀寫 ZIP、RAR 或 PHAR 壓縮文件。這些通信方式都包含下述相同的過程:

1.開始通信

2.讀取數據

3.寫入數據

4.結束通信

雖然過程是一樣的,但是讀寫文件系統中文件的方式與收發 HTTP 消息的方式有所不同,流封裝協議的作用是使用通用的接口封裝這種差異。

每個流都有一個協議和一個目標。指定協議和目標的方法是使用流標識符:scheme://target,其中 scheme 是流的封裝協議,target 是流的數據源。

http://流封裝協議

下面使用 HTTP 流封裝協議創建了一個與 Flicker API 通信的 PHP 流:

不要以為這是普通的網頁 URL,file_get_contents() 函數的字符串參數其實是一個流標識符。http 協議會讓 PHP 使用 HTTP 流封裝協議,在這個參數中,http 之后是流的目標。

我們通常使用 file_get_contents()、fopen()、fwrite() 和 fclose() 等函數讀寫文件系統,因為 PHP 默認使用的流封裝協議是 file://,所以我們很少認為這些函數使用的是 PHP 流。下面的示例演示了使用 file:// 流封裝協議創建一個讀寫 /etc/hosts 文件的流:

我們通常會省略掉 file:// 協議,因為這是 PHP 使用的默認值。

php://流封裝協議

編寫命令行腳本的 PHP 開發者會感激 php:// 流封裝協議,這個流封裝協議的作用是與 PHP 腳本的標準輸入、標準輸出和標準錯誤文件描述符通信。我們可以使用 PHP 提供的文件系統函數打開、讀取或寫入下面四個流:

1. php://stdin :這是個只讀 PHP 流,其中的數據來自標準輸入。PHP 腳本可以使用這個流接收命令行傳入腳本的信息;

2. php://stdout :把數據寫入當前的輸出緩沖區,這個流只能寫,無法讀或尋址;

3. php://memory :從系統內存中讀取數據,或者把數據寫入系統內存。缺點是系統內存有限,所有使用 php://temp 更安全;

4. php://temp :和 php://memory 類似,不過,沒有可用內存時,PHP 會把數據寫入這個臨時文件。

其他流封裝協議

PHP 和 PHP 擴展還提供了很多其他流封裝協議,例如,與 ZIP 和 TAR 壓縮文件、FTP 服務器、數據壓縮庫、Amazon API、Dropbox API 等通信的流封裝協議。需要注意的是,PHP 中的 fopen()、fgets()、fputs()、feof() 以及 fclose() 等函數不僅可以用來處理文件系統中的文件,還可以在所有支持這些函數的流封裝協議中使用。

自定義流封裝協議

我們還可以自己編寫 PHP 流封裝協議。PHP 提供了一個示例 StreamWrapper 類,演示如何編寫自定義的流封裝協議,支持部分或全部 PHP 文件系統函數。關于如何編寫,具體請參考以下文檔:

有些 PHP 流能夠接受一系列可選的參數,這些參數叫流上下文,用于定制流的行為。不同的流封裝協議使用的流上下文有所不同,流上下文使用 stream_context_create() 函數創建,這個函數返回的上下文對象可以傳入大多數文件系統函數。

例如,你知道可以使用 file_get_contents() 發送 HTTP POST 請求嗎?使用一個流上下文對象即可實現:

流過濾器

目前為止我們討論了如何打開流,讀取流中的數據,以及把數據寫入流。不過,PHP 流真正強大的地方在于過濾、轉換、添加或刪除流中傳輸的數據,例如,我們可以打開一個流處理 Markdown 文件,在把文件內容讀入內存的過程中自動將其轉化為 HTML。

運行該腳本,輸出的都是大寫字母:

我們還可以使用 php://filter 流封裝協議把過濾器附加到流上,不過,使用這種方式之前必須先打開 PHP 流:

這個方式實現效果和 stream_filter_append() 函數一樣,但是相比之下更為繁瑣。不過,PHP 的某些文件系統函數在調用后無法附加過濾器,例如 file() 和 fpassthru(),使用這些函數時只能使用 php://filter 流封裝協議附加流過濾器。

自定義流過濾器

我們還可以編寫自定義的流過濾器。其實,大多數情況下都要使用自定義的流過濾器,自定義的流過濾器是個 PHP 類,繼承內置的 php_user_filter 類( ),且必須實現 filter()、onCreate() 和 onClose() 方法,最后,必須使用 stream_filter_register() 函數注冊自定義的流過濾器。

然后,我們必須使用 stream_filter_register() 函數注冊這個自定義的 DirtyWordsFilter 流過濾器:

第一個參數用于標識這個自定義過濾器的過濾器名,第二個參數是這個自定義過濾器的類名。接下來就可以使用這個自定義的流過濾器了:

修改 test.txt 內容如下:

運行上面的自定義過濾器腳本,結果如下:

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如何接收別的服務器post過來的數據 - 技術問答

通常情況下用戶使用瀏覽器網頁表單向服務器post提交數據,我們使用PHP的$_POST接收用戶POST到服務器的數據,并進行適當的處理。但有些情況下,如用戶使用客戶端軟件向服務端php程序發送post數據,而不能用$_POST來識別,那又該如何處理呢?

我們介紹php接受post數據的三種方式:

1.$_POST方式接收數據

$_POST方式是通過 HTTP POST 方法傳遞的變量組成的數組,是自動全局變量。如使用$_POST[‘name’]就可以接收到網頁表單以及網頁異步方式post過來的數據,

即$_POST只能接收文檔類型為Content-Type: application/x-www-form-urlencoded提交的數據,也就是表單POST過來的數據。

2.$GLOBALS[‘HTTP_RAW_POST_DATA’]方式接收數據

但$GLOBALS[‘HTTP_RAW_POST_DATA’]中是否保存POST過來的數據取決于centent-Type的設置,只有在PHP在無法識別的Content-Type的情況下,才會將POST過來的數據原樣地填入變量$GLOBALS[‘HTTP_RAW_POST_DATA’]中,像Content-Type=application/x-www-form-urlencoded時,該變量是空的。

另外,它同樣無法讀取Content-Type為multipart/form-data的POST數據,也需要設置php.ini中的always_populate_raw_post_data值為On,PHP才會總把POST數據填入變量$http_raw_post_data。

3.php://input方式接收數據

如果訪問原始 POST 數據的更好方法是 php://input。php://input 允許讀取 POST 的原始數據。和 $HTTP_RAW_POST_DATA 比起來,它給內存帶來的壓力較小,并且不需要任何特殊的php.ini設置,php://input不能用于 enctype=”multipart/form-data”。對于未指定 Content-Type 的POST數據,則可以使用file_get_contents(“php://input”)來獲取原始數據。事實上,用PHP接收POST的任何數據都可以使用本方法。而不用考慮Content-Type,包括二進制文件流也可以。php://input讀取不到$_GET數據。是因為$

php 接收到之后post數據寫入數據庫

form表單demo:task.html

fieldset id="setFiled"

legend發布任務/legend

form action="registr.php" method="post" id="steForm"

label任務類型:/labelbr

input type="text" name="type"? id="taskType" placeholder="請選擇任務類型"/br

label酬nbsp;nbsp;金:/labelbr

input type="number" name="money" id="forMoney" min="1" max="1000"/label元/labelbr

label截止時間:/labelbr

input type="datetime" name="time" id="timeSubmit"/span data-year="" data-month="" data-date="" id="showDate"/spanbr

label詳細描述:/labelbr

textarea maxlength="512" name="textAray" id="msgArea"/textareabr

input type="submit" name="subMit" id="forSub" value="點擊發布" /

/form

擴展資料

php接收POST數據的三種方式

1、$_POST 方式接受數據

$_POST 方式是由通過HTTP的POST方法傳遞過來的數據組成的數組,是一個自動全局變量。

注:只能接收Content-Type:application/x-www-form-urlencode提交的數據。也就是只能接收表單過來的數據。

2、GLOBLES[‘HTTP_RAW_POST_DATA’]

如果訪問原始POST數據不是php能夠識別的文檔類型,比如:text/xml 或者soap等等,可以用$GLOBLES[‘HTTP_RAW_POST_DATA’]來接收,$HTTP_RAW_POST_DATA變量包含有原始POST數據。此變量僅在碰到未識別的MIME數據時產生。

注:$HTTP_RAW_POST_DATA對于enctype=”multipart/form-data”表單數據不可用,也就是說使用$HTTP_RAW_POST_DATA無法接受網頁表單post過來的數據。

3、file_get_contents(“php://input”);

如果訪問原始POST數據,更好的方法是使用file_get_content(“php://input”);對于未指定Content-Type的POST數據,可以使用該方法讀取POST原始數據,包括二進制流也可以和$HTTP_RAW_POST_DATA比起來。它帶來的生存眼里更小,并且不需要任何特殊的php.ini設置。

注:php://input不能用于 enctype=”multipart/form-data”

例如:$postStr = file_get_contents("php://input"); //獲取POST數據

本文名稱:php接收流數據處理 php輸入流
當前鏈接:http://m.kartarina.com/article34/hgecse.html

成都網站建設公司_創新互聯,為您提供網站內鏈域名注冊外貿網站建設網站維護虛擬主機

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

綿陽服務器托管
主站蜘蛛池模板: 亚洲大尺度无码专区尤物 | 亚洲午夜福利AV一区二区无码| 亚洲精品无码专区| 妖精色AV无码国产在线看| 国精品无码一区二区三区在线蜜臀| 久久亚洲精品成人无码网站| 精品一区二区三区无码免费直播| 亚洲中文字幕无码不卡电影| WWW久久无码天堂MV| 无码专区久久综合久中文字幕 | 久久久精品天堂无码中文字幕 | 亚洲综合无码一区二区| 日韩经典精品无码一区| 亚洲AV无码国产一区二区三区| 亚洲精品中文字幕无码蜜桃| 国产AV无码专区亚洲AV蜜芽| 日韩av无码中文字幕| 自慰无码一区二区三区| 国产在线无码视频一区| 亚洲AV无码一区二区三区网址| 久久久久无码精品亚洲日韩| 亚洲人成国产精品无码| 黑人巨大无码中文字幕无码| 亚洲av无码偷拍在线观看| 亚洲AV综合色区无码二区偷拍| 亚洲成AV人在线播放无码| 亚洲AV无码专区国产乱码4SE| 精品无人区无码乱码大片国产| 曰韩无码AV片免费播放不卡| 天堂一区人妻无码| 亚洲AV无码国产精品永久一区| 日韩精品少妇无码受不了| 国产精品无码A∨精品影院| 中文字幕精品无码一区二区三区| 亚洲午夜AV无码专区在线播放| 精品乱码一区内射人妻无码| 中文字幕人妻三级中文无码视频 | 国产台湾无码AV片在线观看| 中文字幕无码视频专区| 亚洲精品无码mv在线观看网站| 无码人妻精品一区二区在线视频|