med*_*onn 4 c# content-type multipart asp.net-web-api
我需要能够将多部分响应的Content-Type值设置为:
Content-Type: multipart/related; type=application/dicom; boundary={MessageBoundary}
Run Code Online (Sandbox Code Playgroud)
这是在国际标准中定义的,所以我别无选择,我看到使用"type = xxx/yyy"是在MultiPart消息中定义"主要"内容类型的标准用法.
但是......我还没有找到一种方法来使用Web API中优秀的MultipartContent类来生成这个字符串.我试过了:
1)什么都不做 - 希望它从内容中的第一个项目中获取 - 它没有
2)设置为子类型的一部分 - 例如:
MultipartContent mpc = new MultipartContent("related; type=application/dicom+xml");
Run Code Online (Sandbox Code Playgroud)
这失败,错误"值的格式'multipart/related; type = application/dicom + xml'无效."
3)明确设置为MediaTypeHeadervalue上的另一个参数:
var mthv = new MediaTypeHeaderValue("multipart/related");
mthv.Parameters.Add(new NameValueHeaderValue("type", "application/dicom+xml"));
Run Code Online (Sandbox Code Playgroud)
这给出了同样的错误:-(
我在这里遗漏了一些明显的东西,还是真的没有办法表明相关的类型?
更新:
经过一些研究,并反编译NameValueHeaderValue类,似乎问题是类型值中的/和+字符 - 因为NameValueHeaderValue的构造函数检查名称和令牌,以查看它们的本机和"仅令牌字符"版本具有相同的长度 - 即它们是否包含任何非令牌字符 - 如果是这种情况则拒绝它们.鉴于类型值的标准值是MIME类型,根据定义,它包含/字符,这似乎是一个过度且不恰当的严格约束.
你是正确的,因为问题在于类型值中的字符/和+字符,但是在拒绝输入时.NET并不完全错误(我可能希望API的这一部分设计得更好,但我知道的是什么).指定MIME的RFC 2045(第5.1节)表示,如果参数值包含任何参数值,则必须引用它们()<>@,;:\"/[]?=.RFC 2387描述了多部分/相关内容类型,它表示参数值通常需要引用,并且它们给出的示例具有正确引用的从属内容类型值.至于你的具体问题,例如这应该有效:
var mpc = new MultipartContent ("related") ;
var nvv = new NameValueHeaderValue ("type", "\"application/dicom+xml\"") ;
mpc.Headers.ContentType.Parameters.Add (nvv) ;
Run Code Online (Sandbox Code Playgroud)