[英]WebAPI v2 - JSON Serialization for OData expand causes $type to be incorrect
[英]OData Library v3 JSON entry serialization includes: “__metadata”: { “id”
使用OData Library October '11 CTP使用v3序列化条目我得到以下内容:
{
"d":{
"__metadata": {
"id":"http://dev.foo.bar/Statuses(7)",
"type":"Presentation.Status"
},
"Description":"Testing..."
}
}
在v3规范中,示例如下:
DataServiceVersion:3.0
{
"d": {
"__metadata": {
"uri": "Customers(\'ALFKI\')",
"type": "SampleModel.Customer",
....
规范使用_ metadata / uri, Libary 使用“ _metadata / id”。 在[2.2.6.3.3实体类型(作为JSON对象)]一节中,规范说明:
EntityType实例MAY <58>的JavaScript Object Notation(JSON)序列化包括名为“_ metadata”的名称/值对。 此名称/值对不是数据,而是按照本文档中定义的约定,指定JSON对象表示的EntityType实例的元数据。 此名称/值对与表示在实体类型上定义的属性的其他名称/值对的排序是无关紧要的。 在OData协议的1.0版和2.0版中,“ _ metadata”属性的值包含七个名称/值对:“uri”,“type”,“etag”,“edit_media”,“media_src”,“media_etag”,和“content_type”。 在OData协议的3.0版本中,增加了三个名称/值对:“属性”,“操作”和“功能”。 这些名称/值对的顺序无关紧要。 “uri”名称/值对的值必须是标识由JSON对象表示的EntityType实例的规范URI。
看起来OData库的当前CTP错误地发出“id”,它应该发出“uri”,就像uriNVP一样 - 定义如下:
metadataNVP = quotation-mark "__metadata" quotation-mark
name-seperator
begin-object
( uriNVP
....
uriNVP = quotation-mark "uri" quotation-mark
name-seperator
quotation-mark resourcePath quotation-mark
图书馆是不正确的 - 或者我错过了什么或使用不正确?
从5.0 RTM开始,JSON支持消失了吗? WTF? 为什么以及如何取回?
if (((ODataVersion) settings.Version) == ODataVersion.V3)
{
specifiedTypes = RemoveApplicationJsonFromAcceptableMediaTypes(specifiedTypes, mediaTypesForPayloadKind, settings.AcceptableMediaTypes);
}
这是来自的代码
internal static ODataFormat GetContentTypeFromSettings(ODataMessageWriterSettings settings, ODataPayloadKind payloadKind, MediaTypeResolver mediaTypeResolver, out MediaType mediaType, out Encoding encoding)
V3规范尚未完成。 我们确实将id属性添加到OData库中,它还没有进入官方规范。 请注意,id和uri是两个不同的东西。
id属性是ODataEntry.Id属性的值。 它应该是标识实体的全局唯一URI。 它不必是有效的URL,因此例如“urn:myentity:id1”完全没问题。 它与ATOM表示中的id元素的值相同。
uri属性是编辑或读取链接。 所以它是ODataEntry.EditLink的值,或者如果它为null,则它是ODataEntry.ReadLink的值。 这必须是有效的URL,可用于读取和/或修改实体。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.