PHP header()函數(shù)使用詳細(301、404等錯誤設(shè)置)
更新時間:2013年04月17日 21:33:26 作者:
用PHP header()函數(shù)實現(xiàn)頁面404錯誤提示功能,特整理了PHP header()函數(shù)的詳細使用分享給大家,需要大家多多支持我們
如果您剛剛開始學習PHP,可能有許多函數(shù)需要研究,今天我們就來學習一下PHP Header()的使用方法,更多的使用說明,請您參照PHP中文手冊,下面是關(guān)于header函數(shù)的詳細使用說明
header實現(xiàn)404無法找到頁面
Header("HTTP/1.1 404 Not Found");
針對apache配置中的ErrorDocument 404 /404.php功能,把nginx配置中的
error_page 404 /404.php;
改成
error_page 404 = /404.php;
php heager 301
<?php
header("HTTP/1.1 301 Moved Permanently");
header ("Location:$url");
?>
不管頁面有多少header,它會執(zhí)行最后一個,不過是有條件的,例如:
header('Location:http://www.dbjr.com.cn');
header('Location:http://www.g.cn');
header('Location:http://www.baidu.com');
這個就會跳到百度
header('Location:http://www.dbjr.com.cn');echo '烈火網(wǎng);
header('Location:http://www.g.cn');
header('Location:http://www.baidu.com');
這個就會跳到google
下面是關(guān)于header函數(shù)的詳細使用說明
一、作用:
~~~~~~~~~
PHP只是以HTTP協(xié)議將HTML文檔的標頭送到瀏覽器,告訴瀏覽器具體怎么處理這個頁面,至于傳送的內(nèi)容則需要熟悉一下HTTP協(xié)議了,與PHP無關(guān)了
傳統(tǒng)的標頭一定包含下面三種標頭之一,并只能出現(xiàn)一次。
Location: xxxx:yyyy/zzzz
Content-Type: xxxx/yyyy
Status: nnn xxxxxx
二、先來了解一下HTTP協(xié)議的運作方式
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
HTTP協(xié)議是基于請求/響應(yīng)范式的。一個客戶機與服務(wù)器建立連接后,發(fā)送一個請求給服務(wù)器,請求方式的格式為,統(tǒng)一資源標識符、協(xié)議版本號,后邊是 MIME信息包括請求修飾符、客戶機信息和可能的內(nèi)容。服務(wù)器接到請求后,給予相應(yīng)的響應(yīng)信息,其格式為一個狀態(tài)行包括信息的協(xié)議版本號、一個成功或錯誤的代碼,后邊是MIME信息包括服務(wù)器信息、實體信息和可能的內(nèi)容。
它分四個過程,在HTTP協(xié)議中,服務(wù)端是指提供HTTP服務(wù)的部分,客戶端是指你使用的瀏覽器或者下載工具等等。在通訊時,由客戶端發(fā)出請求連接,服務(wù)端建立連接;然后,客戶端發(fā)出HTTP請求(Request),服務(wù)端返回響應(yīng)信息(Respond),由此完成一個HTTP操作。
三、HTTP協(xié)議狀態(tài)碼表示的意思
~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1×× 保留
2×× 表示請求成功地接收
3×× 為完成請求客戶需進一步細化請求
4×× 客戶錯誤
5×× 服務(wù)器錯誤
四、操作實例:
~~~~~~~~~~~~~
<1> 重定向功能,這種最常見
<?php
Header("Location: http://www.dbjr.com.cn/");
?>
<2> 強制用戶每次訪問這個頁面時獲取最新資料,而不是使用存在客戶端的緩存。
代碼
<?php
//告訴瀏覽器此頁面的過期時間(用格林威治時間表示),只要是已經(jīng)過去的日期即可。
header("Expires: Mon, 26 Jul 1970 05:00:00 GMT");
//告訴瀏覽器此頁面的最后更新日期(用格林威治時間表示)也就是當天,目的就是強迫瀏覽器獲取最新資料
header("Last-Modified: " . gmdate("D, d M Y H:i:s") . "GMT");
//告訴客戶端瀏覽器不使用緩存
header("Cache-Control: no-cache, must-revalidate");
//參數(shù)(與以前的服務(wù)器兼容),即兼容HTTP1.0協(xié)議
header("Pragma: no-cache");
//輸出MIME類型
header("Content-type: application/file");
//文件長度
header("Content-Length: 227685");
//接受的范圍單位
header("Accept-Ranges: bytes");
//缺省時文件保存對話框中的文件名稱
header("Content-Disposition: attachment; filename=$filename");
?>
<3> 輸出狀態(tài)值到瀏覽器,主要用于訪問權(quán)限控制
<?php
header('HTTP/1.1 401 Unauthorized');
header('status: 401 Unauthorized');
?>
比如要限制一個用戶不能訪問該頁,則可設(shè)置狀態(tài)為404,如下所示,這樣瀏覽器就顯示為即該頁不存在
<?php
header('HTTP/1.1 404 Not Found');
header("status: 404 Not Found");
?>
注意: 傳統(tǒng)的標頭一定包含下面三種標頭之一,并只能出現(xiàn)一次。 Content-Type: xxxx/yyyy Location: xxxx:yyyy/zzzz Status: nnn xxxxxx 在新的多型標頭規(guī)格 (Multipart MIME) 方可以出現(xiàn)二次以上。
使用范例
范例一: 本例使瀏覽器重定向到 PHP 的官方網(wǎng)站。
Header("Location: http://www.dbjr.com.cn/"); exit;
范例二: 要使用者每次都能得到最新的資料,而不是 Proxy 或 cache 中的資料,可以使用下列的標頭
header("Expires: Mon, 26 Jul 1997 05:00:00 GMT");
header("Last-Modified: " . gmdate("D, d M Y H:i:s") . "GMT"); header("Cache-Control: no-cache, must-revalidate");
header("Pragma: no-cache");
范例三: 讓使用者的瀏覽器出現(xiàn)找不到檔案的信息。
header("Status: 404 Not Found");
范例四:讓使用者下載檔案。
header("Content-type: application/x-gzip");
header("Content-Disposition: attachment; filename=文件名");
header("Content-Description: PHP3 Generated Data");
header -- 發(fā)送一個原始 HTTP 標頭說明
void header ( string string [, bool replace [, int http_response_code]] )
header() 函數(shù)用來發(fā)送一個原始 HTTP 標頭。有關(guān) HTTP 標頭的更多內(nèi)容見 HTTP/1.1 規(guī)范。
可選參數(shù) replace 指明是替換掉前一條類似的標頭還是增加一條相同類型的標頭。默認為替換,但如果將其設(shè)為 FALSE 則可以強制發(fā)送多個同類標頭。例如:
<?php
header('WWW-Authenticate: Negotiate');
header('WWW-Authenticate: NTLM', false);
?>
第二個可選參數(shù) http_response_code 強制將 HTTP 響應(yīng)代碼設(shè)為指定值(此參數(shù)是 PHP 4.3.0 新加的)。
有兩種特殊的 header 調(diào)用。第一種是標頭以字符串“HTTP/”(大小寫不重要)開頭的,可以用來確定要發(fā)送的 HTTP 狀態(tài)碼。例如,如果配置了 Apache 用 PHP 來處理找不到文件的錯誤處理請求(使用 ErrorDocument 指令),需要確保腳本產(chǎn)生了正確的狀態(tài)碼。
<?php
header("HTTP/1.0 404 Not Found")
?>
注: HTTP 狀態(tài)碼標頭行總是第一個被發(fā)送到客戶端,而并不管實際的 header() 調(diào)用是否是第一個。除非 HTTP 標頭已經(jīng)發(fā)送出去,任何時候都可以通過用新的狀態(tài)行調(diào)用 header() 函數(shù)來覆蓋原先的。
HTTP狀態(tài)檢測(HTTP Header):
第二種特殊情況是以“Location:”標頭。它不只是把這個標頭發(fā)送回瀏覽器,它還將一個 REDIRECT(302)狀態(tài)碼返回給瀏覽器,除非之前已經(jīng)發(fā)出了某個 3xx 狀態(tài)碼。
<?php
header("Location: http://www.example.com/"); /* 重定向瀏覽器 */
/* 確保重定向后,后續(xù)代碼不會被執(zhí)行 */
exit;
?>
注: HTTP/1.1 標準需要一個絕對地址的 URI 做為 Location: 的參數(shù), 但有一些客戶端支持相對 URI。通??梢允褂?$_SERVER['HTTP_HOST']、$_SERVER['PHP_SELF'] 及 dirname() 函數(shù)來自己從相對 URI 產(chǎn)生出絕對 URI:
<?php
header("Location: http://%22.$_server['http_host'/]
. rtrim(dirname($_SERVER['PHP_SELF']), '/\\')
."/".$relative_url);
?>
注: 即使啟用了 session.use_trans_sid,Session ID 也不會隨著 Location 頭信息被傳遞。必須手工用 SID 常量來傳遞。
PHP 腳本通常會產(chǎn)生一些動態(tài)內(nèi)容,這些內(nèi)容必須不被瀏覽器或代理服務(wù)器緩存。很多代理服務(wù)器和瀏覽器都可以被下面的方法禁止緩存:
<?php
header("Cache-Control: no-cache, must-revalidate"); // HTTP/1.1
header("Expires: Mon, 26 Jul 1997 05:00:00 GMT"); // 過去的時間
?>
注: 可能會發(fā)現(xiàn)即使不輸出上面所有的代碼,網(wǎng)頁也沒有被緩沖。用戶有很多選項可以設(shè)置來改變?yōu)g覽器的默認緩存行為。通過發(fā)送上述標頭,應(yīng)該可以覆蓋任何可以導致腳本頁面被緩存的設(shè)置。
另外,當使用了 session 時,利用 session_cache_limiter() 函數(shù)和 session.cache_limiter 選項可以用來自動產(chǎn)生正確的緩存相關(guān)標頭。
要記住 header() 必須在任何實際輸出之前調(diào)用,不論是來自普通的 HTML 標記,空行或者 PHP。有一個常見錯誤就是在通過 include(),require() 或一些其它的文件存取類函數(shù)讀取代碼時,有一些空格或者空行在調(diào)用 header() 之前被發(fā)送了出去。同樣在一個單獨的 PHP/HTML 文件中這個錯誤也很普遍。
<html>
<?php
/* 這將產(chǎn)生一個錯誤,因為在調(diào) header()
* 之前已經(jīng)輸出了東西 */
header('Location: http://www.example.com/');
?>
注: 自 PHP 4 起,可以通過一些輸出緩沖函數(shù)來解決這個問題。代價是把所有向瀏覽器的輸出都緩存在服務(wù)器,直到下命令發(fā)送它們。可以在代碼中使用 ob_start() 及 ob_end_flush() 來實現(xiàn)這樣的功能,或者通過修改 php.ini 中的 output_buffering 配置選項來實現(xiàn),也可以通過修改服務(wù)器配置文件來實現(xiàn)。
附header()兩個常用用法:
//設(shè)置頁面編碼:
header('Content-Type:text/html;charset=gb2312');
//調(diào)整頁面:
header('location:http://www.baidu.com');
header實現(xiàn)404無法找到頁面
復制代碼 代碼如下:
Header("HTTP/1.1 404 Not Found");
針對apache配置中的ErrorDocument 404 /404.php功能,把nginx配置中的
復制代碼 代碼如下:
error_page 404 /404.php;
改成
復制代碼 代碼如下:
error_page 404 = /404.php;
php heager 301
復制代碼 代碼如下:
<?php
header("HTTP/1.1 301 Moved Permanently");
header ("Location:$url");
?>
不管頁面有多少header,它會執(zhí)行最后一個,不過是有條件的,例如:
header('Location:http://www.dbjr.com.cn');
header('Location:http://www.g.cn');
header('Location:http://www.baidu.com');
這個就會跳到百度
header('Location:http://www.dbjr.com.cn');echo '烈火網(wǎng);
header('Location:http://www.g.cn');
header('Location:http://www.baidu.com');
這個就會跳到google
下面是關(guān)于header函數(shù)的詳細使用說明
一、作用:
~~~~~~~~~
PHP只是以HTTP協(xié)議將HTML文檔的標頭送到瀏覽器,告訴瀏覽器具體怎么處理這個頁面,至于傳送的內(nèi)容則需要熟悉一下HTTP協(xié)議了,與PHP無關(guān)了
傳統(tǒng)的標頭一定包含下面三種標頭之一,并只能出現(xiàn)一次。
Location: xxxx:yyyy/zzzz
Content-Type: xxxx/yyyy
Status: nnn xxxxxx
二、先來了解一下HTTP協(xié)議的運作方式
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
HTTP協(xié)議是基于請求/響應(yīng)范式的。一個客戶機與服務(wù)器建立連接后,發(fā)送一個請求給服務(wù)器,請求方式的格式為,統(tǒng)一資源標識符、協(xié)議版本號,后邊是 MIME信息包括請求修飾符、客戶機信息和可能的內(nèi)容。服務(wù)器接到請求后,給予相應(yīng)的響應(yīng)信息,其格式為一個狀態(tài)行包括信息的協(xié)議版本號、一個成功或錯誤的代碼,后邊是MIME信息包括服務(wù)器信息、實體信息和可能的內(nèi)容。
它分四個過程,在HTTP協(xié)議中,服務(wù)端是指提供HTTP服務(wù)的部分,客戶端是指你使用的瀏覽器或者下載工具等等。在通訊時,由客戶端發(fā)出請求連接,服務(wù)端建立連接;然后,客戶端發(fā)出HTTP請求(Request),服務(wù)端返回響應(yīng)信息(Respond),由此完成一個HTTP操作。
三、HTTP協(xié)議狀態(tài)碼表示的意思
~~~~~~~~~~~~~~~~~~~~~~~~~~~~
1×× 保留
2×× 表示請求成功地接收
3×× 為完成請求客戶需進一步細化請求
4×× 客戶錯誤
5×× 服務(wù)器錯誤
四、操作實例:
~~~~~~~~~~~~~
<1> 重定向功能,這種最常見
<?php
Header("Location: http://www.dbjr.com.cn/");
?>
<2> 強制用戶每次訪問這個頁面時獲取最新資料,而不是使用存在客戶端的緩存。
代碼
<?php
//告訴瀏覽器此頁面的過期時間(用格林威治時間表示),只要是已經(jīng)過去的日期即可。
header("Expires: Mon, 26 Jul 1970 05:00:00 GMT");
//告訴瀏覽器此頁面的最后更新日期(用格林威治時間表示)也就是當天,目的就是強迫瀏覽器獲取最新資料
header("Last-Modified: " . gmdate("D, d M Y H:i:s") . "GMT");
//告訴客戶端瀏覽器不使用緩存
header("Cache-Control: no-cache, must-revalidate");
//參數(shù)(與以前的服務(wù)器兼容),即兼容HTTP1.0協(xié)議
header("Pragma: no-cache");
//輸出MIME類型
header("Content-type: application/file");
//文件長度
header("Content-Length: 227685");
//接受的范圍單位
header("Accept-Ranges: bytes");
//缺省時文件保存對話框中的文件名稱
header("Content-Disposition: attachment; filename=$filename");
?>
<3> 輸出狀態(tài)值到瀏覽器,主要用于訪問權(quán)限控制
<?php
header('HTTP/1.1 401 Unauthorized');
header('status: 401 Unauthorized');
?>
比如要限制一個用戶不能訪問該頁,則可設(shè)置狀態(tài)為404,如下所示,這樣瀏覽器就顯示為即該頁不存在
<?php
header('HTTP/1.1 404 Not Found');
header("status: 404 Not Found");
?>
注意: 傳統(tǒng)的標頭一定包含下面三種標頭之一,并只能出現(xiàn)一次。 Content-Type: xxxx/yyyy Location: xxxx:yyyy/zzzz Status: nnn xxxxxx 在新的多型標頭規(guī)格 (Multipart MIME) 方可以出現(xiàn)二次以上。
使用范例
范例一: 本例使瀏覽器重定向到 PHP 的官方網(wǎng)站。
Header("Location: http://www.dbjr.com.cn/"); exit;
范例二: 要使用者每次都能得到最新的資料,而不是 Proxy 或 cache 中的資料,可以使用下列的標頭
header("Expires: Mon, 26 Jul 1997 05:00:00 GMT");
header("Last-Modified: " . gmdate("D, d M Y H:i:s") . "GMT"); header("Cache-Control: no-cache, must-revalidate");
header("Pragma: no-cache");
范例三: 讓使用者的瀏覽器出現(xiàn)找不到檔案的信息。
header("Status: 404 Not Found");
范例四:讓使用者下載檔案。
header("Content-type: application/x-gzip");
header("Content-Disposition: attachment; filename=文件名");
header("Content-Description: PHP3 Generated Data");
header -- 發(fā)送一個原始 HTTP 標頭說明
void header ( string string [, bool replace [, int http_response_code]] )
header() 函數(shù)用來發(fā)送一個原始 HTTP 標頭。有關(guān) HTTP 標頭的更多內(nèi)容見 HTTP/1.1 規(guī)范。
可選參數(shù) replace 指明是替換掉前一條類似的標頭還是增加一條相同類型的標頭。默認為替換,但如果將其設(shè)為 FALSE 則可以強制發(fā)送多個同類標頭。例如:
<?php
header('WWW-Authenticate: Negotiate');
header('WWW-Authenticate: NTLM', false);
?>
第二個可選參數(shù) http_response_code 強制將 HTTP 響應(yīng)代碼設(shè)為指定值(此參數(shù)是 PHP 4.3.0 新加的)。
有兩種特殊的 header 調(diào)用。第一種是標頭以字符串“HTTP/”(大小寫不重要)開頭的,可以用來確定要發(fā)送的 HTTP 狀態(tài)碼。例如,如果配置了 Apache 用 PHP 來處理找不到文件的錯誤處理請求(使用 ErrorDocument 指令),需要確保腳本產(chǎn)生了正確的狀態(tài)碼。
<?php
header("HTTP/1.0 404 Not Found")
?>
注: HTTP 狀態(tài)碼標頭行總是第一個被發(fā)送到客戶端,而并不管實際的 header() 調(diào)用是否是第一個。除非 HTTP 標頭已經(jīng)發(fā)送出去,任何時候都可以通過用新的狀態(tài)行調(diào)用 header() 函數(shù)來覆蓋原先的。
HTTP狀態(tài)檢測(HTTP Header):
第二種特殊情況是以“Location:”標頭。它不只是把這個標頭發(fā)送回瀏覽器,它還將一個 REDIRECT(302)狀態(tài)碼返回給瀏覽器,除非之前已經(jīng)發(fā)出了某個 3xx 狀態(tài)碼。
<?php
header("Location: http://www.example.com/"); /* 重定向瀏覽器 */
/* 確保重定向后,后續(xù)代碼不會被執(zhí)行 */
exit;
?>
注: HTTP/1.1 標準需要一個絕對地址的 URI 做為 Location: 的參數(shù), 但有一些客戶端支持相對 URI。通??梢允褂?$_SERVER['HTTP_HOST']、$_SERVER['PHP_SELF'] 及 dirname() 函數(shù)來自己從相對 URI 產(chǎn)生出絕對 URI:
<?php
header("Location: http://%22.$_server['http_host'/]
. rtrim(dirname($_SERVER['PHP_SELF']), '/\\')
."/".$relative_url);
?>
注: 即使啟用了 session.use_trans_sid,Session ID 也不會隨著 Location 頭信息被傳遞。必須手工用 SID 常量來傳遞。
PHP 腳本通常會產(chǎn)生一些動態(tài)內(nèi)容,這些內(nèi)容必須不被瀏覽器或代理服務(wù)器緩存。很多代理服務(wù)器和瀏覽器都可以被下面的方法禁止緩存:
<?php
header("Cache-Control: no-cache, must-revalidate"); // HTTP/1.1
header("Expires: Mon, 26 Jul 1997 05:00:00 GMT"); // 過去的時間
?>
注: 可能會發(fā)現(xiàn)即使不輸出上面所有的代碼,網(wǎng)頁也沒有被緩沖。用戶有很多選項可以設(shè)置來改變?yōu)g覽器的默認緩存行為。通過發(fā)送上述標頭,應(yīng)該可以覆蓋任何可以導致腳本頁面被緩存的設(shè)置。
另外,當使用了 session 時,利用 session_cache_limiter() 函數(shù)和 session.cache_limiter 選項可以用來自動產(chǎn)生正確的緩存相關(guān)標頭。
要記住 header() 必須在任何實際輸出之前調(diào)用,不論是來自普通的 HTML 標記,空行或者 PHP。有一個常見錯誤就是在通過 include(),require() 或一些其它的文件存取類函數(shù)讀取代碼時,有一些空格或者空行在調(diào)用 header() 之前被發(fā)送了出去。同樣在一個單獨的 PHP/HTML 文件中這個錯誤也很普遍。
<html>
<?php
/* 這將產(chǎn)生一個錯誤,因為在調(diào) header()
* 之前已經(jīng)輸出了東西 */
header('Location: http://www.example.com/');
?>
注: 自 PHP 4 起,可以通過一些輸出緩沖函數(shù)來解決這個問題。代價是把所有向瀏覽器的輸出都緩存在服務(wù)器,直到下命令發(fā)送它們。可以在代碼中使用 ob_start() 及 ob_end_flush() 來實現(xiàn)這樣的功能,或者通過修改 php.ini 中的 output_buffering 配置選項來實現(xiàn),也可以通過修改服務(wù)器配置文件來實現(xiàn)。
附header()兩個常用用法:
//設(shè)置頁面編碼:
header('Content-Type:text/html;charset=gb2312');
//調(diào)整頁面:
header('location:http://www.baidu.com');
您可能感興趣的文章:
- php 定義404頁面的實現(xiàn)代碼
- ThinkPHP3.2.3框架實現(xiàn)的空模塊、空控制器、空操作,跳轉(zhuǎn)到錯誤404頁面圖文詳解
- thinkphp框架下404頁面設(shè)置 僅三步
- ThinkPHP 404頁面的設(shè)置方法
- ThinkPHP訪問不存在的模塊跳轉(zhuǎn)到404頁面的方法
- php使用curl判斷網(wǎng)頁404(不存在)的方法
- php 404錯誤頁面實現(xiàn)代碼
- 用php來改寫404錯誤頁讓你的頁面更友好
- php 智能404跳轉(zhuǎn)代碼,適合換域名沒改變目錄的網(wǎng)站
- thinkPHP5框架設(shè)置404、403等http狀態(tài)頁面的方法
- PHP統(tǒng)計nginx訪問日志中的搜索引擎抓取404鏈接頁面路徑
- php簡單檢測404頁面的方法示例
相關(guān)文章
thinkPHP模板中for循環(huán)與switch語句用法示例
這篇文章主要介紹了thinkPHP模板中for循環(huán)與switch語句用法,結(jié)合實例形式分析了for循環(huán)與switch語句的具體功能、定義與具體使用技巧,需要的朋友可以參考下2016-11-11thinkPHP實現(xiàn)上傳圖片及生成縮略圖功能示例
這篇文章主要介紹了thinkPHP實現(xiàn)上傳圖片及生成縮略圖功能,結(jié)合實例形式分析了thinkPHP圖片上傳及縮略圖設(shè)置、生成、保存、數(shù)據(jù)庫寫入等相關(guān)操作技巧,需要的朋友可以參考下2017-10-10PHP多線程批量采集下載美女圖片的實現(xiàn)代碼(續(xù))
之前寫過一篇《PHP批量采集下載美女圖片》文中主要采用file_get_content做采集圖片,今天發(fā)現(xiàn)采集了400張圖片 居然需要70分鐘以上,真是難以忍受2013-06-06Yii2框架操作數(shù)據(jù)庫的方法分析【以mysql為例】
這篇文章主要介紹了Yii2框架操作數(shù)據(jù)庫的方法,結(jié)合實例形式分析了Yii2框架配置、連接mysql數(shù)據(jù)庫及執(zhí)行SQL進行增刪改查等相關(guān)操作技巧,需要的朋友可以參考下2019-05-05PHPStorm 2020.1 調(diào)試 Nodejs的多種方法詳解
這篇文章主要介紹了PHPSTORM 2020.1 調(diào)試 Nodejs的多種方法詳解,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-09