详细解释PHP中header

来源:互联网 发布:三维重建算法 编辑:程序博客网 时间:2024/05/17 22:17

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

header()是用来发送 HTTP Header的。replace是个可选的参数,指示是否替代一个先期相似的header,
或者增加第2个相同类型的header。默认的是替代,但是如果你传递FALSE参数给第2个参数(即replace),你
能强制使用多个相同类型的header。例如:

<?php
header(’WWW-Authenticate: Negotiate’);
header(’WWW-Authenticate: NTLM’, false);
?>

第二个可选的参数http_response_code强置HTTP响应代码的值。(PHP>4.3.0)

有两种特定的header调用。一种是header用字符串”HTTP/”开头的(大小写无所谓),它用
来指定发出的HTTP状态码。举个例子来说,如果你已经配置Apache使用PHP脚本来处理请求
不存在的文件(用ErrorDocument指令),你可能想确认你的脚本生成一个合适的状态码:

<?php
header(”HTTP/1.0 404 Not Found”);
?>

注意:HTTP状态行 总是最先发送给客户端的,不管你实际上在什么时候调用header()函数。
除非你的HTTP header已经发送出去了,否则,在任何时候,状态将会被header()函数用一个新的
状态行 覆盖。
在PHP 3中,只有PHP编译为Apache的模块是,并且用下面Staus Header才能取得同样的效果

<?php
header(”Status: 404 Not Found”);
?>

第二中特殊的情况就是”Location:”header。如果没有某些 3xx的状态码已经发出的话,它不仅
发出Location行,而且发出一个重定向的状态码(302)。

<?php
header(”Location: http://www.upsdn.net”);
exit;
?>

注意:HTTP/1.1要求一个绝对URI作为Location的参数:包括协议头,主机名和绝对路径,
但是某些客户端可以接受相对URI。你可用$_SERVER['HTTP_HOST'] $_SERVER['PHP_SELF']和
dirname()来从一个相对URI来产生绝对URI。

<?php
header(”Location: http://” . $_SERVER['HTTP_HOST']
. dirname($_SERVER['PHP_SELF'])
. “/” . $relative_url);
?>

PHP脚本通常生成一些动态的内容,不必被客户端的浏览器或者代理服务器缓存。许多代理和客户端可以
强制禁止缓存:

<?php
// 时间总是过去的
header(”Expires: Mon, 26 Jul 1997 05:00:00 GMT”);

// 文件总是被修改的
header(”Last-Modified: ” . gmdate(”D, d M Y H:i:s”) . ” GMT”);

// HTTP/1.1
header(”Cache-Control: no-store, no-cache, must-revalidate”);
header(”Cache-Control: post-check=0, pre-check=0″, false);

// HTTP/1.0
header(”Pragma: no-cache”);
?>

注意:你可能发现即使你没有输出上面的header,你的页面还是不能被缓存。可能是有几个选项改变了默认的
缓存行为。见sessrion_cache_limiter().

如果你想提示用户保存你发送过去的数据,比如一个已经生成的PDF文件,你可以用Content_Dispostion
头来提供一个推荐的文件名,强迫浏览器显示保存对话框.

<?php
header(’Content-type: application/pdf’);
header(’Content-Disposition: attachment; filename=”downloaded.pdf”‘);
readfile(’original.pdf’);
?>

对于IE,要加上Connection头

header(”HTTP/1.1 301 Moved Permanently”);
header(”Location: “.$url);
header(”Connection: close”); 

 

php header中的Cache-control参数说明

网页的缓存是由HTTP消息头中的“Cache-control”来控制的,常见的取值有private、no-cache、max-age、must-revalidate等,默认为private。其作用根据不同的重新浏览方式分为以下几种情况: 

(1) 打开新窗口

值为private、no-cache、must-revalidate,那么打开新窗口访问时都会重新访问服务器。

而如果指定了max-age值,那么在此值内的时间里就不会重新访问服务器,例如:

Cache-control: max-age=5(表示当访问此网页后的5秒内再次访问不会去服务器)

(2) 在地址栏回车

值为private或must-revalidate则只有第一次访问时会访问服务器,以后就不再访问。

值为no-cache,那么每次都会访问。

值为max-age,则在过期之前不会重复访问。

(3) 按后退按扭

值为private、must-revalidate、max-age,则不会重访问,

值为no-cache,则每次都重复访问

(4) 按刷新按扭

无论为何值,都会重复访问

Cache-control值为“no-cache”时,访问此页面不会在Internet临时文章夹留下页面备份。

另外,通过指定“Expires”值也会影响到缓存。例如,指定Expires值为一个早已过去的时间,那么访问此网时若重复在地址栏按回车,那么每次都会重复访问: Expires: Fri, 31 Dec 1999 16:00:00 GMT

比如:禁止页面在IE中缓存

http响应消息头部设置:

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相同,该页将被缓存,但被标记为立即过期

header常用指令

header分为三部分:

第一部分为HTTP协议的版本(HTTP-Version);

第二部分为状态代码(Status);

第三部分为原因短语(Reason-Phrase)。 

// fix 404 pages:   用这个header指令来解决URL重写产生的404 header

header(’HTTP/1.1 200 OK’);

// set 404 header:   页面没找到

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

//页面被永久删除,可以告诉搜索引擎更新它们的urls

// set Moved Permanently header (good for redrictions)

// use with location header

header(’HTTP/1.1 301 Moved Permanently’);

// 访问受限

header(’HTTP/1.1 403 Forbidden’);

// 服务器错误

header(’HTTP/1.1 500 Internal Server Error’);

// 重定向到一个新的位置

// redirect to a new location:

header(’Location: http://www.example.org/‘);

延迟一段时间后重定向

// redrict with delay:

header(’Refresh: 10; url=http://www.example.org/’);

print ‘You will be redirected in 10 seconds’;

// 覆盖 X-Powered-By value

// override X-Powered-By: PHP:

header(’X-Powered-By: PHP/4.4.0′);

header(’X-Powered-By: Brain/0.6b’);

// 内容语言 (en = English)

// content language (en = English)

header(’Content-language: en’);

//最后修改时间(在缓存的时候可以用到)

// last modified (good for caching)

$time = time() – 60; // or filemtime($fn), etc

header(’Last-Modified: ‘.gmdate(’D, d M Y H:i:s’, $time).’ GMT’);

// 告诉浏览器要获取的内容还没有更新

// header for telling the browser that the content

// did not get changed

header(’HTTP/1.1 304 Not Modified’);

// 设置内容的长度 (缓存的时候可以用到):

// set content length (good for caching):

header(’Content-Length: 1234′);

// 用来下载文件:

// Headers for an download:

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

// Disable caching of the current document:

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 pastheader(’Pragma: no-cache’);

// set content type:

header(’Content-Type: text/html; charset=iso-8859-1′);

header(’Content-Type: text/html; charset=utf-8′);

header(’Content-Type: text/plain’);

// plain text file

header(’Content-Type: image/jpeg’);

// JPG picture

header(’Content-Type: application/zip’);

// ZIP file

header(’Content-Type: application/pdf’);

// PDF file

header(’Content-Type: audio/mpeg’);

// Audio MPEG (MP3,…) file

header(’Content-Type: application/x-shockwave-flash’);

// 显示登录对话框,可以用来进行HTTP认证

// Flash animation// show sign in box

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’;?>

原创粉丝点击