> 백엔드 개발 > PHP 튜토리얼 > PHP header() 함수 사용법에 대한 자세한 설명

PHP header() 함수 사용법에 대한 자세한 설명

WBOY
풀어 주다: 2016-07-25 09:11:46
원래의
1037명이 탐색했습니다.

참고: 페이지에 헤더가 몇 개 있든 상관없이 마지막 헤더가 실행되지만 조건부입니다. 예를 들면 다음과 같습니다.

  1. header('위치:http://bbs.it-home.org')
  2. header('위치:http://www .g.cn');
  3. header('위치:http://www.baidu.com');
코드 복사

이것은 점프합니다. 바이두로

  1. header('위치:http://bbs.it-home.org');
  2. header('위치:http://www.g. cn');
  3. header('위치:http://www.baidu.com');
코드 복사

Google로 이동합니다.

헤더 기능 사용 상세 설명

1. PHP는 HTTP 프로토콜을 사용하여 HTML 문서의 헤더만 브라우저에 보내고 브라우저에 페이지 처리 방법을 알려줍니다. 전송되는 내용은 HTTP 프로토콜에 익숙해야 하며 관련이 없습니다. PHP. 기존 헤더는 다음 세 가지 헤더 중 하나를 포함해야 하며 한 번만 나타날 수 있습니다. 위치: xxxx:yyyy/zzzz 콘텐츠 유형: xxxx/yyyy 상태: nnn xxxxxx

2. HTTP 프로토콜의 작동 방식 HTTP 프로토콜은 요청/응답 패러다임을 기반으로 합니다. 클라이언트는 서버와 연결을 설정한 후 서버에 요청을 보냅니다. 요청 형식은 통일된 리소스 식별자, 프로토콜 버전 번호, 요청 수정자를 포함한 MIME 정보, 클라이언트 정보 및 가능한 콘텐츠로 구성됩니다. 요청을 받은 후 서버는 해당 응답 정보를 제공하며, 그 형식은 정보의 프로토콜 버전 번호, 성공 또는 오류 코드, 서버 정보, 엔터티 정보 및 가능한 내용을 포함하는 MIME 정보를 포함하는 상태 줄입니다. HTTP 프로토콜에서 서버는 HTTP 서비스를 제공하는 부분을 의미하고, 클라이언트는 사용하는 브라우저나 다운로드 도구 등을 의미합니다. 통신 중에 클라이언트는 연결을 요청하고, 서버는 연결을 설정하고, 클라이언트는 HTTP 요청(Request)을 보내고, 서버는 응답 정보(Respond)를 반환함으로써 HTTP 작업을 완료합니다.

3. HTTP 프로토콜 상태 코드 1×× 예약됨 2××는 요청이 성공적으로 수신되었음을 나타냅니다. 3×× 요청을 완료하려면 고객이 요청을 더욱 구체화해야 합니다. 4×× 고객 오류 5×× 서버 오류

4. 동작 예시 (1) 리다이렉트 기능, 가장 많이 사용되는 기능입니다

<?php 
   Header("Location: http://www.php.net/"); 
?> 
로그인 후 복사

(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"); 
?>
로그인 후 복사

참고: 기존 헤더에는 다음 세 가지 헤더 중 하나가 포함되어야 하며 한 번만 나타날 수 있습니다. 콘텐츠 유형: xxxx/yyyy 위치: xxxx:yyyy/zzzz 상태: nnn xxxxxx는 새로운 멀티파트 헤더 사양(멀티파트 MIME)에서 두 번 이상 나타날 수 있습니다. 사용 예 예제 1: 이 예제는 브라우저를 PHP 공식 웹사이트로 리디렉션합니다.

  1. Header("위치: http://www.php.net/"); 종료
코드 복사

예 2: 사용자가 매번 최신 데이터를 가져오도록 하려면 프록시나 캐시의 데이터 대신 다음 헤더를 사용할 수 있습니다.

  1. header("만료: 1997년 7월 26일 월요일 05:00:00 GMT")
  2. header("최종 수정: " . gmdate("D, d M Y H:i:s ") . "GMT"); header("Cache-Control: no-cache, must-revalidate");
  3. header("Pragma: no-cache");
코드 복사

예 3: 사용자의 브라우저에 파일을 찾을 수 없다는 메시지가 표시되도록 합니다.

  1. header("Status: 404 Not Found");
코드 복사

예 4: 사용자가 파일을 다운로드할 수 있도록 합니다.

  1. header("콘텐츠 유형: 애플리케이션/x-gzip")
  2. header("콘텐츠 처리: 첨부 파일; 파일 이름=파일 이름" ) ;
  3. header("콘텐츠 설명: PHP3 생성 데이터");
코드 복사

header -- 发送一个原始 HTTP 标头说明 void header ( string string [, bool replace [, int http_response_code]] )   header() 函数用来发送一个原始 HTTP 标头。有关 HTTP 标头的更多内容见 HTTP/1.1 规范。 可选参数 replace 指明是替换掉前一条类似的标头还是增加一条相同类型的标头。默认为替换,但如果将其设为 FALSE 则可以强制发送多个同类标头。例如:

<?php 
  header('WWW-Authenticate: Negotiate'); 
  header('WWW-Authenticate: NTLM', false); 
?>
로그인 후 복사

第二个可选参数 http_response_code 强制将 HTTP 响应代码设为指定值(此参数是 PHP 4.3.0 新加的)。 有两种特殊的 header 调用。第一种是标头以字符串“HTTP/”(大小写不重要)开头的,可以用来确定要发送的 HTTP 状态码。例如,如果配置了 Apache 用 PHP 来处理找不到文件的错误处理请求(使用 ErrorDocument 指令),需要确保脚本产生了正确的状态码。

<?php 
 header("HTTP/1.0 404 Not Found") 
?>
로그인 후 복사

  注: HTTP 状态码标头行总是第一个被发送到客户端,而并不管实际的 header() 调用是否是第一个。除非 HTTP 标头已经发送出去,任何时候都可以通过用新的状态行调用 header() 函数来覆盖原先的。    第二种特殊情况是以“Location:”标头。它不只是把这个标头发送回浏览器,它还将一个 REDIRECT(302)状态码返回给浏览器,除非之前已经发出了某个 3xx 状态码。

<?php 
  header("Location: http://www.example.com/"); /* 重定向浏览器 */ 
  /* 确保重定向后,后续代码不会被执行 */ 
  exit; 
?> 
로그인 후 복사

注: HTTP/1.1 标准需要一个绝对地址的 URI 做为 Location: 的参数, 但有一些客户端支持相对 URI。通常可以使用 $_SERVER['HTTP_HOST']、$_SERVER['PHP_SELF'] 及 dirname() 函数来自己从相对 URI 产生出绝对 URI:

<?php 
  header("Location: http://%22.$_server['http_host'/] 
  . rtrim(dirname($_SERVER['PHP_SELF']), '/\\') 
  ."/".$relative_url); 
?> 
로그인 후 복사

  注: 即使启用了 session.use_trans_sid,Session ID 也不会随着 Location 头信息被传递。必须手工用 SID 常量来传递。      PHP 脚本通常会产生一些动态内容,这些内容必须不被浏览器或代理服务器缓存。很多代理服务器和浏览器都可以被下面的方法禁止缓存: 

<?php 
  header("Cache-Control: no-cache, must-revalidate"); // HTTP/1.1 
  header("Expires: Mon, 26 Jul 1997 05:00:00 GMT"); // 过去的时间 
 ?>
로그인 후 복사

  注: 可能会发现即使不输出上面所有的代码,网页也没有被缓冲。用户有很多选项可以设置来改变浏览器的默认缓存行为。通过发送上述标头,应该可以覆盖任何可以导致脚本页面被缓存的设置。      另外,当使用了 session 时,利用 session_cache_limiter() 函数和 session.cache_limiter 选项可以用来自动产生正确的缓存相关标头。      要记住 header() 必须在任何实际输出之前调用,不论是来自普通的 HTML 标记,空行或者 PHP。有一个常见错误就是在通过 include(),require() 或一些其它的文件存取类函数读取代码时,有一些空格或者空行在调用 header() 之前被发送了出去。同样在一个单独的 PHP/HTML 文件中这个错误也很普遍

<?php 
  /* 这将产生一个错误,因为在调 header() 
  * 之前已经输出了东西 */ 
  header('Location: http://www.abc.com/'); 
?>
로그인 후 복사

  注: 自 PHP 4 起,可以通过一些输出缓冲函数来解决这个问题。代价是把所有向浏览器的输出都缓存在服务器,直到下命令发送它们。可以在代码中使用 ob_start() 及 ob_end_flush() 来实现这样的功能,或者通过修改 php.ini 中的 output_buffering 配置选项来实现,也可以通过修改服务器配置文件来实现。

附header()两个常用用法:

  1. //设置页面编码:
  2. header('Content-Type:text/html;charset=gb2312');
  3. //调整页面:
  4. header('location:http://bbs.it-home.org');
复制代码

您可能感兴趣的文章: php header()函数的简单例子 php header函数实现文件下载的实例代码 php中header函数的用法举例详解 php header 使用详解 php header函数 文件下载时直接提示保存的代码 php header头信息应用举例 php 文件头部(header)信息详解 PHP中HEADER头消息详解 php header函数使用要点



원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿