>本教程建立在PHP流的基本面,證明了其權力的實際應用。我們將構建自定義過濾器,將其連接到流中,然後將它們集成到文檔解析器中。 建議對PHP流的先驗知識。完整的源代碼可在GitHub上找到。
>密鑰概念:
php_user_filter
的方法,以創建滿足您應用程序需求的過濾器。 filter()
>stream_filter_append()
>
PHP提供了一系列內置過濾器(例如,
>列表可用過濾器。 string.toupper
string.tolower
使用string.strip_tags
附加過濾器:mcrypt.*
mdecrypt.*
stream_get_filters()
>或者,使用
stream_filter_append()
$h = fopen('lorem.txt', 'r'); stream_filter_append($h, 'convert.base64-encode'); fpassthru($h); fclose($h);
> php://filter
閱讀時間過濾:Markdown Filter
$filter = 'convert.base64-encode'; $file = 'lorem.txt'; $h = fopen('php://filter/read=' . $filter . '/resource=' . $file,'r'); fpassthru($h); fclose($h);
此自定義過濾器將標記轉換為HTML。 它擴展了fpassthru()
,覆蓋
接收:
:輸入數據的桶。 php_user_filter
>
filter()
filter()
:輸出的存儲桶。
$in
>
$out
$consumed
和$closing
。 註冊和用法:onCreate()
onClose()
<?php namespace MarkdownFilter; use \Michelf\MarkdownExtra as MarkdownExtra; class MarkdownFilter extends \php_user_filter { // ... (Implementation as in original text) ... }
$out
>
這個過濾器將HTML內容嵌入模板中(在此示例中使用RAINTPL)。 它已註冊為template.*
>,允許通過通配符參數。
$h = fopen('lorem.txt', 'r'); stream_filter_append($h, 'convert.base64-encode'); fpassthru($h); fclose($h);
TemplateFilter
class(使用Raintpl類似於原始的實現):
$filter = 'convert.base64-encode'; $file = 'lorem.txt'; $h = fopen('php://filter/read=' . $filter . '/resource=' . $file,'r'); fpassthru($h); fclose($h);
>方法從過濾器名稱解碼標題。 onCreate()
方法處理數據,應用模板並寫入結果。
filter()
> 應用程序使用過濾器將源目錄中的Markdown文件遞歸轉換為目標目錄中的HTML文件,以維護目錄結構。 它使用作曲家進行依賴管理(Michelf/PHP-Markdown和Rain/Raintpl)。
>腳本(如原始文本中的實現)處理命令行參數,寄存器過濾器,通過目錄進行迭代,並將過濾器應用於Markdown Files。mddoc
常見問題(常見問題解答):mddoc
(FAQ部分在很大程度上保持不變,因為它提供了對PHP流的有價值的上下文和信息。
以上是有效地使用PHP流的詳細內容。更多資訊請關注PHP中文網其他相關文章!