Ok, vì vậy cách tôi đề xuất thực hiện việc này là với tệp stream wrapper. Hãy để tôi whip lên một ví dụ nhanh:
class staticStreamWrapper {
public $context;
protected static $data = array();
protected $path = '';
protected $pointer = 0;
protected $writable = false;
public function stream_close() {}
public function stream_eof() {
return $this->pointer >= strlen(static::$data[$this->path]);
}
public function stream_flush() {}
public function stream_open($path, $mode, $options, &$opened_path) {
switch ($mode[0]) {
case 'r':
if (!isset(static::$data[$path])) return false;
$this->path = $path;
$this->writable = isset($mode[1]) && $mode[1] == '+';
break;
case 'w':
static::$data[$path] = '';
$this->path = $path;
$this->writable = true;
break;
case 'a':
if (!isset(static::$data[$path])) static::$data[$path] = '';
$this->path = $path;
$this->writable = true;
$this->pointer = strlen(static::$data[$path]);
break;
case 'x':
if (isset(static::$data[$path])) return false;
$this->path = $path;
$this->writable = true;
break;
case 'c':
if (!isset(static::$data[$path])) static::$data[$path] = '';
$this->path = $path;
$this->writable = true;
break;
default:
return false;
}
$opened_path = $this->path;
return true;
}
public function stream_read($count) {
$bytes = min(strlen(static::$data[$this->path]) - $this->pointer, $count);
$data = substr(static::$data[$this->path], $this->pointer, $bytes);
$this->pointer += $bytes;
return $data;
}
public function stream_seek($offset, $whence = SEEK_SET) {
$len = strlen(static::$data[$this->path]);
switch ($whence) {
case SEEK_SET:
if ($offset <= $len) {
$this->pointer = $offset;
return true;
}
break;
case SEEK_CUR:
if ($this->pointer + $offset <= $len) {
$this->pointer += $offset;
return true;
}
break;
case SEEK_END:
if ($len + $offset <= $len) {
$this->pointer = $len + $offset;
return true;
}
break;
}
return false;
}
public function stream_stat() {
$size = strlen(static::$data[$this->path]);
$time = time();
return array(
0 => 0,
'dev' => 0,
1 => 0,
'ino' => 0,
2 => 0777,
'mode' => 0777,
3 => 1,
'nlink' => 1,
4 => 0,
'uid' => 0,
5 => 0,
'gid' => 0,
6 => '',
'rdev' => '',
7 => $size,
'size' => $size,
8 => $time,
'atime' => $time,
9 => $time,
'mtime' => $time,
10 => $time,
'ctime' => $time,
11 => -1,
'blksize' => -1,
12 => -1,
'blocks' => -1,
);
}
public function stream_tell() {
return $this->pointer;
}
public function stream_write($data) {
if (!$this->writable) return 0;
$size = strlen($data);
$len = strlen(static::$data[$this->path]);
if ($this->stream_eof()) {
static::$data[$this->path] .= $data;
} else {
static::$data[$this->path] = substr_replace(
static::$data[$this->path],
$data,
$this->pointer
);
}
$this->pointer += $size;
return $size;
}
public function unlink($path) {
if (isset(static::$data[$path])) {
unset(static::$data[$path]);
}
return true;
}
}
Bây giờ, sau đó bạn sẽ cần phải đăng ký wrapper:
stream_wrapper_register('static', 'staticStreamWrapper');
Vì vậy, bây giờ bạn có thể đối xử với nó như một tập tin mặc dù nó không bao giờ thực sự rời khỏi PHP (nó được lưu trữ dưới dạng biến tĩnh)!
file_put_contents('static://foo.txt', 'this is my data');
file_get_contents('static://foo.txt'); // "this is my data"
$f = fopen('static://foo.txt', 'r'); // should return a resource
// etc...
bạn muốn làm gì với nó khi bạn lưu? Bạn có nghĩ về việc sử dụng luồng tệp thay vì bộ nhớ dùng chung không? xem [StreamWrapper] (http://us2.php.net/manual/en/class.streamwrapper.php) – ircmaxell
Tôi chỉ lưu dữ liệu vào tệp (sử dụng 'file_put_contents') và nạp tên tệp vào các hàm OpenSSL. Phần lớn chi phí là từ các hàm OpenSSL và các hoạt động VFS (đọc, viết, bỏ liên kết). Làm cách nào để tạo sự khác biệt? –