首頁  >  文章  >  後端開發  >  header location頁面跳轉失敗的原因詳解

header location頁面跳轉失敗的原因詳解

伊谢尔伦
伊谢尔伦原創
2018-05-18 10:47:209068瀏覽

http頭訊息
頭訊息的作用很多,最主要的有下面幾個:
#1、跳到
當瀏覽器接受到頭訊息中的Location: xxxx 後,就會自動跳到xxxx 指向的URL位址,這點有點類似用js 寫跳轉。但是這個跳轉只有瀏覽器知道,不管體內容裡有沒有東西,使用者都看不到。
範例:header("Location: http://www.php.cn/");
2、指定網頁的內容
同樣一個XML文件,如果頭資訊中指定:Content-type: application/xml 的話,瀏覽器會將其依照XML檔案格式解析。但是,如果在頭資訊中是:Content-type: text/xml 的話,瀏覽器就會將其視為存文本解析。 (瀏覽器不是按照副檔名解析檔案的)
範例:header('Content-type: application/pdf');
3、附件
不知道大家有沒有註意,有些時候在一些網站下載東西,點下載連接以後,結果瀏覽器將這個附件當成網頁打開了,裡面顯示的都是亂碼,這個問題也和頭信息有關。有時候瀏覽器會根據Content-type 來判斷是開啟還是儲存,這樣有時就會判斷錯誤(主要是網站設計者忘記寫Content-type)。其實,還有一個可以來指定該內容為附件、需要保存,這就是:Content-Disposition: attachment; filename="xxxxx"#​​##範例:header('Content-Disposition: attachment; filename="downloaded.pdf "');
      //開啟文件,並輸出
      readfile('original.pdf');
HTTP協定狀態碼
1×  #  
2××  表示請求成功地接收  
3××  為完成請求客戶需進一步細化請求  
4××  客戶錯誤  
5××  伺服器錯誤  

語法:
##

header(string,replace,http_response_code)

#
   <?php 
      header("Location: http://www.php.cn/");
      exit;
   ?>

參數

string:必需。規定要傳送的報頭
字串replace:可選。指示該報頭是否替換先前的報頭,或新增第二個報頭。預設是 true(替換)。 false(允許相同類型的多個報頭)。
http_response_code:可選。把 HTTP 回應碼強制為指定的值。 (PHP 4 以及更高版本可用)
例1:
重定向網頁

   <?php  
       //告诉浏览器此页面的过期时间(用格林威治时间表示),只要是已经过去的日期即可。  
       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"); 
  ?>

例2:

強制使用者每次造訪這個頁面時取得最新資料,而不是使用存在客戶端的快取。

   <?php  
       header(&#39;HTTP/1.1 401 Unauthorized&#39;);  
       header(&#39;status: 401 Unauthorized&#39;);  
   ?>

範例3:

輸出狀態值到瀏覽器,主要用於存取權限控制

   <?php  
       header(&#39;HTTP/1.1    404    Not Found&#39;);  
       header("status:    404    Not Found"); //这种写法错误
   ?>

範例4:

要限制一個使用者不能存取該頁,則可設定狀態為404,如下所示,這樣瀏覽器就顯示為即該頁不存在

header("Content-type: audio/mpeg");
header("Content-Disposition: attachment; filename=filenale");
header("Content-Description: PHP3 Generated Data");

例5:

隱藏檔案的位置

html標籤 6988905309f3ad8099323e53cd3f34175db79b134e9f6b82c0b36e0489ee08ed就可以實現普通檔案下載。如果為了保密文件,就不能把文件連結告訴別人,可以用header函數實作文件下載。

<?php
//some code here
?>
//这里应该是一个空行
<?php
    header("http/1.1 403 Forbidden");
    exit();
?>

例6:

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

<?php
//some code here
?>
//这里应该是一个空行
<?php
    header("http/1.1 403 Forbidden");
    exit();
?>

原因:
PHP脚本开始执行 时,它可以同时发送http消息头部(标题)信息和主体信息. http消息头部(来自 header() 或SetCookie() 函数)并不会立即发送,相反,它被保存到一个列表中. 这样就可以允许你修改标题信息,包括缺省的标题(例如Content-Type 标题).但是,一旦脚本发送了任何非标题的输出(例如,使用 HTML 或 print()调用),那么PHP就必须先发送完所有的Header,然后终止 HTTPheader.而后继续发送主体数据.从这时开始,任何添加或修改Header信息的试图都是不允许的,并会发送上述的错误消息之一。
解决办法:
修改php.ini打开缓存(output_buffering),将output_buffering=0修改成output_buffering=4096
或者在程序中使用缓存函数ob_start(),ob_end_flush() 等。原理是:output_buffering被启用时,在脚本发送输出时,PHP并不发送HTTPheader。相反,它将此输出通过管道(pipe)输入到动态增加的缓存中(只能在PHP4.0中使用,它具有中央化的输出机制)。你仍然可以修改/添加header,或者设置cookie,因为 header实际上并没有发送。当全部脚本终止时,PHP将自动发送HTTP header到浏览器,然后再发送输出缓冲中的内容。

以上是header location頁面跳轉失敗的原因詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn