拦截OData“查询”

Inx*_*x51 5 .net c# odata asp.net-web-api

我想“拦截” /更改将OData与Web API一起使用时所生成的OData查询。但是我不确定如何“提取”所生成的查询。.我假设OData过滤器会展开并扩展更多有关如何生成某种表达式树或某种查询的信息..如果是这种情况,那就是我希望能够在将其作为SQL命令发送到数据库之前进行更改的查询类型。

我已经在网上搜索了某种提取生成的表达式树的方法..但是找不到足够的信息,所以我希望这里的人对整个OData-“框架”的工作原理有更多的了解。 ..

关于从哪里开始的任何想法?

oza*_*mut 2

您可以在执行之前更改 Odata url。继承EnableQueryAttribute类并更改url。以下是在将 guid 字符串格式发送到 oracle 之前将其更改为十六进制字符串格式的真实案例。

public class EnableQueryForGuid : EnableQueryAttribute
{
    public override void OnActionExecuting(HttpActionContext actionContext)
    {
        var url = actionContext.Request.RequestUri.OriginalString;

        var newUrl = ModifyUrl(url);

        actionContext.Request.RequestUri = new Uri(newUrl);
        base.OnActionExecuting(actionContext);
    }

    private string ModifyUrl(string url)
    {
        Regex regex = new Regex(@"%27([A-Za-z0-9]{32})%27");
        var res = regex.Matches(url);
        if (res.Count > 0)
        {
            var guidPart = res[0].Value.Remove(0, 3);
            guidPart = guidPart.Remove(guidPart.Length - 3, 3);
            var guidValue = new Guid(BitConverter.ToString((new Guid(guidPart)).ToByteArray()).Replace("-", ""));
            url = url.Replace(res[0].Value, guidValue.ToString());
        }
        return url;
    }
}
Run Code Online (Sandbox Code Playgroud)

然后在您的控制器方法上使用这个新属性:

    [HttpGet]
    [EnableQueryForGuid]
    [ODataRoute("GetSomething")]
    public IHttpActionResult GetSomething()
    {
      ....
    }
Run Code Online (Sandbox Code Playgroud)

原始查询:

OData/GetSomething?&$filter=MyGuid%20eq%20%272C3C7BC0EC7FA248B0DEE3DAA371EE73%27

更改后的查询:

OData/GetSomething?&$filter=MyGuid%20eq%20e5794d6a-5db1-475a-8c49-0f91a8f53c8a