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

探討php中header的用法詳解

編輯:PHP綜合
 header() is used to send raw HTTP headers. See the HTTP/1.1 specification for more information on HTTP headers.

范例一:
復制代碼 代碼如下:
<?PHP
Header("Location: http://www.jb51.net";);
exit;//在每個重定向之後都必須加上“exit",避免發生錯誤後,繼續執行。
?>

復制代碼 代碼如下:
<?php
header("refresh:2;url=http://www.jb51.net");
echo "正在加載,請稍等...<br>三秒後自動跳轉至<a href="http://www.jb51.net" mce_href="http://www.jb51.net">百度</a>...";
?>

--------------------------------------------------------------------------------
范例二:禁止頁面在IE中緩存
使浏覽者每次都能得到最新的資料,而不是 Proxy 或 cache 中的資料:
復制代碼 代碼如下:
<?PHP
header( 'Expires: Fri, 4 Dec 2009 09: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="cs.jpg" mce_src="cs.jpg">";   //通常讀取的是緩存文件
?>
<?
print "<img src="cs.jpg?".time()."" mce_src="cs.jpg?".time()."">";   //增加了唯一的編號,使浏覽器重新請求
w//print "<img src="cs.jpg?".rand(100,999)."" mce_src="cs.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.baidu.com');
//文件延遲轉向:
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