我想重建我的上一个项目。在过去,我没有使用任何Web API。 我可以使用ODataQueryOptions为我的handler.ashx中的查询执行$ filter,$ orderby,$ top,$ skip ? 有些事情。如何手动在.ashx上创建ODataQueryOptions
var option = new ODataQueryOptions(request.params);
var query = option.ApplyTo(db.products);
我想重建我的上一个项目。在过去,我没有使用任何Web API。 我可以使用ODataQueryOptions为我的handler.ashx中的查询执行$ filter,$ orderby,$ top,$ skip ? 有些事情。如何手动在.ashx上创建ODataQueryOptions
var option = new ODataQueryOptions(request.params);
var query = option.ApplyTo(db.products);
我认为你可以,如果你可以构造一个ODataQueryOptions
的实例。
但是,这是什么:
var option = new ODataQueryOptions(request.params);
的Web API并没有提供这样的构造函数。它是你自己的实现吗?
谢谢。
完成此操作的一种方法是手动构建请求URI并将其设置为ODataQueryOptions
构造函数的请求参数。所以这可能不是原始的海报正在寻找的东西(问题需要一些澄清)。
在我的情况下,我有一个单元测试,我想验证odata选项被应用到我的可查询对象。在下面的示例代码中,假设您正在测试ProductController
,其中包含ProductName字段。基于sfuqua的回答
// Manually set an OData query parameter
const string restUrl = "http://localhost/api/product?$orderby=ProductName";
// Need to construct an HTTP Context and a Request, then inject them into the controller
var config = new HttpConfiguration();
var request = new HttpRequestMessage(HttpMethod.Post, restUrl);
var route = config.Routes.MapHttpRoute(WebApiConfig.DefaultRouteName, "api/{controller}/{id}");
var routeData = new HttpRouteData(route, new HttpRouteValueDictionary { { "controller", "Product" } });
var controller = new ProductController()
{
Request = request,
ControllerContext = new HttpControllerContext(config, routeData, request),
Url = new UrlHelper(request)
};
// Build up the OData query parameters
var modelBuilder = new ODataConventionModelBuilder();
modelBuilder.AddEntity(typeof(Product));
var edmModel = modelBuilder.GetEdmModel();
var oDataQueryContext = new ODataQueryContext(edmModel, typeof(Product));
var oDataQueryOptions = new ODataQueryOptions<Product>(oDataQueryContext, _controller.Request);
// Finally, call the controller
var result = controller.Get(oDataQueryOptions);
上面我做我自己的助手基于OData的乌里OdataQueryOptions类,它的构造:
using System.Linq;
using System.Net.Http;
using System.Web.Http.OData;
using System.Web.Http.OData.Builder;
using System.Web.Http.OData.Query;
namespace OdataHelpers
{
public static class ODataBuilder<T>
{
public static ODataQueryOptions<T> BuildOptions(string oDataUri)
{
var baseUri = "";
var odUri = "";
var spl = oDataUri.Split('?');
if (spl.Count() == 0)
odUri = spl[0];
else
{
baseUri = spl[0];
odUri = spl[1];
}
if (string.IsNullOrEmpty(baseUri))
baseUri = "http://localhost/api/" + typeof(T).Name;
var request = new HttpRequestMessage(HttpMethod.Get, baseUri + "?" + oDataUri.Replace("?", ""));
var modelBuilder = new ODataConventionModelBuilder();
modelBuilder.AddEntity(typeof(T));
var edmModel = modelBuilder.GetEdmModel();
var oDataQueryContext = new ODataQueryContext(edmModel, typeof(T));
return new ODataQueryOptions<T>(oDataQueryContext, request);
}
}
}
使用例:
var OdataStuff = ODataBuilder<CustomerIntView>.BuildOptions("$orderby=Id");
我已将此实现添加到我的ReverseOdataUriParser库: https://开头github上。 COM/Svakinn/ReverseOdataUriMapper – Svakinn 2017-12-29 18:44:45
是的,你可以看到[点击这里] (https://msdn.microsoft.com/en-us/library/system.web.http.odata.query.odataqueryoptions(v=vs.118).aspx) – qujck 2015-02-09 20:13:20