黑帽联盟

 找回密码
 会员注册
查看: 1381|回复: 0
打印 上一主题 下一主题

[php] php header 详细使用说明

[复制链接]

148

主题

9

听众

337

积分

版主

Rank: 7Rank: 7Rank: 7

  • TA的每日心情
    擦汗
    2018-6-6 11:33
  • 签到天数: 348 天

    [LV.8]以坛为家I

    不管页面有多少header,它会执行最后一个,不过是有条件的,例如:
    header('Location:http://www.cnblackhat.com');
    header('Location:http://www.g.cn');
    header('Location:http://www.baidu.com');
    这个就会跳到百度

    header('Location:http://www.cnblackhat.com');echo 'cnblackhat';
    header('Location:http://www.g.cn');
    header('Location:http://www.baidu.com');
    这个就会跳到google

    下面是关于header函数的详细使用说明
    一、作用:
    ~~~~~~~~~
    PHP只是以HTTP协议将HTML文档的标头送到浏览器,告诉浏览器具体怎么处理这个页面,至于传送的内容则需要熟悉一下HTTP协议了,与PHP无关了
    传统的标头一定包含下面三种标头之一,并只能出现一次。
    Location: xxxx:yyyy/zzzz
    Content-Type: xxxx/yyyy
    Status: nnn xxxxxx

    二、先来了解一下HTTP协议的运作方式
    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    HTTP协议是基于请求/响应范式的。一个客户机与服务器建立连接后,发送一个请求给服务器,请求方式的格式为,统一资源标识符、协议版本号,后边是 MIME信息包括请求修饰符、客户机信息和可能的内容。服务器接到请求后,给予相应的响应信息,其格式为一个状态行包括信息的协议版本号、一个成功或错误的代码,后边是MIME信息包括服务器信息、实体信息和可能的内容。
    它分四个过程,在HTTP协议中,服务端是指提供HTTP服务的部分,客户端是指你使用的浏览器或者下载工具等等。在通讯时,由客户端发出请求连接,服务端建立连接;然后,客户端发出HTTP请求(Request),服务端返回响应信息(Respond),由此完成一个HTTP操作。

    三、HTTP协议状态码表示的意思
    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    1××  保留
    2××  表示请求成功地接收
    3××  为完成请求客户需进一步细化请求
    4××  客户错误
    5××  服务器错误

    四、操作实例:
    ~~~~~~~~~~~~~
    <1> 重定向功能,这种最常见
    <?php
    Header("Location: https://bbs.cnblackhat.com");
    ?>

    <2> 强制用户每次访问这个页面时获取最新资料,而不是使用存在客户端的缓存。
    <?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");
    //输出MIME类型
    header("Content-type: application/file");
    //文件长度
    header("Content-Length: 227685");
    //接受的范围单位
    header("Accept-Ranges: bytes");
    //缺省时文件保存对话框中的文件名称
    header("Content-Disposition: attachment; filename=$filename");
    ?>

    <3> 输出状态值到浏览器,主要用于访问权限控制
    <?php
    header('HTTP/1.1 401 Unauthorized');
    header('status: 401 Unauthorized');
    ?>
    比如要限制一个用户不能访问该页,则可设置状态为404,如下所示,这样浏览器就显示为即该页不存在
    <?php
    header('HTTP/1.1 404 Not Found');
    header("status: 404 Not Found");
    ?>

    注意: 传统的标头一定包含下面三种标头之一,并只能出现一次。 Content-Type: xxxx/yyyy Location: xxxx:yyyy/zzzz Status: nnn xxxxxx 在新的多型标头规格 (Multipart MIME) 方可以出现二次以上。

    使用范例

    范例一: 本例使浏览器重定向到黑帽联盟的官方网站。
    Header("Location: https://bbs.cnblackhat.com"); exit; >?
    范例二: 要使用者每次都能得到最新的资料,而不是 Proxy 或 cache 中的资料,可以使用下列的标头
    header("Expires: Mon, 26 Jul 1997 05:00:00 GMT");
    header("Last-Modified: " . gmdate("D, d M Y H:i:s") . "GMT"); header("Cache-Control: no-cache, must-revalidate");
    header("Pragma: no-cache"); >?

    范例三: 让使用者的浏览器出现找不到档案的信息。
    header("Status: 404 Not Found"); >?

    范例四:让使用者下载档案。
    header("Content-type: application/x-gzip");
    header("Content-Disposition: attachment; filename=文件名");
    header("Content-Description: PHP3 Generated Data"); >?

    帖子永久地址: 

    黑帽联盟 - 论坛版权1、本主题所有言论和图片纯属会员个人意见,与本论坛立场无关
    2、本站所有主题由该帖子作者发表,该帖子作者与黑帽联盟享有帖子相关版权
    3、其他单位或个人使用、转载或引用本文时必须同时征得该帖子作者和黑帽联盟的同意
    4、帖子作者须承担一切因本文发表而直接或间接导致的民事或刑事法律责任
    5、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
    6、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
    7、黑帽联盟管理员和版主有权不事先通知发贴者而删除本文

    您需要登录后才可以回帖 登录 | 会员注册

    发布主题 !fastreply! 收藏帖子 返回列表 搜索
    回顶部