asp.net-web-api – 为什么我的超级简单的ASP.NET Web API(mvc4)实体框架5不起作用?

我花了好几天才知道我工作的问题,但没有运气.

>我创建了新的MVC4 Web API项目.
>使用我的数据库添加EF5(项目>添加> ADO.NET实体数据模型>从Azure sql中的数据库创建).
>将两个表添加到edmx,如下所示.两个* .tt文件成功生成实体和模型类.

我可以看到断点(结果)正常给出查询结果.
但json提供异常流而没有错误消息. (即,http:// localhost:41813 / api / sheet / 157返回“157”,无法下载.一般情况下,“157.json”已下载)

我将结果中的属性复制到我手工制作的POCO风格的类中,并且它有效.

我的问题是什么?我无法使用生成的模型类通过Json发送数据.
我几乎没有发现问题,因为在结果断点之后没有错误消息和可用的调试步骤.

解决方法

序列化失败的原因是您的导航属性 – 当序列化程序尝试遍历对象图时,它们会导致循环依赖.

为了使您的简单样本工作,您几乎没有办法解决它.

>从SheetDetail中删除导航属性
>在viewmodel类中包装您的对象,省略Navigation属性
>使用JsonIgnoreAttribute创建元数据类,然后使用partial class和MetadataTypeAttribute将其附加到您的实体

在这里你可以找到第三个解决方案的样本(样本做了一些假设,因为我不知道你的确切数据类型):

public class SheetDetailSerializationMetadata
{
    [JsonIgnore]
    public Sheet Sheet { get; set; }
}

[MetadataType(typeof(SheetDetailSerializationMetadata))]
public partial class SheetDetail
{ 
}

相关文章

### 创建一个gRPC服务项目(grpc服务端)和一个 webapi项目(...
一、SiganlR 使用的协议类型 1.websocket即时通讯协议 2.Ser...
.Net 6 WebApi 项目 在Linux系统上 打包成Docker镜像,发布为...
一、 PD简介PowerDesigner 是一个集所有现代建模技术于一身的...
一、存储过程 存储过程就像数据库中运行的方法(函数) 优点:...
一、Ueditor的下载 1、百度编辑器下载地址:http://ueditor....