探讨php中header的用法详解
时间:2020-04-08 14:42 来源/作者:PHP教程网
-
he ad er() is used to send raw HTTP headers. See the HTTP/1.1 specification for more information on HTTP headers.
-
-
范例一:
-
-
复制代码 代码如下:
-
-
-
<?PHP
-
Header("Location: //www.zzvips.com";);
-
exit;
-
?>
-
-
-
-
复制代码 代码如下:
-
-
-
<?php
-
header("refresh:2;url=//www.zzvips.com");
-
echo "正在加载,请稍等...<br>三秒后自动跳转至<a href="
-
?>
-
-
-
--------------------------------------------------------------------------------
-
范例二:禁止页面在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' );
-
?>
-
-
-
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 仅当在安全连接中使用时才防止缓存,如果在非安全页中使用,处理方式与 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代码段之间有一个空行:
-
-
复制代码 代码如下:
-
-
-
-
?>
-
-
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
-
?>
-
-
-
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
-
-
header('HTTP/1.1 200 OK');
-
-
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';
-
-
-
-
header('X-Powered-By: PHP/4.4.0');
-
header('X-Powered-By: Brain/0.6b');
-
-
header('Content-language: en');
-
-
$time = time() - 60;
-
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');
-
-
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');
-
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');
-
header('Content-Type: application/zip');
-
header('Content-Type: application/pdf');
-
header('Content-Type: audio/mpeg');
-
header('Content-Type: application/x-shockwave-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';
-
?>
相关文章
热门资讯