1

我试图:

    [EnableQuery]
    [HttpGet]
    [ODataRoute("")]
    public IHttpActionResult Get(ODataQueryOptions<UserODataModel> options)
    {
        var users = _repository.RetrieveOData();
       
        var serialQuery = JsonConvert.SerializeObject(options, jsonOptions);
        
        //save serialQuery somewhere

        return Ok(users);
    }

但是得到了

Newtonsoft.Json.JsonSerializationException:'从'Microsoft.Owin.Host.SystemWeb.CallStreams.InputStream'上的'ReadTimeout'获取值时出错。'

“此流不支持超时。”

我知道已经有一个关于序列化 Stream 的问题:

Newtonsoft Json.net - 如何序列化流的内容?

但在这种情况下,我不能从中“提取流值” ODataQueryOptions,或者我可以吗?

一些想法?

4

2 回答 2

2

由于我们在同一家公司工作,如果有人感兴趣,我们找到了一种方法,也许不是很好的方法来序列化 ODataQueryOptions:

    public static ODataQueryOptions DeserializeQueryOptions(SerializedQueryOptions options)
    {
        var uri = new Uri(teste.OriginalUri);
        var model = ODataConfig.Model; //GetEdmModel
        var segment = model.EntityContainer.FindEntitySet(options.EdmType);
        var newPath = new Microsoft.AspNet.OData.Routing.ODataPath(new EntitySetSegment(segment));

        var httpConfiguration = new HttpConfiguration();
        httpConfiguration.EnableDependencyInjection();
        var request = new HttpRequestMessage(HttpMethod.Get, uri)
        {
            Properties =
            {
                { HttpPropertyKeys.HttpConfigurationKey, httpConfiguration },
            }
        };

        var context = new ODataQueryContext(model, options.EntityType, newPath);
        var oDataQueryOptions = new ODataQueryOptions(context, request);

        return oDataQueryOptions;
    }

    public static SerializedQueryOptions SerializeQueryOptions(ODataQueryOptions options)
    {
        return new SerializedQueryOptions
        {
            OriginalUri = options.Request.RequestUri.AbsoluteUri,
            EdmType = options.Context.NavigationSource.Name,
            EntityType = options.Context.ElementClrType
        };
    }

将其序列化为对象后,您可以将其序列化为 JSON 字符串:

    var queryOptionsSerialized = new SerializedQueryOptions()
    {
        OriginalUri = "http://localhost:25723/odata/users?$skip=0&$top=2&$orderby=fullName&$count=true",
        EdmType = "users",
        EntityType = typeof(UserODataModel)
    };

    var json = JsonConvert.SerializeObject(queryOptionsSerialized);
    var deserialized = JsonConvert.DeserializeObject<SerializedQueryOptions>(json);

    var options = ODataQueryOptionsHelper.DeserializeQueryOptions(deserialized);
于 2019-06-18T18:36:13.357 回答
0

如果 One 不使用 OData 路由或使用 ApiController(不是 ODataController),则将获取 ODataPath 的方式修改为:

ODataUriParser parser = new ODataUriParser(model, serviceRoot, requestUri);
ODataPath path = parser.ParsePath();
//var newPath = new Microsoft.AspNet.OData.Routing.ODataPath(new EntitySetSegment(segment));
Microsoft.AspNet.OData.Routing.ODataPath newPath = new Microsoft.AspNet.OData.Routing.ODataPath(path.FirstOrDefault());

其中serviceRoot是模型中定义的路径以外的 Url 部分。

于 2021-04-22T11:27:54.487 回答