在MVC中序列化DbGeography类型

时间:2014-08-08 05:08:56

标签: c# asp.net-mvc json.net

我在序列化DbGeography类型时遇到了问题。我的控制器操作总是给出错误而不是对象。

出于举例的目的,这是我的班级:

public class Centre
{
  public int CentreId { get; set; }

  [Required]
  public string Name { get; set; }

  [Required]
  [JsonConverter(typeof(DbGeographyConverter))]
  public DbGeography Location { get; set; }
}

我的DbGeographyConverter类是根据许多示例定义的:

public class DbGeographyConverter : JsonConverter
{
  private const string LATITUDE_KEY = "latitude";
  private const string LONGITUDE_KEY = "longitude";

  public override bool CanConvert(Type objectType)
  {
    return objectType.Equals(typeof(DbGeography));
  }

  public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)
  {
    if (reader.TokenType == JsonToken.Null)
      return default(DbGeography);

    var jObject = JObject.Load(reader);

    if (!jObject.HasValues || (jObject.Property(LATITUDE_KEY) == null || jObject.Property(LONGITUDE_KEY) == null))
      return default(DbGeography);

    string wkt = string.Format(CultureInfo.InvariantCulture, "POINT({1} {0})", jObject[LATITUDE_KEY], jObject[LONGITUDE_KEY]);
    return DbGeography.FromText(wkt, DbGeography.DefaultCoordinateSystemId);
  }

  public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer)
  {
    var dbGeography = value as DbGeography;

    serializer.Serialize(writer, dbGeography == null || dbGeography.IsEmpty ? null : new { latitude = dbGeography.Latitude.Value, longitude = dbGeography.Longitude.Value });
  }
}

然后,在我的控制器类(CentreController)中,我有以下几行:

public async Task<JsonResult> Get(int Id)
{
  var centre = new Centre {CentreId = Id};
  // This is a call to our data service, which basically loads the centre object
  // from the database via Entity Framework.
  centre = (await CentreService.Get(centre)).Data;

  //centre.Location = null;
  //var jc = JsonConvert.SerializeObject(centre);

  return Json(centre,JsonRequestBehavior.AllowGet);
}

这给了我500错误和Null值的异常。

如果我取消注释该行

//centre.Location = null;

然后代码运行正常,但没有位置转移回调用者。

如果我取消注释该行

//var jc = JsonConvert.SerializeObject(centre);

然后调用我的DbGeographyConverter,并且jc对象包含我想要返回的正确数据,但是在字符串而不是JsonResult中。对Json的调用不会调用DbGeographyConverter,我无法解决原因。

如何让Json调用运行我的自定义转换器?或者,如何让我的控制器方法将JsonConvert的输出转换为JsonResult?

2 个答案:

答案 0 :(得分:1)

您可以使用Json.NET转换为json,然后使用Content方法返回转换后的字符串。记得添加适当的内容类型。

public async Task<ActionResult> Get(int Id)
{
    var centre = new Centre {CentreId = Id};
    centre = (await CentreService.Get(centre)).Data;

    var jc = JsonConvert.SerializeObject(centre);

    Response.ContentType = "application/json";
    return Content(jc)
}

对你有用吗?

答案 1 :(得分:0)

使用Json.NET nuget包,默认的System.Web.Mvc.Json方法无法处理DbGeography中的nullval。