- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
HTTP/1.1 Accept
请求 header 在 RFC 2616, section 14.1 中指定.
它的语法是这样的:
Accept = "Accept" ":"
#( media-range [ accept-params ] )
#
根据section 2.1,没有任何数字状态零个或多个 .但是,第 14.1 节没有说明如何解释空的 Accept
。 header 。这与 section 14.2 形成对比,其中谈到 Accept-Encoding
,其中不仅1#
使用(一个或多个),但对于空的 Accept-Encoding
也是如此 header 已指定,这有点奇怪。其他一些处理请求 header 的部分也特定于空值的特殊情况。
一个人应该对待一个空的 Accept
标题等同于不存在 Accept
标题?我错过了这方面的任何官方资源吗?
最佳答案
来自 RFC2616 Sec4.2 :
Each header field consists of a name followed by a colon (":") and the field value.
乍一看,这似乎将指定空 header 值的邮件置于格式错误、不合规的类别中。然而,RFC2616 Sec2.1 中概述的增强 BNF 形式表示
"#element" allows any number, including zero
由于这是用于指定 Accept header 值的声明,因此空值似乎是有效的。
由于规范中的以下指示,解析空 header 和仅包含空格的 header 可能会出现问题:
The field-content does not include any leading or trailing LWS: linear white space occurring before the first non-whitespace character of the field-value or after the last non-whitespace character of the field-value. Such leading or trailing LWS MAY be removed without changing the semantics of the field value. Any LWS that occurs between field-content MAY be replaced with a single SP before interpreting the field value or forwarding the message downstream.
恕我直言,发送空 header 完全没有意义。不应该这样做,解析器可能无法正确解析这些 header 。传统上,在处理不兼容组件时想要规避此类限制的人会指定如下“伪空”值:
X-MyCustomHeader: ""
如果您只是想验证 header 字段是否作为某种形式的 bool 开关发送,请考虑发送像上面这样的占位符值而不是空值。
更新
我想我在直接回答问题时不是很清楚:在空的 Accept header 的情况下,您确实有两个选择:
406 Not Acceptable
响应以通知客户您不提供任何内容类型以接受空的 Accept 值 (duh)。这是合理的,但不是 RFC2616 Sec14.1 所要求的:
If an Accept header field is present, and if the server cannot send a response which is acceptable according to the combined Accept field value, then the server SHOULD send a 406 (not acceptable) response.
Accept:
值(如果消息拒绝不是一个选项)与 Accept: */*
相同。关于http - 如何解释空的 HTTP Accept header ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12130910/
在 HTTP 中,您可以在请求中指定您的客户端可以使用 accept header 接受响应中的特定内容,其值如 application/xml。内容类型规范允许您在内容类型中包含参数,例如chars
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 Improve th
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 3 年前。 Improve th
我的 RESTFul API 只能响应 JSON 编码的数据(即我所有的 header 都有 Content-Type: application/json)。如果请求具有不允许 JSON 的 Acce
我有 C linux TCP 客户端/服务器应用程序。我想出了一个奇怪的场景,但我不知道这个应用程序是否有任何后果。我有一个可以接受 N 个连接的服务器端,例如这个服务器将接受 100 个连接。在这种
我试图找出 的可能值范围接受 和 接受-联系 header 字段,但我在 RFC 中找不到完整列表。有谁知道他们在哪里?我经常看到 Accept: application/sdp;level=1,
在 TCP 套接字代码中,我们创建了 2 个套接字。第一个接受新连接,第二个接受来自客户端的数据并在新连接建立时创建。 TCP header 中的哪个控制位允许服务器知道将此段传递给 ServerSo
我可以设置 Request.Content-Type = ... , Request.Content-Length = ... 如何设置Accept和Accept-Language? 我想上传一个文件
假设A是服务器,B是客户端。 B 创建一个到服务器 A 的套接字 b 并 ServerSocket.accept() 创建一个相应的套接字 a 对于客户端 B 现在,如果服务器 A 关闭了 a 但客户
如果客户端connect()先于服务端accept()成功,那么客户端如何知道服务端accept()成功呢?如果在 connect() 成功和服务器 accept() 之间的时间间隔调用 send()
这是我的代码: void error(const char *msg) { perror(msg); exit(1); } void sServer::acceptClientConn
在我的 pom.xml 中有以下详细信息 org.codehaus.jackson jackson-core-asl 1.9.13
假设我有两个如下所示的端点: @GET @Path("/blah") @Produces(MIME_TYPE_1) public Thing getThing() { .... } @GET
我的 Controller : @RestController public class ClawerController { @RequestMapping("/hello"
我不想要可视化 merge 工具,我也不希望必须 vi 冲突文件并手动在 HEAD(我的)和导入的更改(他们的)之间进行选择。大多数时候,我要么想要他们的所有更改,要么想要我的所有更改。通常这是因为我
我正在使用 spring 4.1.1.RELEASE 并包括: pom 中的 jackson-core-asl 1.9.13 和 jackson-mapper-asl 1.9.13 来创建一个带有 R
我正在尝试开发自己的基于非阻塞 NIO 消息的通信库。我已经阅读了 1000 个关于它的教程和书籍章节,我认为最终我得到了一些可以在很少的同时连接下工作的东西。但是当我在服务器端共存许多连接时,我遇到
我正在尝试编写一个 Bind 元编程模板辅助元函数,将模板参数绑定(bind)到某物。 我有一个简单的模板元函数的工作实现: template struct MakePair { using
我使用 spring 构建 Restful API,当我访问以下方法时: // get the entity in DB by using id number @RequestMapping(
只是想知道是否有一种方法可以通过 ASP.NET Core 中的属性强制检查 HTTP header 值是否属于一组给定值(例如 application/json,应用程序/xml) 我知道有 Pro
我是一名优秀的程序员,十分优秀!