file_get_contents
(PHP 4 >= 4.3.0, PHP 5)
file_get_contents — Reads entire file into a string
說明
string file_get_contents
( string $filename
[, bool $use_include_path
= false
[, resource $context
[, int $offset
= -1
[, int $maxlen
]]]] )
file_get_contents() is the preferred way to read the
contents of a file into a string. It will use memory mapping techniques if
supported by your OS to enhance performance.
Note:
If you're opening a URI with special characters, such as spaces, you
need to encode the URI with urlencode().
參數
-
filename
-
Name of the file to read.
-
use_include_path
-
Note:
As of PHP 5 the FILE_USE_INCLUDE_PATH
constant can be used
to trigger include path
search.
-
context
-
A valid context resource created with
stream_context_create(). If you don't need to use a
custom context, you can skip this parameter by NULL
.
-
offset
-
The offset where the reading starts on the original stream.
Seeking (offset
) is not supported with remote files.
Attempting to seek on non-local files may work with small offsets, but this
is unpredictable because it works on the buffered stream.
-
maxlen
-
Maximum length of data read. The default is to read until end
of file is reached. Note that this parameter is applied to the
stream processed by the filters.
回傳值
The function returns the read data 或者在失敗時回傳 FALSE
.
Warning本函式可能回傳布林值
FALSE
,但也可能回傳一個與 FALSE
等值的非布林值,例如
0 或者 ""。請參閱布林類型章節以獲取更多訊息。應使用
=== 運算符來測試本函式的回傳值。
錯誤/例外
An E_WARNING
level error is generated if filename
cannot be found, maxlength
is less than zero, or if seeking to the specified offset
in the stream fails.
範例
Example #1 Get and output the source of the homepage of a website
<?php
$homepage = file_get_contents('http://www.example.com/');
echo $homepage;
?>
Example #2 Searching within the include_path
<?php
// <= PHP 5
$file = file_get_contents('./people.txt', true);
// > PHP 5
$file = file_get_contents('./people.txt', FILE_USE_INCLUDE_PATH);
?>
Example #3 Reading a section of a file
<?php
// Read 14 characters starting from the 21st character
$section = file_get_contents('./people.txt', NULL, NULL, 20, 14);
var_dump($section);
?>
string(14) "lle Bjori Ro"
Example #4 Using stream contexts
<?php
// Create a stream
$opts = array(
'http'=>array(
'method'=>"GET",
'header'=>"Accept-language: en\r\n" .
"Cookie: foo=bar\r\n"
)
);
$context = stream_context_create($opts);
// Open the file using the HTTP headers set above
$file = file_get_contents('http://www.example.com/', false, $context);
?>
註釋
Note: 本函式可安全用於二進位對象。
Warning使用 SSL 時,Microsoft IIS
會違反協議不發送close_notify標記就關閉連線。PHP 會在到資料尾端時報告“SSL: Fatal Protocol Error”。
要解決此問題,error_reporting 應設定為將機級別至不包含警告。
PHP 4.3.7 及更高版本可以在使用 https:// 包裝器打該串流時檢測出有問題的 IIS 伺服器軟體並抑制警告。在使用
fsockopen() 建立 ssl:// 端口時, 開發者需檢測並抑制此警告。