JSON:API规范中Accept头部多扩展参数的正确语法解析
在JSON:API规范的实际应用中,开发者经常会遇到需要同时使用多个扩展(extensions)的情况。本文将从HTTP协议规范和JSON:API规范两个维度,深入解析Accept头部携带多个扩展参数的正确语法格式。
HTTP协议对媒体类型参数的规定
根据HTTP/1.1规范(RFC 9110),媒体类型参数通常由分号(;)分隔。按照这个规则,直觉上可能会认为每个扩展都应该作为独立的参数列出,例如:
Accept: application/vnd.api+json;ext="https://my-ext1";ext="https://my-ext2"
这种格式在技术上符合HTTP协议对媒体类型参数的基本定义,每个扩展都作为一个独立的ext参数出现。
JSON:API的特殊规范要求
然而,JSON:API规范对ext和profile参数做出了更具体的规定。规范明确指出:
ext和profile参数的值必须是一个用空格(U+0020)分隔的扩展或profile URI列表
这意味着JSON:API规范实际上覆盖了HTTP协议的一般规则,为这些参数定义了特定的序列化格式。正确的语法应该是:
Accept: application/vnd.api+json;ext="https://my-ext1 https://my-ext2"
技术实现要点
-
单一参数原则:ext参数在Accept头部中只能出现一次,所有扩展URI都包含在这个单一参数的值中
-
分隔符要求:扩展URI之间必须使用空格字符(ASCII 32)分隔,不能使用逗号、分号等其他分隔符
-
引号使用:整个扩展列表应该被包含在双引号中,形成一个完整的参数值
-
URI编码:如果扩展URI本身包含空格等特殊字符,需要进行适当的百分号编码
实际应用建议
在实际开发中,建议开发者:
-
使用JSON:API客户端库自动处理这些细节,避免手动构造Accept头部
-
如果需要手动构造,确保严格遵循空格分隔的格式要求
-
在API测试中,特别验证服务器对多扩展Accept头部的处理是否符合预期
-
注意与profile参数的组合使用,这两个参数是独立的,可以同时出现在Accept头部中
理解这些细节对于实现完全兼容JSON:API规范的客户端非常重要,特别是在需要同时使用多个扩展功能的复杂应用场景中。
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin07
compass-metrics-modelMetrics model project for the OSS CompassPython00