note that this function does not actually use sendfile() on linux systems (at least not in PHP 7.2.12)
(PHP 5, PHP 7, PHP 8)
stream_copy_to_stream — データをあるストリームから別のストリームにコピーする
$from
,$to
,$length
= null
,$offset
= 0
現在の位置(あるいはもし指定されていれば
offset
の位置)から最大
length
バイトのデータを
from
から to
にコピーします。もし length
が null
の
場合は、from
にある残りすべてのデータが
コピーされます。
from
コピー元のストリーム。
to
コピー先のストリーム。
length
コピーする最大バイト数。 デフォルトでは、残りの全てのデータがコピーされます。
offset
コピーを開始する位置。
コピーされたバイト数を返します。失敗した場合に false
を返します。
バージョン | 説明 |
---|---|
8.0.0 |
length は、nullable になりました。
|
例1 stream_copy_to_stream() の例
<?php
$src = fopen('http://www.example.com', 'r');
$dest1 = fopen('first1k.txt', 'w');
$dest2 = fopen('remainder.txt', 'w');
echo stream_copy_to_stream($src, $dest1, 1024) . " バイトが first1k.txt にコピーされました\n";
echo stream_copy_to_stream($src, $dest2) . " バイトが remainder.txt にコピーされました\n";
?>
note that this function does not actually use sendfile() on linux systems (at least not in PHP 7.2.12)
stream_copy_to_stream almost copies a stream...
$objInputStream = fopen("php://input", "rb");
$objTempStream = fopen("php://temp", "w+b");
stream_copy_to_stream($objInputStream, $objTempStream);
That code will copy a stream but it will also move the stream pointers to EOF. This is fine if you plan on rewinding the temp stream but good luck rewinding the input stream.
rewind($objTempStream);
rewind($objInputStream);
So as you can see this is stream copy or stream move depending on what kind of stream you are working with, and because there are no peaking functions your effed if you need to read from an input stream in multiple classes that are unrelated.