c# – 带有外键的ASP.NET WebApi JSON响应和实体

我正在开发WebApi项目,我的域名中有2个实体:

public class Street
{
  public int ID { get; set; }
  public string Name { get; set; }
  public int StreetTypeID { get; set; }
  public virtual StreetType StreetType { get; set; }
}

和街道类型:

public class StreetType
{
  public int ID { get; set; }
  public string Name { get; set; }
  public virtual ICollection

我使用FluenApi来映射这些实体:

public class StreetTypeMap : EntityTypeConfigurationrequired().HasMaxLength(50);
     HasMany(a => a.Streets).Withrequired(p => p.StreetType).HasForeignKey(p => p.StreetTypeID);
     ToTable("StreetType");
   }
 }

和街道实体类似.
现在我得到JSON:

{
  "id":1,"name":"Street1","streettypeid":3
}

我怎样才能获得JSON:

{
  "id":1,"streettypeid":
   {
    "id":3,"name":"Type3"
   }
}

或者一些类似的结构.我怎样才能在.NET中实现这一目标?

我的控制器:

StreetController : BaseApiController

    public class BaseApiController

}

最佳答案
要保留JSON中的对象引用,请将以下代码添加到Global.asax文件中的Application_Start方法

var json = GlobalConfiguration.Configuration.Formatters.JsonFormatter;
json.SerializerSettings.PreserveReferencesHandling = 
    Newtonsoft.Json.PreserveReferencesHandling.All;

欲了解更多数据,请阅读this文章.

另一种方法是尝试在您的webapi中使用OData.
您必须安装OData包:

Install-Package Microsoft.AspNet.Odata

然后你就可以使用$expand来导致相关实体被包含在响应内联中.
您可以按原样保留所有内容,但我认为可以正确添加IgnoreDataMember(不要忘记使用System.Runtime.Serialization添加;)

public class StreetType
{
  public int ID { get; set; }
  public string Name { get; set; }
  [IgnoreDataMember]
  public virtual ICollection

还需要为你添加属性Get方法

[EnableQuery]
public virtual IQueryable

之后,您可以创建http请求,如:

http://blablabla/Street?$expand=StreetType

并使用他们的StreetType获取所有Streets

相关文章

在要实现单例模式的类当中添加如下代码:实例化的时候:frmC...
1、如果制作圆角窗体,窗体先继承DOTNETBAR的:public parti...
根据网上资料,自己很粗略的实现了一个winform搜索提示,但是...
近期在做DSOFramer这个控件,打算自己弄一个自定义控件来封装...
今天玩了一把WMI,查询了一下电脑的硬件信息,感觉很多代码都...
最近在研究WinWordControl这个控件,因为上级要求在系统里,...