>  기사  >  백엔드 개발  >  헤더 위치 페이지 점프 실패 이유에 대한 자세한 설명

헤더 위치 페이지 점프 실패 이유에 대한 자세한 설명

伊谢尔伦
伊谢尔伦원래의
2018-05-18 10:47:209130검색

http 헤더 정보
헤더 정보에는 많은 기능이 있으며 가장 중요한 기능은 다음과 같습니다.
1.Jump
브라우저가 헤더 정보에서 위치: xxxx를 수신하면 자동으로 xxxx 포인터로 이동합니다. URL 주소는 js를 사용하여 점프를 작성하는 것과 약간 유사합니다. 하지만 이 점프는 브라우저에서만 알 수 있고, 콘텐츠에 내용이 있든 없든 사용자는 볼 수 없습니다.
예: header("위치: http://www.php.cn/");
2. 웹페이지의 콘텐츠를 지정하세요
헤더 정보가 지정된 경우 동일한 XML 파일: 콘텐츠 유형: 애플리케이션 /xml , 브라우저는 XML 파일 형식에 따라 이를 구문 분석합니다. 그러나 헤더 정보가 Content-type: text/xml인 경우 브라우저는 이를 저장된 텍스트로 구문 분석합니다. (브라우저에서는 확장자에 따라 파일을 구문 분석하지 않습니다.)
예: header('Content-type: application/pdf');
3. Attachment
어떤 곳에서 다운로드할 때 가끔 그런 점을 눈치채셨는지 모르겠습니다. 웹사이트를 클릭하고 연결을 다운로드한 후 브라우저에서 첨부 파일을 웹 페이지로 열었고 표시된 내용이 왜곡된 문자로 표시되었습니다. 이 문제는 헤더 정보와도 관련이 있습니다. 때로는 브라우저가 Content-type을 기준으로 열거나 저장할지 여부를 결정하므로 때로는 잘못된 판단을 내리기도 합니다(주로 웹 사이트 디자이너가 Content-type 작성을 잊어버렸기 때문). 실제로 콘텐츠가 첨부 파일이고 저장되어야 함을 지정하는 또 다른 방법이 있습니다. Content-Disposition: filename="xxxxx"
Example: header('Content-Disposition: attachment; filename=" download.pdf"'
요청
4×× 클라이언트 오류
5×× 서버 오류

구문: ​​

header(string,replace,http_response_code)

매개변수
문자열: 필수. 전송할 헤더
문자열
을 지정합니다.

교체: 선택 사항입니다. 이 헤더가 이전 헤더를 대체하는지 아니면 두 번째 헤더를 추가하는지 여부를 나타냅니다. 기본값은 true(교체)입니다. false(동일한 유형의 여러 헤더 허용)

http_response_code: 선택사항. HTTP 응답 코드를 지정된 값으로 강제합니다. (PHP 4 이상에서 사용 가능)
예 1: 웹페이지 리디렉션

   <?php 
      header("Location: http://www.php.cn/");
      exit;
   ?>

예 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"); 
  ?>

예제 3:

접근 제어에 주로 사용되는 상태 값을 브라우저에 출력합니다.

   <?php  
       header(&#39;HTTP/1.1 401 Unauthorized&#39;);  
       header(&#39;status: 401 Unauthorized&#39;);  
   ?>

예제 4:

사용자가 이 페이지에 접근하는 것을 제한하려면 아래와 같이 상태를 404로 설정하면 됩니다. 브라우저 페이지가 존재하지 않는다고 표시됩니다

   <?php  
       header(&#39;HTTP/1.1    404    Not Found&#39;);  
       header("status:    404    Not Found"); //这种写法错误
   ?>

예제 5:

파일 위치 숨기기


html 태그

964063332538fb740a260abbbb0bad4216ef26f8b7ea0fc89bdf90e275a93e5d 이는 일반적인

파일 다운로드
를 통해 달성할 수 있습니다. 파일을 기밀로 유지하고 싶고 다른 사람에게 파일 링크를 알릴 수 없는 경우 헤더 기능을 사용하여 파일을 다운로드할 수 있습니다.

header("Content-type: audio/mpeg");
header("Content-Disposition: attachment; filename=filenale");
header("Content-Description: PHP3 Generated Data");
예 6: 헤더 함수 이전에 콘텐츠 입력일반적으로 헤더 함수 이전에는 html 콘텐츠를 출력할 수 없습니다. 마찬가지로 setcookie() 및 세션 함수도 출력 스트림에 추가해야 합니다. . header()가 실행되기 전에 echo 문이 있는 경우 나중에 header()를 만나면 "경고: 헤더 정보를 수정할 수 없습니다. 헤더는 이미 ....에서 전송되었습니다." 오류가 보고됩니다. 즉, 이들 함수 앞에는 텍스트, 빈 줄, 캐리지 리턴 등이 있어서는 안 되며, header() 함수 뒤에 exit() 함수를 추가하는 것이 가장 좋습니다. 예를 들어, 다음과 같은 잘못된 쓰기에는 두 개의 php 코드

섹션 사이에 빈 줄이 있습니다.

<?php
//some code here
?>
//这里应该是一个空行
<?php
    header("http/1.1 403 Forbidden");
    exit();
?>

原因:
PHP脚本开始执行 时,它可以同时发送http消息头部(标题)信息和主体信息. http消息头部(来自 header() 或SetCookie() 函数)并不会立即发送,相反,它被保存到一个列表中. 这样就可以允许你修改标题信息,包括缺省的标题(例如Content-Type 标题).但是,一旦脚本发送了任何非标题的输出(例如,使用 HTML 或 print()调用),那么PHP就必须先发送完所有的Header,然后终止 HTTPheader.而后继续发送主体数据.从这时开始,任何添加或修改Header信息的试图都是不允许的,并会发送上述的错误消息之一。
解决办法:
修改php.ini打开缓存(output_buffering),将output_buffering=0修改成output_buffering=4096
或者在程序中使用缓存函数ob_start(),ob_end_flush() 等。原理是:output_buffering被启用时,在脚本发送输出时,PHP并不发送HTTPheader。相反,它将此输出通过管道(pipe)输入到动态增加的缓存中(只能在PHP4.0中使用,它具有中央化的输出机制)。你仍然可以修改/添加header,或者设置cookie,因为 header实际上并没有发送。当全部脚本终止时,PHP将自动发送HTTP header到浏览器,然后再发送输出缓冲中的内容。

위 내용은 헤더 위치 페이지 점프 실패 이유에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.