㈠ 關於 php fopen()函數的問題
假設有文件內容,那麼$file就是1,否則就是0
那麼if的第一個分支,如果有文件,那麼!$file就是0了,則第一個分支不會成立,會直接轉到else裡面
如果沒有文件,那麼!$file = !0 = 1;那麼第一個分支就會成立,直接輸出打開文件失敗
LZ頭痛的原因就在於,把邏輯的真假和文件的有否弄混淆了
㈡ php fopen函數報錯failed to open stream 未能打開流
fopen報錯有以下幾種情況:
要打開的文件不存在
要打開的文件無許可權訪問(常見於Linux系統)
打開的模式選擇了x+或x,其中x+以讀寫方式打開,x以寫入方式打開,這兩種模式會創建一個新的文件,如果文件已經存在,則會打開失敗,函數返回false並拋出warning級別的錯誤
解決方法:
選擇合適的打開模式,對於文件不存在即報錯的模式,需要注意打開的文件一定要存在
為文件設置正確的許可權
打開文件前判斷是否存在,根據實際需求刪除舊文件或更改文件名
㈢ php怎麼訪問url,如果訪問如果返回true訪問失敗返回false,不要跳轉, 就判斷訪問是否成
php訪問url的四種方式
1.fopen方式
//訪問指定URL函數
[php] view plain
print?
function access_url($url) {
if ($url=='') return false;
$fp = fopen($url, 'r') or exit('Open url faild!');
if($fp){
while(!feof($fp)) {
$file.=fgets($fp)."";
}
fclose($fp);
}
return $file;
}
2.file_get_contents方式(打開遠程文件的時候會造成CPU飆升。file_get_contents其實也可以post)
[php] view plain
print?
$content = file_get_contents("httttp://wwww..com");
3.curl方式
[php] view plain
print?
function curl_file_get_contents($rl){
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $rl);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true) ; // 獲取數據返回
curl_setopt($ch, CURLOPT_BINARYTRANSFER, true) ; // 在啟用 CURLOPT_RETURNTRANSFER 時候將獲取數據返回
$r = curl_exec($ch);
curl_close($ch);
return $r;
}
4.fsockopen方式(只能獲取網站主頁信息,其他頁面不可以)
[php] view plain
print?
$fp = fsockopen("www..com", 80, $errno, $errstr, 30);
if (!$fp) {
echo "$errstr ($errno)<br />\n";
} else {
$out="GET / HTTP/1.1\r\n";
$out.="Host: www..com\r\n";
$out.="Connection: Close\r\n\r\n";
fwrite($fp, $out);
while (!feof($fp)) {
echo fgets($fp, 128);
}
fclose($fp);
}
㈣ php fopen函數打開本地文件顯示 failed to open stream 代碼如下
<?php
$DOCUMENT_ROOT=$_SERVER['DOCUMENT_ROOT'];
if(($fp=fopen("{$DOCUMENT_ROOT}/../a/b/c.txt",'r')===false){
echo"openfilefail";
}
㈤ php中fopen函數的返回值是什麼啊
判斷條件改成
if(!$file)
當文件不存在的時候就會顯示sorry了。。
㈥ php 中 fopen()打開文件(Url)失敗是什麼原因
需要在php.ini中將相關配置開啟
fopen原型:
resourcefopen(string$filename,string$mode[,bool$use_include_path=false[,resource$context]])
如果PHP認為filename指定的是一個已注冊的協議,而該協議被注冊為一個網路URL,PHP將檢查並確認allow_url_fopen已被激活。如果關閉了,PHP將發出一個警告,而fopen的調用則失敗。
allow_url_fopen:本選項激活了URL形式的fopen封裝協議使得可以訪問URL對象例如文件。默認的封裝協議提供用ftp和http協議來訪問遠程文件,一些擴展庫例如zlib可能會注冊更多的封裝協議。
注意:
出於安全性考慮,此選項只能在php.ini中設置。
此選項是緊接著版本4.0.3發布後引進的。版本4.0.3以及之前的版本只能在編譯時通過配置項--disable-url-fopen-wrapper來取消此特性。
㈦ PHP,如果想要在文件末尾寫入方式打開一個文件,該給fopen()傳什麼參數
據我所知,共有下面幾種方式,下面我用我總結了知識給你簡單說明,並且能夠讓你快速記得它們的區別:
文檔說:
r(read只讀,文件頭,不存在就出錯)
w(write清空狀態下的寫,不存在會創建)
x(以只讀方式創建文件,如文件存在則返回false)
a(add末尾增加的寫,文件尾,不存在會創建)
r+(read讀/寫,文件頭,不存在就出錯)
w+(write清空狀態下的讀寫,不存在就創建)
x+(以讀寫方式創建文件,如文件存在則返回false)
a+(add末尾增加的讀寫,文件尾,不存在就創建)
我說:
上面的內容比較容易混淆,現在分類給你看看:
r,r+(讀)內容保留,不存在不創建。+表示(寫)
w,w+(寫),內容不保留,不存在則創建。+表示(讀)
a,a+(寫),內容保留,不存在則創建。+表示(讀)
x,x+ 寫方式創建文件,存在返回false。+表示(讀)
------------------------------------------------
b (bit二進制模式,默認模式,推薦使用)
t(文本,一般不常用)
㈧ PHP中如果fopen指向的文件不存在時怎麼顯示或跳轉指定的其他內容或鏈接,詳細描述如下
你用fopen打開之後,判斷下變數fh是否為真就完了,因為打開失敗會返回false的,所以加個判斷就行,為假就不繼續執行了,做跳轉,還有技術方面不會的也可以指導教學
㈨ php中fopen()如何理解
fopen
(PHP 3, PHP 4, PHP 5)
fopen -- 打開文件或者 URL
說明
resource fopen ( string filename, string mode [, bool use_include_path [, resource zcontext]] )
fopen() 將 filename 指定的名字資源綁定到一個流上。如果 filename 是 "scheme://..." 的格式,則被當成一個 URL,PHP 將搜索協議處理器(也被稱為封裝協議)來處理此模式。如果該協議尚未注冊封裝協議,PHP 將發出一條消息來幫助檢查腳本中潛在的問題並將 filename 當成一個普通的文件名繼續執行下去。
如果 PHP 認為 filename 指定的是一個本地文件,將嘗試在該文件上打開一個流。該文件必須是 PHP 可以訪問的,因此需要確認文件訪問許可權允許該訪問。如果激活了安全模式或者 open_basedir 則會應用進一步的限制。
如果 PHP 認為 filename 指定的是一個已注冊的協議,而該協議被注冊為一個網路 URL,PHP 將檢查並確認 allow_url_fopen 已被激活。如果關閉了,PHP 將發出一個警告,而 fopen 的調用則失敗。
注: 所支持的協議列表見附錄 M。某些協議(也被稱為 wrappers)支持 context 和/或 php.ini 選項。參見相應的頁面哪些選項可以被設定(例如 php.ini 中用於 http wrapper 的 user_agent 值)。
注: 對 context 的支持是 PHP 5.0.0 添加的。有關 context 的說明見參考 CXLV, Stream Functions。
注: 自 PHP 4.3.2 起,對所有區別二進制和文本模式的平台默認模式都被設為二進制模式。如果在升級後腳本碰到問題,嘗試暫時使用 't' 標記,直到所有的腳本都照以下所說的改為更具移植性以後。
mode 參數指定了所要求到該流的訪問類型。可以是以下:
表格 1. fopen() 中 mode 的可能值列表
mode 說明
'r' 只讀方式打開,將文件指針指向文件頭。
'r+' 讀寫方式打開,將文件指針指向文件頭。
'w' 寫入方式打開,將文件指針指向文件頭並將文件大小截為零。如果文件不存在則嘗試創建之。
'w+' 讀寫方式打開,將文件指針指向文件頭並將文件大小截為零。如果文件不存在則嘗試創建之。
'a' 寫入方式打開,將文件指針指向文件末尾。如果文件不存在則嘗試創建之。
'a+' 讀寫方式打開,將文件指針指向文件末尾。如果文件不存在則嘗試創建之。
'x' 創建並以寫入方式打開,將文件指針指向文件頭。如果文件已存在,則 fopen() 調用失敗並返回 FALSE,並生成一條 E_WARNING 級別的錯誤信息。如果文件不存在則嘗試創建之。這和給 底層的 open(2) 系統調用指定 O_EXCL|O_CREAT 標記是等價的。此選項被 PHP 4.3.2 以及以後的版本所支持,僅能用於本地文件。
'x+' 創建並以讀寫方式打開,將文件指針指向文件頭。如果文件已存在,則 fopen() 調用失敗並返回 FALSE,並生成一條 E_WARNING 級別的錯誤信息。如果文件不存在則嘗試創建之。這和給 底層的 open(2) 系統調用指定 O_EXCL|O_CREAT 標記是等價的。此選項被 PHP 4.3.2 以及以後的版本所支持,僅能用於本地文件。
注: 不同的操作系統家族具有不同的行結束習慣。當寫入一個文本文件並想插入一個新行時,需要使用符合操作系統的行結束符號。基於 Unix 的系統使用 \n 作為行結束字元,基於 Windows 的系統使用 \r\n 作為行結束字元,基於 Macintosh 的系統使用 \r 作為行結束字元。
如果寫入文件時使用了錯誤的行結束符號,則其它應用程序打開這些文件時可能會表現得很怪異。
Windows 下提供了一個文本轉換標記('t')可以透明地將 \n 轉換為 \r\n。與此對應還可以使用 'b' 來強制使用二進制模式,這樣就不會轉換數據。要使用這些標記,要麼用 'b' 或者用 't' 作為 mode 參數的最後一個字元。
默認的轉換模式依賴於 SAPI 和所使用的 PHP 版本,因此為了便於移植鼓勵總是指定恰當的標記。如果是操作純文本文件並在腳本中使用了 \n 作為行結束符,但還要期望這些文件可以被其它應用程序例如 Notepad 讀取,則在 mode 中使用 't'。在所有其它情況下使用 'b'。
在操作二進制文件時如果沒有指定 'b' 標記,可能會碰到一些奇怪的問題,包括壞掉的圖片文件以及關於 \r\n 字元的奇怪問題。
注: 為移植性考慮,強烈建議在用 fopen() 打開文件時總是使用 'b' 標記。
注: 再一次,為移植性考慮,強烈建議你重寫那些依賴於 't' 模式的代碼使其使用正確的行結束符並改成 'b' 模式。
如果也需要在 include_path 中搜尋文件的話,可以將可選的第三個參數 use_include_path 設為 '1' 或 TRUE。
如果打開失敗,本函數返回 FALSE。
例子 1. fopen() 例子
<?php
$handle = fopen("/home/rasmus/file.txt", "r");
$handle = fopen("/home/rasmus/file.gif", "wb");
$handle = fopen("http://www.example.com/", "r");
$handle = fopen("ftp://user:[email protected]/somefile.txt", "w");
?>
如果在用伺服器模塊版本的 PHP 時在打開和寫入文件上遇到問題,記住要確保所使用的文件是伺服器進程所能夠訪問的。
在 Windows 平台上,要小心轉義文件路徑中的每個反斜線,或者用斜線。
<?php
$handle = fopen("c:\\data\\info.txt", "r");
?>