> 백엔드 개발 > PHP 튜토리얼 > php请求重写向的一个问题

php请求重写向的一个问题

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
풀어 주다: 2016-06-20 12:35:10
원래의
1006명이 탐색했습니다.

php请求重写向的一个问题


同事叫我帮忙解释一个问题:一个PHP生成的重定向请求,在Nginx日志里产生两种截然不同的记录:一种响应体大小是零个字节;另一种响应体大小是五个字节。


现在年纪大了,面对问题时的嗅觉不再灵敏,第一感觉零是正确的,心想是不是重定向后忘记退出了,后面还有内容输出,可是查了一下代码发现没有问题:


1

2

3

4

header('Location: /path');

exit;

?>

在绕了一大圈之后,我猛然意识到环境是Nginx+PHP,响应没有「Content-Length」,数据是通过「Transfer-Encoding」分块发送的,所以重定向的空响应体实际类似:


0\r\n\r\n

不多不少,正好五个字节,细节大家可以参考Chunked transfer encoding。如此看来在此类空响应体的情况下,PHP主动输出一个「Content-Length: 0」说不定会更好些。


那零个字节的响应如何解释呢?查询日志发现如下两种情况:


HEAD “/path HTTP/1.1” 302 0

GET “/path HTTP/1.0” 302 0

前者是HEAD请求,不需要响应体;后者是HTTP/1.0,不支持「Transfer-Encoding」。


问题基本解释清楚了,擦擦额头的汗,总算没在同事面前丢脸。


转自:一个HTTP小问题


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