我是OData的新手。我已经建立了一个ASP.NET Web API控制器,如下所示:
using System.Data.Entity;
using System.Data.Entity.Infrastructure;
using System.Web.OData.Routing;
namespace HelloWebApi.Controllers
{
public class TestsController : ODataController
{
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
,ODdataConfig
和WebApiConfig
,如下所示:
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 Not Found响应。我还尝试将[ODataRoute]
属性显式添加到操作方法名称中;这样做时,我得到的是HTTP 406不可接受的响应。
我要配置的URL是:
http://localhost:6701/odata/tests/
odata
是后缀,tests
是控制器名称。请指出我做错了。
ODataConventionModelBuilder
配置的路由区分大小写。在您的代码中,您定义了:
ODataConventionModelBuilder
基于此,端点将为builder.EntitySet<Test>("Tests");
(注意“测试”中的大写字母“ T”)。
这是设计使然,以保持与OData规范的兼容性。
也就是说,从http://localhost:6701/odata/Tests/开始,您可以选择使用Web API OData 5.4类的HttpConfiguration
方法启用不区分大小写的路由。例如,您可以在EnableCaseInsensitive()
方法中添加:
ODataConfig.Register()
有关更多信息,请参见Microsoft的config.EnableCaseInsensitive(caseInsensitive: true);
下的Basic Case Insensitive Support。