程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> php中header的用法

php中header的用法

編輯:PHP綜合
header的用法

header()函數的作用是:發送一個原始 HTTP 標頭[Http Header]到客戶端。
標頭 (header) 是服務器以 HTTP 協義傳 Html 資料到浏覽器前所送出的字串,在標頭
與 Html 文件之間尚需空一行分隔。有關 HTTP 的詳細說明,可以參 RFC 2068 官方文件
(http://www.w3.org/Protocols/rfc2068/rfc2068)。
PHP 中送回 Html 資料前,需先 傳完所有的標頭。

使用范例

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

<?PHP
Header("Location: http://www.PHP.Net";);
exit;   //在每個重定向之後都必須加上“exit",避免發生錯誤後,繼續執行。
?>
<?PHP
/**
@title:PHP定時跳轉
@功能:等待指定的時間,然後再跳轉到指定頁面(代替Html meta方式)
*/
header("refresh:3;url=http://axgle.za.Net");
print('正在加載,請稍等...<br>三秒後自動跳轉~~~');
/*
補充說明:
若等待時間為0,則與header("location:")等效。
*/
header重定向 就等價於替用戶在地址欄輸入url
?>  

范例二:禁止頁面在IE中緩存

要使用者每次都能得到最新的資料,而不是 Proxy 或 cache 中的資料,可以使用下列的標頭

<?PHP
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-store, no-cache, must-revalidate'
);
header( 'Cache-Control: post-check=0, pre-check=0', false
);
header( 'Pragma: no-cache' );
//兼容http1.0和https
?> CacheControl = no-cache
Pragma=no-cache
Expires = -1

Expires是個好東東,如果服務器上的網頁經常變化,就把它設置為-1,表示立即過期。如果一個網頁每天凌晨1點更新,可以把Expires設置為第二天的凌晨1點。
當HTTP1.1服務器指定CacheControl = no-cache時,浏覽器就不會緩存該網頁。

舊式 HTTP 1.0 服務器不能使用 Cache-Control 標題。所以為了向後兼容 HTTP 1.0 服務器,IE使用Pragma:no-cache 標題對 HTTP 提供特殊支持。
如果客戶端通過安全連接 (https://) 與服務器通訊,且服務器在響應中返回 Pragma:no-cache 標題,則 Internet Explorer 不會緩存此響應。
注意:Pragma:no-cache 僅當在安全連接中使用時才防止緩存,如果在非安全頁中使用,處理方式與 Expires:-1 相同,該頁將被緩存,但被標記為立即過期。

http-equiv meta標記:

在html頁面中可以用http-equiv meta來標記指定的http消息頭部。老版本的IE可能不支持Html meta標記,所以最好使用http消息頭部來禁用緩存。

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

網上很多資料這樣寫:PHP的函數header()可以向浏覽器發送Status標頭,
如 header(”Status: 404 Not Found”)。
但是我發現實際上浏覽器返回的響應卻是:

HTTP/1.x 200 OK
Date: Thu, 03 Aug 2006 07:49:11 GMT
Server: apache/2.0.55 (Win32) PHP/5.0.5
X-Powered-By: PHP/5.0.5
Status: 404 Not Found
Content-Length: 0
Keep-Alive: timeout=15, max=98
Connection: Keep-Alive
Content-Type: text/Html

查了一些資料,正確的寫法是:
header(”http/1.1 404 Not Found”);

第一部分為HTTP協議的版本(HTTP-Version);第二部分為狀態代碼(Status);第三部分為原因短語(Reason-Phrase)。

范例四:讓使用者下載檔案( 隱藏文件的位置 )

Html標簽 就可以實現普通文件下載。如果為了保密文件,就不能把文件鏈接告訴別人,可以用header函數實現文件下載。
<?PHP
header("Content-type: application/x-gzip");
header("Content-Disposition: attachment; filename=文件名\");
header("Content-Description: PHP3 Generated Data");
?>

范例四:header函數前輸入內容

一般來說在header函數前不能輸出Html內容,類似的還有setcookIE() 和 session 函數,這些函數需要在輸出流中增加消息頭部信息。如果在header()執行之前有echo等語句,當後面遇到header()時,就會報出 “Warning: Cannot modify header information - headers already sent by ….”錯誤。就是說在這些函數的前面不能有任何文字、空行、回車等,而且最好在header()函數後加上exit()函數。例如下面的錯誤寫法,在兩個PHP代碼段之間有一個空行:

//some code here
?>
//這裡應該是一個空行
header(”http/1.1 403 Forbidden”);
exit();
?>

原因是:PHP腳本開始執行 時,它可以同時發送http消息頭部(標題)信息和主體信息. http消息頭部(來自 header() 或 SetCookIE() 函數)並不會立即發送,相反,它被保存到一個列表中. 這樣就可以允許你修改標題信息,包括缺省的標題(例如 Content-Type 標題).但是,一旦腳本發送了任何非標題的輸出(例如,使用 Html 或 print() 調用),那麼PHP就必須先發送完所有的Header,然後終止 HTTP header.而後繼續發送主體數據.從這時開始,任何添加或修改Header信息的試圖都是不允許的,並會發送上述的錯誤消息之一。

解決辦法:

修改php.ini打開緩存(output_buffering),或者在程序中使用緩存函數ob_start(),ob_end_flush()等。原理是:output_buffering被啟用時,在腳本發送輸出時,PHP並不發送HTTP header。相反,它將此輸出通過管道(pipe)輸入到動態增加的緩存中(只能在PHP 4.0中使用,它具有中央化的輸出機制)。你仍然可以修改/添加header,或者設置cookIE,因為header實際上並沒有發送。當全部腳本終止時,PHP將自動發送HTTP header到浏覽器,然後再發送輸出緩沖中的內容。

=================================================================
PHP 手冊實例應用

1:您可以使用heder命令,強制使浏覽器使用新鮮的內容(無緩存) 。
也可以給網址增加了一個唯一的編號,使其每次都讀取新的內容,避免緩存。
example:
<?
print "<img src='yourfile.jpg'>";   //通常讀取的是緩存文件
?>

<?
print "<img src='yourfile.jpg?".time()."'>";   //增加了唯一的編號,使浏覽器重新請求

w//print
"<img src='yourfile.jpg?".rand(100,999)."'>";
?>

2: 下面是個很好的函數,將圖片傳送給浏覽器顯示。
<?PHP
function PE_img_by_path($PE_imgpath = "")
{
    if (file_exists($PE_imgpath)) {
        $PE_imgarray = pathinfo($PE_imgpath);

        $iconcontent = file_get_contents($PE_imgpath);
        header("Content-type: image/" . $PE_imgarray["extension"]);
        header('Content-length: ' . strlen($iconcontent));
        echo $iconcontent;
        dIE(0);
    }
    return false;
}
?>
更多的實例:

<?PHP

// ok
header('HTTP/1.1 200 OK');

//設置一個404頭:
header('HTTP/1.1 404 Not Found');

//設置地址被永久的重定向
header('HTTP/1.1 301 Moved Permanently');

//轉到一個新地址
header('Location: http://www.example.org/');

//文件延遲轉向:
header('Refresh: 10; url=http://www.example.org/');
print 'You will be redirected in 10 seconds';

//當然,也可以使用Html語法實現
// <meta http-equiv="refresh" content="10;http://www.example.org/ />

// override X-Powered-By: PHP:
header('X-Powered-By: PHP/4.4.0');
header('X-Powered-By: Brain/0.6b');

//文檔語言
header('Content-language: en');

//告訴浏覽器最後一次修改時間
$time = time() - 60; // or filemtime($fn), etc
header('Last-ModifIEd: '.gmdate('D, d M Y H:i:s', $time).' GMT');

//告訴浏覽器文檔內容沒有發生改變
header('HTTP/1.1 304 Not ModifIEd');

//設置內容長度
header('Content-Length: 1234');

//設置為一個下載類型
header('Content-Type: application/octet-stream');
header('Content-Disposition: attachment; filename="example.zip"');
header('Content-Transfer-Encoding: binary');
// load the file to send:
readfile('example.zip');

// 對當前文檔禁用緩存
header('Cache-Control: no-cache, no-store, max-age=0, must-revalidate');
header('Expires: Mon, 26 Jul 1997 05:00:00 GMT'); // Date in the past
header('Pragma: no-cache');

//設置內容類型:
header('Content-Type: text/Html; charset=iso-8859-1');
header('Content-Type: text/Html; charset=utf-8');
header('Content-Type: text/plain'); //純文本格式
header('Content-Type: image/jpeg'); //JPG圖片
header('Content-Type: application/zip'); // ZIP文件
header('Content-Type: application/pdf'); // PDF文件
header('Content-Type: audio/mpeg'); // 音頻文件
header('Content-Type: application/x-shockwave-flash'); //Flash動畫

//顯示登陸對話框
header('HTTP/1.1 401 Unauthorized');
header('WWW-Authenticate: Basic realm="Top Secret"');
print 'Text that will be displayed if the user hits cancel or ';
print 'enters wrong login data';
?>

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