我想“拦截”/改变在使用OD API与Web API时生成的OData查询..但我不完全确定如何“提取”生成的查询..我假设OData过滤器,扩展和更多的一些如何生成某种表达式树或某种查询…如果是这种情况,那么我希望能够在它作为sql命令发送到数据库之前更改的查询类型.
我在网上搜索了一些提取生成的表达式树的方法..但是无法找到足够的信息,所以我有点希望有人能更深入地了解整个OData-“框架”是如何工作的..
任何从哪里开始的想法?
解决方法
您可以在执行之前更改Odata网址.继承自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; } }
[HttpGet] [EnableQueryForGuid] [ODaTaroute("GetSomething")] public IHttpActionResult GetSomething() { .... }
原始查询:
OData/GetSomething?&$filter=MyGuid%20eq%20%272C3C7BC0EC7FA248B0DEE3DAA371EE73%27
更改查询:
OData/GetSomething?&$filter=MyGuid%20eq%20e5794d6a-5db1-475a-8c49-0f91a8f53c8a
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。