在一篇博客文章中,我使用下面的PHP来设置响应的内容类型:

header('content-type: application/json; charset=utf-8');

我刚刚在那篇文章上得到了一条评论,说content-type需要大写,content-type。这对吗?它似乎适用于所有小写的情况,并且我假设HTTP头是不区分大小写的。或者仅仅是因为浏览器很好?


当前回答

正式来说,头是不区分大小写的,但是,通常的做法是将每个单词的第一个字母大写。 但是,因为这是常见的做法,某些程序,如IE,假设头文件是大写的。 所以当文档说它们不区分大小写时,糟糕的程序员基本上已经改变了文档。

其他回答

正式来说,头是不区分大小写的,但是,通常的做法是将每个单词的第一个字母大写。 但是,因为这是常见的做法,某些程序,如IE,假设头文件是大写的。 所以当文档说它们不区分大小写时,糟糕的程序员基本上已经改变了文档。

它们不区分大小写。事实上,在请求对象中可用之前,NodeJS web服务器会显式地将它们转换为小写。

这里需要注意的是,所有头文件都用 只使用小写,不管客户端实际是如何发送它们的。这 简化了出于任何目的解析头的任务。

tldr;HTTP/1.1和HTTP/2报头都不区分大小写。

根据RFC 7230 (HTTP/1.1):

每个报头字段由一个不区分大小写的字段名组成 后面跟着一个冒号(“:”),可选的前导空格,字段 值,以及可选的尾随空格。

https://www.rfc-editor.org/rfc/rfc7230#section-3.2

另外,RFC 7540 (HTTP/2):

就像在HTTP/1。x,报头字段名是ASCII字符串 不区分大小写进行比较的字符。

https://www.rfc-editor.org/rfc/rfc7540#section-8.1.2

HTTP的RFC(如上所述)规定header是不区分大小写的,但是你会发现在某些浏览器中(我在看你,IE),每个单词的大写往往是最好的:

Location: http://stackoverflow.com

Content-Type: text/plain

vs

location: http://stackoverflow.com

content-type: text/plain

这不是“HTTP”标准,只是浏览器的另一个怪癖,我们作为开发人员必须考虑。

标头名称不区分大小写。

来自RFC 2616 -“超文本传输协议—HTTP/1.1”,章节4.2,“消息头”:

每个报头字段由一个名称后跟冒号(“:”)和字段值组成。字段名不区分大小写。

更新的RFC 7230没有列出RFC 2616在此部分的任何更改。