• WebApi Serialize Entity Framework objects into JSON(webapi下将实体对象序列化为Json)


    情景描述:

    在ASP.NET MVC 4 WebApi框架下,将Linq To Entity查询出来的实体对象序列化为Json格式传回客户端。

    问题一: 出现Loop Reference问题导致无法正常序列化查询出来的数据项为Json格式。

    通常解决方案是设置entity framework停用LazyLoading和ProxyCreation,这样序列化单个对象获取的数据可能并不满足前台所需。

    http://www.dotblogs.com.tw/programlin/archive/2012/10/15/77500.aspx

    此时往往需要使用自定义数据传输对象来填充数据。

    问题二: 每次需定义DTO数据传输对象比较繁琐。

    比较理想的解决方案是通过使用匿名对象Anonymous Type,将需要获取数据填充到匿名对象最后序列化为Json。

    如 return Entity.jobs.Select(p => new

    {
    ID = p.ID,
    Subject = p.Subject,
    Description = p.Description,
    ShowCreatedDate = p.ShowCreatedDate,
    Nickname = p.Nickname,

    Proposals=p.Proposals

    }).ToList()

    );

    其中ShowCreatedDate是由Job partial class添加的拓展属性计算出来的,Proposals是Job的导航对象。

    很方便通过Entity Framework延迟查询功能取出所需数据,最后由匿名对象包装序列化传回到前台。

  • 相关阅读:
    GITHUB常见命令
    GITHUB常用命令
    java构建简单的HTTP服务器
    是否会被锁
    GITHUB使用指南
    GITHUB使用指南、
    C#
    金蝶后台表对应
    金蝶K3表
    nodejs nodejs的操作
  • 原文地址:https://www.cnblogs.com/lushuicongsheng/p/2870394.html
Copyright © 2020-2023  润新知