PHP Conference Japan 2024

stream_filter_register

(PHP 5, PHP 7, PHP 8)

stream_filter_register注册用户自定义流过滤器

描述

stream_filter_register(string $filter_name, string $class): bool

stream_filter_register() 允许您在所有其他文件系统函数(例如 fopen()fread() 等)使用的任何已注册流上实现您自己的过滤器。

参数

filter_name

要注册的过滤器名称。

class

要实现过滤器,您需要定义一个类作为 php_user_filter 的扩展,并包含多个成员函数。当对附加了过滤器的流执行读/写操作时,PHP 将数据通过您的过滤器(以及附加到该流的任何其他过滤器)传递,以便可以根据需要修改数据。您必须完全按照 php_user_filter 中所述实现这些方法 - 否则会导致未定义的行为。

返回值

成功时返回 true,失败时返回 false

如果 filter_name 已定义,则 stream_filter_register() 将返回 false

范例

示例 #1 对 foo-bar.txt 流中的字符进行大写转换的过滤器

下面的示例在 foo-bar.txt 流上实现了一个名为 strtoupper 的过滤器,该过滤器将把写入/读取到该流中的所有字母字符转换为大写。

<?php

/* 定义我们的过滤器类 */
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;
}
}

/* 向PHP注册我们的过滤器 */
stream_filter_register("strtoupper", "strtoupper_filter")
or die(
"注册过滤器失败");

$fp = fopen("foo-bar.txt", "w");

/* 将已注册的过滤器附加到刚刚打开的流 */
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

示例 #2 注册通用的过滤器类以匹配多个过滤器名称。

<?php

/* 定义我们的过滤器类 */
class string_filter extends php_user_filter {
var
$mode;

function
filter($in, $out, &$consumed, $closing)
{
while (
$bucket = stream_bucket_make_writeable($in)) {
if (
$this->mode == 1) {
$bucket->data = strtoupper($bucket->data);
} elseif (
$this->mode == 0) {
$bucket->data = strtolower($bucket->data);
}

$consumed += $bucket->datalen;
stream_bucket_append($out, $bucket);
}
return
PSFS_PASS_ON;
}

function
onCreate()
{
if (
$this->filtername == 'str.toupper') {
$this->mode = 1;
} elseif (
$this->filtername == 'str.tolower') {
$this->mode = 0;
} else {
/* 请求了其他 str.* 过滤器,
报告失败,以便 PHP 继续查找 */
return false;
}

return
true;
}
}

/* 向 PHP 注册我们的过滤器 */
stream_filter_register("str.*", "string_filter")
or die(
"注册过滤器失败");

$fp = fopen("foo-bar.txt", "w");

/* 将注册的过滤器附加到刚刚打开的流
我们也可以在这里绑定到 str.tolower */
stream_filter_append($fp, "str.toupper");

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

参见

添加注释

用户贡献的注释

此页面没有用户贡献的注释。
To Top