- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在创建一个简单的项目来测试 Entity Framework 中的功能。在前端,我想要一个 SPA 应用程序,它使用 OData API 与服务器交互。我如下设置我的第一个 ODataController
public class BlogPostsController : ODataController
{
private readonly IBlogPostService _blogPostService;
public BlogPostsController(
IBlogPostService blogPostService)
{
_blogPostService = blogPostService;
}
[HttpGet]
[EnableQuery]
public IQueryable<BlogPost> GetBlogPosts()
{
return _blogPostService.Queryable();
}
[EnableQuery]
public SingleResult<BlogPost> GetBlogPost([FromODataUri] int key)
{
return SingleResult.Create(_blogPostService.Queryable().Where(bp => bp.Id == key));
}
}
我的 ODataConfig 设置如下
public static class ODataConfig
{
public static void Register(HttpConfiguration config)
{
var builder = new ODataConventionModelBuilder();
builder.EntitySet<Entities.BlogPost>(typeof(Entities.BlogPost).Name);
config.Routes.MapODataServiceRoute("odata", "odata", builder.GetEdmModel());
config.AddODataQueryFilter();
}
}
我的网站托管在我机器上的 IIS 中,当我访问 http://localhost/mytestsite/odata/BlogPosts 时我得到一个 404。但是,如果我更改我的代码以更改我的 Controller 以将 BlogPosts 替换为 BlogPost,那么我可以访问 url http://localhost/mytestsite/odata/BlogPost一切都按预期工作。我的工作 Controller 在下面
public class BlogPostController : ODataController
{
private readonly IBlogPostService _blogPostService;
public BlogPostController(
IBlogPostService blogPostService)
{
_blogPostService = blogPostService;
}
[HttpGet]
[EnableQuery]
public IQueryable<BlogPost> GetBlogPost()
{
return _blogPostService.Queryable();
}
[EnableQuery]
public SingleResult<BlogPost> GetBlogPost([FromODataUri] int key)
{
return SingleResult.Create(_blogPostService.Queryable().Where(bp => bp.Id == key));
}
}
另一个问题是如果我尝试访问 http://localhost/FourTen.Blog.Web/odata/blogpost我也得到了 404。唯一的区别是 URL 中的 blogpost 是小写的。
我的问题是,我是否遗漏了一些命名约定,为什么 URL 区分大小写?
最佳答案
它不起作用的原因是您的配置。您使用名称 BlogPost 注册您的 EntitySet
如果您将其替换为 BlogPosts 它应该可以工作。
builder.EntitySet<Entities.BlogPost>(typeof(Entities.BlogPost).Name);
builder.EntitySet<Entities.BlogPost>("BlogPosts");
关于c# - 为什么让我的 ODataController 有一个复数名称会阻止它工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28851568/
我正在创建一个简单的项目来测试 Entity Framework 中的功能。在前端,我想要一个 SPA 应用程序,它使用 OData API 与服务器交互。我如下设置我的第一个 ODataContro
在 OData v4 Controller 中,是否可以为 Get() 和 Get([FromIDataUri] key) 返回不同的模型? 我喜欢使用 ViewModel,当使用 Get() 方法时
我正在开发一个通过 OData 提供数据的应用程序。我正在使用 ASP.Net 和 ODataControllers 通过 EF 查询——数据由 SQLServer 数据库支持。 在可视化这些数据的前
我有一个作为 MEF 插件实现的 ODataController。该 Controller 在启动时从服务器应用程序加载。我在服务器应用程序中创建了另外 3 个 ODataController,它允许
更新 投票here on User Voice解决歧义。 我编写了一个继承于 ODataController 的 OData WebAPI Controller 。 . public class Ma
我有课,MyClassController继承自 ODataController .我已经能够使用“自动”路由来访问缩放器集合类型的属性,例如 /path/to/MyClass(100)/SomePr
我正在 Web API 2.2 上构建 OData 3 服务。 该服务正确返回我的实体的元数据,但当我查询其中一个实际实体时返回 406 Not Available。我已经做了相当多的研究(我目前正在
谁能解释我什么时候应该继承我的 Controller 表单ODataController对比 ApiController ? 问题是由 ApiController 返回的结果引起的。可以使用 ODat
在将 OData 添加到我的项目之前,我的路线设置如下: config.Routes.MapHttpRoute( name: "ApiById",
我有一个带有 Int64 列的数据对象: [TableAttribute(Name="dbo.vw_RelationLineOfBusiness")] [DataServiceKey("Provide
我编写了一个继承自 ODataController 的 OData WebAPI Controller . public class ManyColumnsController : ODataCont
我正在为我的应用程序 OData Controller 实现一个通用基础 Controller 。这个 Controller 有一个像这样的方法: [EnableQuery(AllowedQueryO
我正在尝试抽象 VS 2013 中自动生成的 ODataController 类,因为除了 POCO 的名称之外,不同 Controller 的代码看起来相同,因此,我做了以下操作: public
如何在 odatacontroller 中删除 asp.net odata.metadata 属性。 我有以下代码: public IHttpActionResult GetCompanyViewM
我正在尝试从我们当前的 ApiController 实现转移到 ODataController,因为这是我发现可以启用返回 OData Json 格式数据的唯一方法。 (与问题 here 相同,但解决
谁能列出 WebAPI 和 OData Controller 之间的区别? 最佳答案 WebApi 是一种应用程序类型(可能是一个框架),用于促进不同平台(web、mobile、windows)之间的
我是一名优秀的程序员,十分优秀!