isSeekable PHP函數(shù),它的主要作用就是測(cè)試某個(gè)資源是否可隨機(jī)定位。 我們可以通過(guò)這個(gè)函數(shù)在PHP中判斷一個(gè)流(例如文件或網(wǎng)絡(luò)資源)是否支持隨機(jī)訪問(wèn)。
通常情況下,如果流可隨機(jī)定位,它通常是支持seek方法。例如,可以使用:fopen()和fopen()并立即傳遞‘r+’或者更大的模式來(lái)打開(kāi)一個(gè)文件,此時(shí)便會(huì)支持隨機(jī)訪問(wèn)。接下來(lái)我們來(lái)簡(jiǎn)單了解一下PHP如何使用isSeekable函數(shù)。
<?php $fp = fopen('/path/to/file', 'r'); if (is_resource($fp) && stream_is_seekable($fp)) { //流支持隨機(jī)訪問(wèn) } fclose($fp); ?>
以上代碼展示的是讀取文件時(shí)的一個(gè)常見(jiàn)情況,如果要對(duì)stdout(或任何其他輸出)進(jìn)行測(cè)試,我們可以直接使用fopen('php://stdout', 'w')來(lái)獲取一個(gè)流。
通常情況下fopen返回的流對(duì)象都是可隨機(jī)訪問(wèn)的,因?yàn)樵摵瘮?shù)被廣泛使用來(lái)打開(kāi)文件以供讀寫(xiě)操作。不過(guò)有些流不支持隨機(jī)訪問(wèn),比如:有些壓縮方案需要先打包之后再讀取,這些操作就會(huì)使流變得不可隨機(jī)訪問(wèn)。
此時(shí)我們可以使用isSeekable函數(shù)來(lái)判斷,判斷是否支持隨機(jī)訪問(wèn)。該函數(shù)的返回值是bool類(lèi)型,如果流支持seek功能,則返回true,否則返回false。如下所示:
<?php $handler = fopen('/dev/stdin', 'r'); var_dump(stream_is_seekable($handler)); // bool(true) ?>
另外告訴大家一個(gè)小技巧,isSeekable方法的替代方法:使用stream_get_meta_data函數(shù),這將返回一個(gè)數(shù)組,該數(shù)組包含有關(guān)流的元數(shù)據(jù),如當(dāng)前流中是否可用,當(dāng)前流的文件名(如果有),以及是否支持認(rèn)證,是否支持讀寫(xiě)操作,以及當(dāng)前流的許多其他功能。使用stream_get_meta_data函數(shù),可以查看流的詳細(xì)信息。
<?php $handler = fopen('/dev/stdin', 'r'); $metaData = stream_get_meta_data($handler); var_dump($metaData['seekable']); // bool(true) ?>
當(dāng)流不支持隨機(jī)訪問(wèn)時(shí),最常見(jiàn)的錯(cuò)誤是:在PHP中使用了不受支持的函數(shù)或方法,這里會(huì)直接拋出錯(cuò)誤。例如在追加模式下打開(kāi)文件,并調(diào)用fseek函數(shù)會(huì)拋出PHP Warning。
總之,isSeekable函數(shù)是一個(gè)非常實(shí)用的函數(shù),可以對(duì)流進(jìn)行檢查,確保您要使用的隨機(jī)訪問(wèn)函數(shù)有效。如果該函數(shù)返回true,那么您可以安全地在流上使用seek功能,否則您需要查看其他解決方案。