我是odata的新手。我已经使用控制器构建了一个web api,如下所示:
using System.Data.Entity;
using System.Data.Entity.Infrastructure;
using System.Web.OData.Routing;
namespace HelloWebApi.Controllers
{
public class TestsController : ODataController
{
//
// GET: /Product/
ProductsContext db = new ProductsContext();
private bool TestExists(int key)
{
return db.tests.Any(p => p.key== key);
}
protected override void Dispose(bool disposing)
{
db.Dispose();
base.Dispose(disposing);
}
[EnableQuery]
public IQueryable<test> Get()
{
return db.tests;
}
模型如下所示:
public class Test
{
[Key]
public int key { get; set; }
public string aaa { get; set; }
}
我还配置了routeconfig,odataconfig,webapi config和global.asax文件,如下所示。
public class RouteConfig
{
public static void RegisterRoutes(RouteCollection routes)
{
routes.Ignore("{resource}.axd/{*pathInfo}");
routes.MapHttpRoute(
name: "Default",
routeTemplate: "{controller}/{action}/{id}"
);
}
}
public class ODataConfig
{
public static void Register(HttpConfiguration config)
{
// Web API routes
config.MapHttpAttributeRoutes();
ODataModelBuilder builder = new ODataConventionModelBuilder();
builder.EntitySet<Test>("Tests");
config.MapODataServiceRoute("odata", "odata", builder.GetEdmModel());
}
}
public static class WebApiConfig
{
public static void Register(HttpConfiguration config)
{
config.Routes.MapHttpRoute(
name: "DefaultApi",
routeTemplate: "api/{controller}/{id}",
defaults: new { id = RouteParameter.Optional }
);
}
}
以下显示的是global.asax文件:
public class WebApiApplication : System.Web.HttpApplication
{
protected void Application_Start()
{
GlobalConfiguration.Configure(config =>
{
ODataConfig.Register(config); //this has to be before WebApi
WebApiConfig.Register(config);
});
//FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
RouteConfig.RegisterRoutes(RouteTable.Routes);
}
}
我尝试做了很多修改。但是我发现Http 404找不到错误。我尝试将[ODataRoute]属性添加到操作方法名称。当这样做时,我得到了Http 406不可接受的响应。
我正在尝试的网址是:http://localhost:6701/odata/tests/其中odata是后缀,tests是控制器名称。请告诉我我做错了什么。
答案 0 :(得分:5)
ODataConventionModelBuilder
配置的路由区分大小写。在您的代码中,您已定义:
builder.EntitySet<Test>("Tests");
基于此,端点将为http://localhost:6701/odata/Tests/(注意大写&#34; T&#34;&#34;测试&#34;)。
这是设计使然,以保持与OData规范的兼容性。
也就是说,从Web API OData 5.4开始,您可以选择使用HttpConfiguration
类EnableCaseInsensitive()
方法启用不区分大小写的路由。例如,您可以添加ODataConfig.Register()
方法:
config.EnableCaseInsensitive(caseInsensitive: true);
有关详细信息,请参阅Microsoft Basic Case Insensitive Support下的ASP.NET Web API for OData V4 Docs。