程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> PHP header() 函數詳細說明(301、404等錯誤設置)

PHP header() 函數詳細說明(301、404等錯誤設置)

編輯:關於PHP編程

       如果您剛剛開始學習PHP,可能有許多函數需要研究,今天我們就來學習一下PHP Header()的使用方法,更多的使用說明,請您參照PHP中文手冊,下面是關於header函數的詳細使用說明

      不管頁面有多少header,它會執行最後一個,不過是有條件的,例如:

      header('Location:http://www.liehuo.net');

      header('Location:http://www.g.cn');

      header('Location:http://www.baidu.com');

      這個就會跳到百度

      header('Location:http://www.liehuo.net');echo '烈火網;

      header('Location:http://www.g.cn');

      header('Location:http://www.baidu.com');

      這個就會跳到google

      下面是關於header函數的詳細使用說明

      一、作用:

      ~~~~~~~~~

      PHP只是以HTTP協議將HTML文檔的標頭送到浏覽器,告訴浏覽器具體怎麼處理這個頁面,至於傳送的內容則需要熟悉一下HTTP協議了,與PHP無關了

      傳統的標頭一定包含下面三種標頭之一,並只能出現一次。

      Location: xxxx:yyyy/zzzz

      Content-Type: xxxx/yyyy

      Status: nnn xxxxxx

      二、先來了解一下HTTP協議的運作方式

      ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

      HTTP協議是基於請求/響應范式的。一個客戶機與服務器建立連接後,發送一個請求給服務器,請求方式的格式為,統一資源標識符、協議版本號,後邊是 MIME信息包括請求修飾符、客戶機信息和可能的內容。服務器接到請求後,給予相應的響應信息,其格式為一個狀態行包括信息的協議版本號、一個成功或錯誤的代碼,後邊是MIME信息包括服務器信息、實體信息和可能的內容。

      它分四個過程,在HTTP協議中,服務端是指提供HTTP服務的部分,客戶端是指你使用的浏覽器或者下載工具等等。在通訊時,由客戶端發出請求連接,服務端建立連接;然後,客戶端發出HTTP請求(Request),服務端返回響應信息(Respond),由此完成一個HTTP操作。

      HTTP狀態檢測(HTTP Header):http://www.veryhuo.com/tools/http_header.php

      三、HTTP協議狀態碼表示的意思

      ~~~~~~~~~~~~~~~~~~~~~~~~~~~~

      1××  保留

      2××  表示請求成功地接收

      3××  為完成請求客戶需進一步細化請求

      4××  客戶錯誤

      5××  服務器錯誤

      四、操作實例:

      ~~~~~~~~~~~~~

      <1> 重定向功能,這種最常見

      Header("Location: http://www.liehuo.net/");

      ?>

      <2> 強制用戶每次訪問這個頁面時獲取最新資料,而不是使用存在客戶端的緩存。

      代碼

      //告訴浏覽器此頁面的過期時間(用格林威治時間表示),只要是已經過去的日期即可。

      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");

      //參數(與以前的服務器兼容),即兼容HTTP1.0協議

      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> 輸出狀態值到浏覽器,主要用於訪問權限控制

      header('HTTP/1.1 401 Unauthorized');

      header('status: 401 Unauthorized');

      ?>

      比如要限制一個用戶不能訪問該頁,則可設置狀態為404,如下所示,這樣浏覽器就顯示為即該頁不存在

      header('HTTP/1.1 404 Not Found');

      header("status: 404 Not Found");

      ?>

      注意: 傳統的標頭一定包含下面三種標頭之一,並只能出現一次。 Content-Type: xxxx/yyyy Location: xxxx:yyyy/zzzz Status: nnn xxxxxx 在新的多型標頭規格 (Multipart MIME) 方可以出現二次以上。

      使用范例

      范例一: 本例使浏覽器重定向到 PHP 的官方網站。

      Header("Location: http://www.liehuo.net/"); 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");

      范例三: 讓使用者的浏覽器出現找不到檔案的信息。

      header("Status: 404 Not Found");

      范例四:讓使用者下載檔案。

      header("Content-type: application/x-gzip");

      header("Content-Disposition: attachment; filename=文件名");

      header("Content-Description: PHP3 Generated Data");

      header -- 發送一個原始 HTTP 標頭說明

      void header ( string string [, bool replace [, int http_response_code]] )

      header() 函數用來發送一個原始 HTTP 標頭。有關 HTTP 標頭的更多內容見 HTTP/1.1 規范。

      可選參數 replace 指明是替換掉前一條類似的標頭還是增加一條相同類型的標頭。默認為替換,但如果將其設為 FALSE 則可以強制發送多個同類標頭。例如:

      header('WWW-Authenticate: Negotiate');

      header('WWW-Authenticate: NTLM', false);

      ?>

      第二個可選參數 http_response_code 強制將 HTTP 響應代碼設為指定值(此參數是 PHP 4.3.0 新加的)。

      有兩種特殊的 header 調用。第一種是標頭以字符串“HTTP/”(大小寫不重要)開頭的,可以用來確定要發送的 HTTP 狀態碼。例如,如果配置了 Apache 用 PHP 來處理找不到文件的錯誤處理請求(使用 ErrorDocument 指令),需要確保腳本產生了正確的狀態碼。

      header("HTTP/1.0 404 Not Found")

      ?>

      注: HTTP 狀態碼標頭行總是第一個被發送到客戶端,而並不管實際的 header() 調用是否是第一個。除非 HTTP 標頭已經發送出去,任何時候都可以通過用新的狀態行調用 header() 函數來覆蓋原先的。

      HTTP狀態檢測(HTTP Header):http://www.veryhuo.com/tools/http_header.php

      第二種特殊情況是以“Location:”標頭。它不只是把這個標頭發送回浏覽器,它還將一個 REDIRECT(302)狀態碼返回給浏覽器,除非之前已經發出了某個 3xx 狀態碼。

      header("Location: http://www.example.com/"); /* 重定向浏覽器 */

      /* 確保重定向後,後續代碼不會被執行 */

      exit;

      ?>

      注: HTTP/1.1 標准需要一個絕對地址的 URI 做為 Location: 的參數, 但有一些客戶端支持相對 URI。通常可以使用 $_SERVER['HTTP_HOST']、$_SERVER['PHP_SELF'] 及 dirname() 函數來自己從相對 URI 產生出絕對 URI:

      header("Location: http://%22.$_server['http_host'/]

      . rtrim(dirname($_SERVER['PHP_SELF']), '/')

      ."/".$relative_url);

      ?>

      注: 即使啟用了 session.use_trans_sid,Session ID 也不會隨著 Location 頭信息被傳遞。必須手工用 SID 常量來傳遞。

      PHP 腳本通常會產生一些動態內容,這些內容必須不被浏覽器或代理服務器緩存。很多代理服務器和浏覽器都可以被下面的方法禁止緩存:

      header("Cache-Control: no-cache, must-revalidate"); // HTTP/1.1

      header("Expires: Mon, 26 Jul 1997 05:00:00 GMT"); // 過去的時間

      ?>

      注: 可能會發現即使不輸出上面所有的代碼,網頁也沒有被緩沖。用戶有很多選項可以設置來改變浏覽器的默認緩存行為。通過發送上述標頭,應該可以覆蓋任何可以導致腳本頁面被緩存的設置。

      另外,當使用了 session 時,利用 session_cache_limiter() 函數和 session.cache_limiter 選項可以用來自動產生正確的緩存相關標頭。

      要記住 header() 必須在任何實際輸出之前調用,不論是來自普通的 HTML 標記,空行或者 PHP。有一個常見錯誤就是在通過 include(),require() 或一些其它的文件存取類函數讀取代碼時,有一些空格或者空行在調用 header() 之前被發送了出去。同樣在一個單獨的 PHP/HTML 文件中這個錯誤也很普遍。

      /* 這將產生一個錯誤,因為在調 header()

      * 之前已經輸出了東西 */

      header('Location: http://www.example.com/');

      ?>

      注: 自 PHP 4 起,可以通過一些輸出緩沖函數來解決這個問題。代價是把所有向浏覽器的輸出都緩存在服務器,直到下命令發送它們。可以在代碼中使用 ob_start() 及 ob_end_flush() 來實現這樣的功能,或者通過修改 php.ini 中的 output_buffering 配置選項來實現,也可以通過修改服務器配置文件來實現。

      附header()兩個常用用法:

      //設置頁面編碼:

      header('Content-Type:text/html;charset=gb2312');

      //調整頁面:

      header

      如果您剛剛開始學習PHP,可能有許多函數需要研究,今天我們就來學習一下PHP Header()的使用方法,更多的使用說明,請您參照PHP中文手冊,下面是關於header函數的詳細使用說明

      不管頁面有多少header,它會執行最後一個,不過是有條件的,例如:

      header('Location:http://www.liehuo.net');

      header('Location:http://www.g.cn');

      header('Location:http://www.baidu.com');

      這個就會跳到百度

      header('Location:http://www.liehuo.net');echo '烈火網;

      header('Location:http://www.g.cn');

      header('Location:http://www.baidu.com');

      這個就會跳到google

      下面是關於header函數的詳細使用說明

      一、作用:

      ~~~~~~~~~

      PHP只是以HTTP協議將HTML文檔的標頭送到浏覽器,告訴浏覽器具體怎麼處理這個頁面,至於傳送的內容則需要熟悉一下HTTP協議了,與PHP無關了

      傳統的標頭一定包含下面三種標頭之一,並只能出現一次。

      Location: xxxx:yyyy/zzzz

      Content-Type: xxxx/yyyy

      Status: nnn xxxxxx

      二、先來了解一下HTTP協議的運作方式

      ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

      HTTP協議是基於請求/響應范式的。一個客戶機與服務器建立連接後,發送一個請求給服務器,請求方式的格式為,統一資源標識符、協議版本號,後邊是 MIME信息包括請求修飾符、客戶機信息和可能的內容。服務器接到請求後,給予相應的響應信息,其格式為一個狀態行包括信息的協議版本號、一個成功或錯誤的代碼,後邊是MIME信息包括服務器信息、實體信息和可能的內容。

      它分四個過程,在HTTP協議中,服務端是指提供HTTP服務的部分,客戶端是指你使用的浏覽器或者下載工具等等。在通訊時,由客戶端發出請求連接,服務端建立連接;然後,客戶端發出HTTP請求(Request),服務端返回響應信息(Respond),由此完成一個HTTP操作。

      HTTP狀態檢測(HTTP Header):http://www.veryhuo.com/tools/http_header.php

      三、HTTP協議狀態碼表示的意思

      ~~~~~~~~~~~~~~~~~~~~~~~~~~~~

      1××  保留

      2××  表示請求成功地接收

      3××  為完成請求客戶需進一步細化請求

      4××  客戶錯誤

      5××  服務器錯誤

      四、操作實例:

      ~~~~~~~~~~~~~

      <1> 重定向功能,這種最常見

      Header("Location: http://www.liehuo.net/");

      ?>

      <2> 強制用戶每次訪問這個頁面時獲取最新資料,而不是使用存在客戶端的緩存。

      代碼

      //告訴浏覽器此頁面的過期時間(用格林威治時間表示),只要是已經過去的日期即可。

      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");

      //參數(與以前的服務器兼容),即兼容HTTP1.0協議

      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> 輸出狀態值到浏覽器,主要用於訪問權限控制

      header('HTTP/1.1 401 Unauthorized');

      header('status: 401 Unauthorized');

      ?>

      比如要限制一個用戶不能訪問該頁,則可設置狀態為404,如下所示,這樣浏覽器就顯示為即該頁不存在

      header('HTTP/1.1 404 Not Found');

      header("status: 404 Not Found");

      ?>

      注意: 傳統的標頭一定包含下面三種標頭之一,並只能出現一次。 Content-Type: xxxx/yyyy Location: xxxx:yyyy/zzzz Status: nnn xxxxxx 在新的多型標頭規格 (Multipart MIME) 方可以出現二次以上。

      使用范例

      范例一: 本例使浏覽器重定向到 PHP 的官方網站。

      Header("Location: http://www.liehuo.net/"); 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");

      范例三: 讓使用者的浏覽器出現找不到檔案的信息。

      header("Status: 404 Not Found");

      范例四:讓使用者下載檔案。

      header("Content-type: application/x-gzip");

      header("Content-Disposition: attachment; filename=文件名");

      header("Content-Description: PHP3 Generated Data");

      header -- 發送一個原始 HTTP 標頭說明

      void header ( string string [, bool replace [, int http_response_code]] )

      header() 函數用來發送一個原始 HTTP 標頭。有關 HTTP 標頭的更多內容見 HTTP/1.1 規范。

      可選參數 replace 指明是替換掉前一條類似的標頭還是增加一條相同類型的標頭。默認為替換,但如果將其設為 FALSE 則可以強制發送多個同類標頭。例如:

      header('WWW-Authenticate: Negotiate');

      header('WWW-Authenticate: NTLM', false);

      ?>

      第二個可選參數 http_response_code 強制將 HTTP 響應代碼設為指定值(此參數是 PHP 4.3.0 新加的)。

      有兩種特殊的 header 調用。第一種是標頭以字符串“HTTP/”(大小寫不重要)開頭的,可以用來確定要發送的 HTTP 狀態碼。例如,如果配置了 Apache 用 PHP 來處理找不到文件的錯誤處理請求(使用 ErrorDocument 指令),需要確保腳本產生了正確的狀態碼。

      header("HTTP/1.0 404 Not Found")

      ?>

      注: HTTP 狀態碼標頭行總是第一個被發送到客戶端,而並不管實際的 header() 調用是否是第一個。除非 HTTP 標頭已經發送出去,任何時候都可以通過用新的狀態行調用 header() 函數來覆蓋原先的。

      HTTP狀態檢測(HTTP Header):http://www.veryhuo.com/tools/http_header.php

      第二種特殊情況是以“Location:”標頭。它不只是把這個標頭發送回浏覽器,它還將一個 REDIRECT(302)狀態碼返回給浏覽器,除非之前已經發出了某個 3xx 狀態碼。

      header("Location: http://www.example.com/"); /* 重定向浏覽器 */

      /* 確保重定向後,後續代碼不會被執行 */

      exit;

      ?>

      注: HTTP/1.1 標准需要一個絕對地址的 URI 做為 Location: 的參數, 但有一些客戶端支持相對 URI。通常可以使用 $_SERVER['HTTP_HOST']、$_SERVER['PHP_SELF'] 及 dirname() 函數來自己從相對 URI 產生出絕對 URI:

      header("Location: http://%22.$_server['http_host'/]

      . rtrim(dirname($_SERVER['PHP_SELF']), '/')

      ."/".$relative_url);

      ?>

      注: 即使啟用了 session.use_trans_sid,Session ID 也不會隨著 Location 頭信息被傳遞。必須手工用 SID 常量來傳遞。

      PHP 腳本通常會產生一些動態內容,這些內容必須不被浏覽器或代理服務器緩存。很多代理服務器和浏覽器都可以被下面的方法禁止緩存:

      header("Cache-Control: no-cache, must-revalidate"); // HTTP/1.1

      header("Expires: Mon, 26 Jul 1997 05:00:00 GMT"); // 過去的時間

      ?>

      注: 可能會發現即使不輸出上面所有的代碼,網頁也沒有被緩沖。用戶有很多選項可以設置來改變浏覽器的默認緩存行為。通過發送上述標頭,應該可以覆蓋任何可以導致腳本頁面被緩存的設置。

      另外,當使用了 session 時,利用 session_cache_limiter() 函數和 session.cache_limiter 選項可以用來自動產生正確的緩存相關標頭。

      要記住 header() 必須在任何實際輸出之前調用,不論是來自普通的 HTML 標記,空行或者 PHP。有一個常見錯誤就是在通過 include(),require() 或一些其它的文件存取類函數讀取代碼時,有一些空格或者空行在調用 header() 之前被發送了出去。同樣在一個單獨的 PHP/HTML 文件中這個錯誤也很普遍。

      /* 這將產生一個錯誤,因為在調 header()

      * 之前已經輸出了東西 */

      header('Location: http://www.example.com/');

      ?>

      注: 自 PHP 4 起,可以通過一些輸出緩沖函數來解決這個問題。代價是把所有向浏覽器的輸出都緩存在服務器,直到下命令發送它們。可以在代碼中使用 ob_start() 及 ob_end_flush() 來實現這樣的功能,或者通過修改 php.ini 中的 output_buffering 配置選項來實現,也可以通過修改服務器配置文件來實現。

      附header()兩個常用用法:

      //設置頁面編碼:

      header('Content-Type:text/html;charset=gb2312');

      //調整頁面:

      header

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved