>本教程建立在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()
<code class="language-php">$h = fopen('lorem.txt', 'r'); stream_filter_append($h, 'convert.base64-encode'); fpassthru($h); fclose($h);</code>
> php://filter
阅读时间过滤:Markdown Filter
<code class="language-php">$filter = 'convert.base64-encode'; $file = 'lorem.txt'; $h = fopen('php://filter/read=' . $filter . '/resource=' . $file,'r'); fpassthru($h); fclose($h);</code>>
此自定义过滤器将标记转换为HTML。 它扩展了fpassthru()
,覆盖
接收:
:输入数据的桶。php_user_filter
>
filter()
filter()
:输出的存储桶。
$in
>
$out
$consumed
和$closing
。 注册和用法:onCreate()
onClose()
<code class="language-php"><?php namespace MarkdownFilter; use \Michelf\MarkdownExtra as MarkdownExtra; class MarkdownFilter extends \php_user_filter { // ... (Implementation as in original text) ... }</code>>写入时间过滤:模板过滤
$out
>
这个过滤器将HTML内容嵌入模板中(在此示例中使用RAINTPL)。 它已注册为template.*
>,允许通过通配符参数。
<code class="language-php">$h = fopen('lorem.txt', 'r'); stream_filter_append($h, 'convert.base64-encode'); fpassthru($h); fclose($h);</code>
TemplateFilter
class(使用Raintpl类似于原始的实现):
<code class="language-php">$filter = 'convert.base64-encode'; $file = 'lorem.txt'; $h = fopen('php://filter/read=' . $filter . '/resource=' . $file,'r'); fpassthru($h); fclose($h);</code>
>方法从过滤器名称解码标题。 onCreate()
方法处理数据,应用模板并写入结果。
filter()
> 应用程序使用过滤器将源目录中的Markdown文件递归转换为目标目录中的HTML文件,以维护目录结构。 它使用作曲家进行依赖管理(Michelf/PHP-Markdown和Rain/Raintpl)。
>脚本(如原始文本中的实现)处理命令行参数,寄存器过滤器,通过目录进行迭代,并将过滤器应用于Markdown Files。mddoc
常见问题(常见问题解答):mddoc
(FAQ部分在很大程度上保持不变,因为它提供了对PHP流的有价值的上下文和信息。
以上是有效地使用PHP流的详细内容。更多信息请关注PHP中文网其他相关文章!