PHP Conference Japan 2024

streamWrapper 类

(PHP 4 >= 4.3.2, PHP 5, PHP 7, PHP 8)

简介

允许您实现自己的协议处理程序和流,以便与所有其他文件系统函数(例如 fopen()fread() 等)一起使用。

注意:

不是一个真正的类,只是一个定义其自身协议的类的原型。

注意:

以与此处描述不同的方式实现方法可能会导致未定义的行为。

当流函数尝试访问与其关联的协议时,将初始化此类的实例。

类概要

class streamWrapper {
/* 属性 */
/* 方法 */
public __construct()
public dir_closedir(): bool
public dir_opendir(string $path, int $options): bool
public mkdir(string $path, int $mode, int $options): bool
public rename(string $path_from, string $path_to): bool
public rmdir(string $path, int $options): bool
public stream_cast(int $cast_as): resource
public stream_close(): void
public stream_eof(): bool
public stream_flush(): bool
public stream_lock(int $operation): bool
public stream_metadata(string $path, int $option, mixed $value): bool
public stream_open(
    string $path,
    string $mode,
    int $options,
    ?string &$opened_path
): bool
public stream_read(int $count): string|false
public stream_seek(int $offset, int $whence = SEEK_SET): bool
public stream_set_option(int $option, int $arg1, int $arg2): bool
public stream_tell(): int
public stream_truncate(int $new_size): bool
public unlink(字符串 $path): 布尔值
public url_stat(字符串 $path, 整数 $flags): 数组|false
public __destruct()
}

属性

资源 context

当前的 上下文,如果调用函数未传递上下文,则为 null

使用 stream_context_get_options() 解析上下文。

注意:

此属性必须为 public,以便 PHP 可以用实际的上下文资源填充它。

目录

添加注释

用户贡献的注释 4 条注释

isaac dot z dot no dot foster at spam dot gmail dot please dot com
14 年前
值得注意的是,yannick at gmail 定义的接口不应始终由流包装器类实现,因为如果类没有使用某些方法,则不应实现这些方法(根据手册)。

具体来说,如果包装器没有使用 mkdir、rename、rmdir 和 unlink 方法,则“不应定义”这些方法。结果是不会返回相应的错误消息。

如果实现了接口,则您将无法灵活地不实现这些方法。

不是想学术化,但这对我很有用。
info at ensostudio dot ru
4 年前
这些方法不是必需的,您可以只实现其中的一部分:目录、文件等。
例如,“glob://”支持最少的语法,glob() 更强大,您可以替换/扩展本机包装器:检查表中的选项 https://php.net/manual/ru/wrappers.glob,您只需要使用 'dir_...dir' 方法创建包装器即可。有关更多信息,请参见 https://php.net/manual/en/class.globiterator.php#125220
匿名
13 年前
这是一个非常简单的流包装器,它为读取调用您的回调函数

<?php

CallbackUrl
{
const
WRAPPER_NAME = 'callback';

public
$context;
private
$_cb;
private
$_eof = false;

private static
$_isRegistered = false;

public static function
getContext($cb)
{
if (!
self::$_isRegistered) {
stream_wrapper_register(self::WRAPPER_NAME, get_class());
self::$_isRegistered = true;
}
if (!
is_callable($cb)) return false;
return
stream_context_create(array(self::WRAPPER_NAME => array('cb' => $cb)));
}

public function
stream_open($path, $mode, $options, &$opened_path)
{
if (!
preg_match('/^r[bt]?$/', $mode) || !$this->context) return false;
$opt = stream_context_get_options($this->context);
if (!
is_array($opt[self::WRAPPER_NAME]) ||
!isset(
$opt[self::WRAPPER_NAME]['cb']) ||
!
is_callable($opt[self::WRAPPER_NAME]['cb'])) return false;
$this->_cb = $opt[self::WRAPPER_NAME]['cb'];
return
true;
}

public function
stream_read($count)
{
if (
$this->_eof || !$count) return '';
if ((
$s = call_user_func($this->_cb, $count)) == '') $this->_eof = true;
return
$s;
}

public function
stream_eof()
{
return
$this->_eof;
}
}

Test {
private
$_s;
public function
__construct($s)
{
$this->_s = $s;
}
public function
read($count) {
return
fread($this->_s, $count);
}
}

$t = new Test(fopen('/etc/services', 'r'));
$fd = fopen('callback://', 'r', false, CallbackUrl::getContext(array($t, 'read')));
while((
$buf = fread($fd, 128)) != '') {
print
$buf;
}
?>
yannick dot battail at gmail dot com
15年前
一个用于包装器的PHP接口

<?php
接口 WrapperInterface
{
/**
* 资源上下文
*
* @var resource
*/
//public $context;

/**
* 构造函数
*
*/
public function __construct();

/**
*
*
* @return bool
*/
public function dir_closedir();

/**
* 请输入描述...
*
* @param string $path
* @param int $options
* @return bool
*/
public function dir_opendir($path , $options);

/**
* 请输入描述...
*
* @return string
*/
public function dir_readdir();

/**
* 请输入描述...
*
* @return bool
*/
public function dir_rewinddir();

/**
* 请输入描述...
*
* @param string $path
* @param int $mode
* @param int $options
* @return bool
*/
public function mkdir($path , $mode , $options);

/**
* 请输入描述...
*
* @param string $path_from
* @param string $path_to
* @return bool
*/
public function rename($path_from , $path_to);

/**
* 请输入描述...
*
* @param string $path
* @param int $options
* @return bool
*/
public function rmdir($path , $options);

/**
* 请输入描述...
*
* @param int $cast_as
* @return resource
*/
public function stream_cast($cast_as);

/**
* 请输入描述...
*
*/
public function stream_close();

/**
* 请输入描述...
*
* @return bool
*/
public function stream_eof();

/**
* 请输入描述...
*
* @return bool
*/
public function stream_flush();

/**
* 请输入描述...
*
* @param mode $operation
* @return bool
*/
public function stream_lock($operation);

/**
* 请输入描述...
*
* @param string $path
* @param string $mode
* @param int $options
* @param string &$opened_path
* @return bool
*/
public function stream_open($path , $mode , $options , &$opened_path);

/**
* 请输入描述...
*
* @param int $count
* @return string
*/
public function stream_read($count);

/**
* 请输入描述...
*
* @param int $offset
* @param int $whence = SEEK_SET
* @return bool
*/
public function stream_seek($offset , $whence = SEEK_SET);

/**
* 请输入描述...
*
* @param int $option
* @param int $arg1
* @param int $arg2
* @return bool
*/
public function stream_set_option($option , $arg1 , $arg2);

/**
* 请输入描述...
*
* @return array
*/
public function stream_stat();

/**
* 请输入描述...
*
* @return int
*/
public function stream_tell();

/**
* 请输入描述...
*
* @param string $data
* @return int
*/
public function stream_write($data);

/**
* 请输入描述...
*
* @param string $path
* @return bool
*/
public function unlink($path);

/**
* 请输入描述...
*
* @param string $path
* @param int $flags
* @return array
*/
public function url_stat($path , $flags);
}

?>
To Top