PHP发送HEADER头消息 - kudosharry

时间:2024-03-03 21:04:02

PHP发送HEADER头消息

PHP中我们经常需要通过HEADER发送HTTP标头消息,以便告诉浏览器一些处理状态(Status)或显示参量,最典型的就是发送页面处理HEADER和发送状态HEADER。
无论是发送哪种HEADER消息,都必须保证在发送HEADER之前没有输出任何信息到终端浏览器。

一、使用HEADER发送文本类型头信息
例1:
<?php
header("Content-Type: text/html; charset=UTF-8");//告知各位观众下面将要输出的文本类型
?>
例 1输出HEADER告诉浏览器将要输出的文本编码格式为UTF-8。这在全页面PHP处理上是必须的,否则可能会引起终端浏览器显示乱码或空白页显示现 象。由于PHP指定在HEADER输出前不能有任何输出信息,包括空格,所以当页面运行出现HEADER信息已经发送的提示时候,需要首先检查在 HEADER之前是否输出了某些信息,包括本PHP页面的包含头文件是否输出信息。
如果需要输出文件提示下载可使用如下方法:
<?php
header("Content-type: application/octet-stream");//FILE流
header("Accept-Ranges: bytes");
header("Accept-Length: $filesize");//提示将要接收的文件大小
header("Content-Disposition: attachment; filename=".$fname); //提示终端浏览器下载操作
?>
如 果是PDF格式也可用header("Content-type: application/pdf");其它格式类似处理,不过上面的例子是个下载文件流通例,但是指定详细的文本格式似乎对浏览器的默认处理似乎更好,比 如让播放器自动播放下载音乐、或PDF编辑器自动打开远程PDF文档等。

附Content-type的MIME类型说明:
 <?php
$mimetypes = array(
        \'ez\' => \'application/andrew-inset\',
        \'hqx\' => \'application/mac-binhex40\',
        \'cpt\' => \'application/mac-compactpro\',
        \'doc\' => \'application/msword\',
        \'bin\' => \'application/octet-stream\',
        \'dms\' => \'application/octet-stream\',
        \'lha\' => \'application/octet-stream\',
        \'lzh\' => \'application/octet-stream\',
        \'exe\' => \'application/octet-stream\',
        \'class\' => \'application/octet-stream\',
        \'so\' => \'application/octet-stream\',
        \'dll\' => \'application/octet-stream\',
        \'oda\' => \'application/oda\',
        \'pdf\' => \'application/pdf\',
        \'ai\' => \'application/postscript\',
        \'eps\' => \'application/postscript\',
        \'ps\' => \'application/postscript\',
        \'smi\' => \'application/smil\',
        \'smil\' => \'application/smil\',
        \'mif\' => \'application/vnd.mif\',
        \'xls\' => \'application/vnd.ms-excel\',
        \'ppt\' => \'application/vnd.ms-powerpoint\',
        \'wbxml\' => \'application/vnd.wap.wbxml\',
        \'wmlc\' => \'application/vnd.wap.wmlc\',
        \'wmlsc\' => \'application/vnd.wap.wmlscriptc\',
        \'bcpio\' => \'application/x-bcpio\',
        \'vcd\' => \'application/x-cdlink\',
        \'pgn\' => \'application/x-chess-pgn\',
        \'cpio\' => \'application/x-cpio\',
        \'csh\' => \'application/x-csh\',
        \'dcr\' => \'application/x-director\',
        \'dir\' => \'application/x-director\',
        \'dxr\' => \'application/x-director\',
        \'dvi\' => \'application/x-dvi\',
        \'spl\' => \'application/x-futuresplash\',
        \'gtar\' => \'application/x-gtar\',
        \'hdf\' => \'application/x-hdf\',
        \'js\' => \'application/x-javascript\',
        \'skp\' => \'application/x-koan\',
        \'skd\' => \'application/x-koan\',
        \'skt\' => \'application/x-koan\',
        \'skm\' => \'application/x-koan\',
        \'latex\' => \'application/x-latex\',
        \'nc\' => \'application/x-netcdf\',
        \'cdf\' => \'application/x-netcdf\',
        \'sh\' => \'application/x-sh\',
        \'shar\' => \'application/x-shar\',
        \'swf\' => \'application/x-shockwave-flash\',
        \'sit\' => \'application/x-stuffit\',
        \'sv4cpio\' => \'application/x-sv4cpio\',
        \'sv4crc\' => \'application/x-sv4crc\',
        \'tar\' => \'application/x-tar\',
        \'tcl\' => \'application/x-tcl\',
        \'tex\' => \'application/x-tex\',
        \'texinfo\' => \'application/x-texinfo\',
        \'texi\' => \'application/x-texinfo\',
        \'t\' => \'application/x-troff\',
        \'tr\' => \'application/x-troff\',
        \'roff\' => \'application/x-troff\',
        \'man\' => \'application/x-troff-man\',
        \'me\' => \'application/x-troff-me\',
        \'ms\' => \'application/x-troff-ms\',
        \'ustar\' => \'application/x-ustar\',
        \'src\' => \'application/x-wais-source\',
        \'xhtml\' => \'application/xhtml+xml\',
        \'xht\' => \'application/xhtml+xml\',
        \'zip\' => \'application/zip\',
        \'au\' => \'audio/basic\',
        \'snd\' => \'audio/basic\',
        \'mid\' => \'audio/midi\',
        \'midi\' => \'audio/midi\',
        \'kar\' => \'audio/midi\',
        \'mpga\' => \'audio/mpeg\',
        \'mp2′ => \'audio/mpeg\',
        \'mp3′ => \'audio/mpeg\',
        \'aif\' => \'audio/x-aiff\',
        \'aiff\' => \'audio/x-aiff\',
        \'aifc\' => \'audio/x-aiff\',
        \'m3u\' => \'audio/x-mpegurl\',
        \'ram\' => \'audio/x-pn-realaudio\',
        \'rm\' => \'audio/x-pn-realaudio\',
        \'rpm\' => \'audio/x-pn-realaudio-plugin\',
        \'ra\' => \'audio/x-realaudio\',
        \'wav\' => \'audio/x-wav\',
        \'pdb\' => \'chemical/x-pdb\',
        \'xyz\' => \'chemical/x-xyz\',
        \'bmp\' => \'image/bmp\',
        \'gif\' => \'image/gif\',
        \'ief\' => \'image/ief\',
        \'jpeg\' => \'image/jpeg\',
        \'jpg\' => \'image/jpeg\',
        \'jpe\' => \'image/jpeg\',
        \'png\' => \'image/png\',
        \'tiff\' => \'image/tiff\',
        \'tif\' => \'image/tiff\',
        \'djvu\' => \'image/vnd.djvu\',
        \'djv\' => \'image/vnd.djvu\',
        \'wbmp\' => \'image/vnd.wap.wbmp\',
        \'ras\' => \'image/x-cmu-raster\',
        \'pnm\' => \'image/x-portable-anymap\',
        \'pbm\' => \'image/x-portable-bitmap\',
        \'pgm\' => \'image/x-portable-graymap\',
        \'ppm\' => \'image/x-portable-pixmap\',
        \'rgb\' => \'image/x-rgb\',
        \'xbm\' => \'image/x-xbitmap\',
        \'xpm\' => \'image/x-xpixmap\',
        \'xwd\' => \'image/x-xwindowdump\',
        \'igs\' => \'model/iges\',
        \'iges\' => \'model/iges\',
        \'msh\' => \'model/mesh\',
        \'mesh\' => \'model/mesh\',
        \'silo\' => \'model/mesh\',
        \'wrl\' => \'model/vrml\',
        \'vrml\' => \'model/vrml\',
        \'css\' => \'text/css\',
        \'html\' => \'text/html\',
        \'htm\' => \'text/html\',
        \'asc\' => \'text/plain\',
        \'txt\' => \'text/plain\',
        \'rtx\' => \'text/richtext\',
        \'rtf\' => \'text/rtf\',
        \'sgml\' => \'text/sgml\',
        \'sgm\' => \'text/sgml\',
        \'tsv\' => \'text/tab-separated-values\',
        \'wml\' => \'text/vnd.wap.wml\',
        \'wmls\' => \'text/vnd.wap.wmlscript\',
        \'etx\' => \'text/x-setext\',
        \'xsl\' => \'text/xml\',
        \'xml\' => \'text/xml\',
        \'mpeg\' => \'video/mpeg\',
         \'mpg\' => \'video/mpeg\',
        \'mpe\' => \'video/mpeg\',
        \'qt\' => \'video/quicktime\',
        \'mov\' => \'video/quicktime\',
        \'mxu\' => \'video/vnd.mpegurl\',
        \'avi\' => \'video/x-msvideo\',
        \'movie\' => \'video/x-sgi-movie\',
        \'ice\' => \'x-conference/x-cooltalk\',
);
?>

二、使用HEADER发送状态(Status)信息
当 我们在响应浏览器操作时候,可能需要输出一些提示状态信息,比如访问的文件不存(404状态)在或者文件被转移(301状态)等,告诉用户(包括搜索引 擎)所访问页面的当前状态,这在实际使用中对站长非常重要,因为这直接影响到搜索引擎对当前页面的判定。当前对于301固定转移(HTTP/1.1 301 Moved Permanently)我们也可以采用其它方式(.htaccess或IIS重定向),但是了解PHP自编程解决这些页面状态提示会加深自己对浏览器状 态的认知。
HEADER状态消息头格式如下:
header("第一部分 第二部分 第三部分");
其中第一部分为HTTP协议的 版本号(HTTP-Version),第二部分为将要发送的状态代码(Status),第三部分为状态原因(Reason-Phrase) ,三部分中间用一个空格分割,第一部分和第二部分都是必需,第三部分的状态原因为可选项,一般推荐按照标准写出(参下文)。
例2:
<?php
header("HTTP/1.1 404 Not Found");
?>
例2实际在使用中很少用到的,感觉有点忽悠终端浏览者的意思。
最经常遇到是下面的例3:
<?php
header("HTTP/1.1 301 Moved Permanently");//301永久迁移
header("Location: 跳转新URL地址,默认Location可能会发送302头,笔者暂不确定。
?>
此语句告诉搜索引擎或浏览者,本页面已经被“蚂蚁搬家”了,走,我带你看看新家去(新网页)。更多关于301重定向的内容请参考完美解决IIS和APACHE的301重定向一文。

下面专门把W3上Header状态代码(Status)罗列一下供各位使用参考:
1、状态码类(Status)定义
1xx类:Informational - Request received, continuing process(信息状态码类:请求已收到,继续处理)
2xx类:Success - The action was successfully received, understood,and accepted(成功状态码类:本次操作已收到并处理OK)
3xx类:Redirection - Further action must be taken in order to complete the request (重定向状态码类:完成请求前必须进一步执行操作)
4xx类:Client Error - The request contains bad syntax or cannot be fulfilled(发往客户端的错误状态码类:请求包含语法错误或请求不能完成)
5xx类:Server Error - The server failed to fulfill an apparently valid request (服务器端的错误状态码类:服务器执行合法请求失败)

2、常用状态码(Status)列表(部分):
| "100" ; Continue
| "101" ; Switching Protocols

| "200" ; OK
| "201" ; Created
| "202" ; Accepted
| "203" ; Non-Authoritative Information
| "204" ; No Content
| "205" ; Reset Content
| "206" ; Partial Content

| "300" ; Multiple Choices
| "301" ; Moved Permanently
| "302" ; Moved Temporarily
| "303" ; See Other
| "304" ; Not Modified
| "305" ; Use Proxy
| "400" ; Bad Request
| "401" ; Unauthorized
| "402" ; Payment Required
| "403" ; Forbidden
| "404" ; Not Found
| "405" ; Method Not Allowed
| "406" ; Not Acceptable
| "407" ; Proxy Authentication Required
| "408" ; Request Time-out
| "409" ; Conflict
| "410" ; Gone
| "411" ; Length Required
| "412" ; Precondition Failed
| "413" ; Request Entity Too Large
| "414" ; Request-URI Too Large
| "415" ; Unsupported Media Type

| "500" ; Internal Server Error
| "501" ; Not Implemented
| "502" ; Bad Gateway
| "503" ; Service Unavailable
| "504" ; Gateway Time-out
| "505" ; HTTP Version not supported

另外我们还可以使用PHP 的HEADER发送一些缓存参数命令、超期命令等,例如:
<?php
header("Cache-Control: no-cache, must-revalidate"); //不要缓存
header("Expires: Fri, 1 Dec 2099 08:00:00 GMT"); // 页面过期时间
?>