我花了好几天才知道我工作的问题,但没有运气.
>我创建了新的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 { }
原文地址:https://www.jb51.cc/aspnet/251631.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。