1

首先,OData 响应的标准规范如下所示:

{
    "d" : {
        "results": [
            {
                "__metadata": {
                    "uri": "http://demos/Orders(10248)",
                    "type": "SampleModel.Order"
                },
                "ProductId": 10248,
                "Name": "Vgnon"
            }
        ],
        "__count": "1"
    }
}

但是,在 Web API(使用 EntitySetController)中,OData 响应如下所示:

    {
            "odata.metadata":"http://localhost:43111/api/$metadata#Products",
            "odata.count":"1",
            "value":
            [
                {
                  "ProductId":2,
                  "CreatedDate":"2013-06-10T23:53:26",
                  "CreatedBy":0,"Name":"Camera"
                }
            ]
        }

注意两个响应中的计数。Web API 是否遵循 OData 标准规范?

此外,正如这个 SO 问题所指出的:Web API OData Inlinecount not working 答案是这样的:

开箱即用的 $inlinecount 仅在您发回 OData 响应时才有效。

这是否意味着在 Web API(使用 EntitySetController 或 ODataController)中我们可以返回 OData 响应和非 OData 响应?或者我应该说,标准 OData 响应和非标准 OData 响应?

4

1 回答 1

8

WebAPI OData 实现确实遵循 OData 规范。您在问题顶部包含的 JSON 是旧的 OData JSON 格式,现在通常称为“详细 JSON”。WebAPI 生成的 JSON 格式是 OData v3 及更高版本的新 OData JSON 格式。WCF 数据服务将为 v3 服务中的“application/json”媒体类型生成相同的格式。

如果您想要旧格式,请尝试发送“application/json;odata=verbose”的 Accept 标头。

请查看此处的规范以了解新 JSON 格式的说明:http: //docs.oasis-open.org/odata/odata-json-format/v4.0/csprd01/odata-json-format-v4。 0-csprd01.html (请注意,这是 OData v4 规范,尚未最终确定,但其中关于 JSON 格式的大部分描述也适用于 v3)。

于 2013-06-13T23:00:31.443 回答