如何将DbGeography param发布到MVC?

时间:2014-12-15 01:04:47

标签: javascript ajax asp.net-mvc entity-framework geospatial

我正在尝试公开一个API,允许用户发布多边形以在服务器上保留。我正在使用ASP.NET MVC 5.如何正确格式化AJAX参数以发布DbGeography的请求?这就是我想要的:

$.ajax({
    url: '/api/map',
    type: 'POST',
    data: {
        Title: 'My Title',
        MyGEOG: {
            WellKnownText: 'POLYGON ((30 10, 10 20, 20 40, 40 40, 30 10))'
        }
    }
});

这就是我的MVC动作签名的样子:

    [HttpPost]
    [Route("map")]
    public JsonResult Post(MyShape newShape) {...}

我的MyShape课程:

public class MapShape
{
    public string Title { get; set; }
    public System.Data.Entity.Spatial.DbGeography MyGEOG { get; set; }
}

在操作中放置断点时,newShape.Title确实显示为My Title,但当AJAX帖子发生时,MyGEOG为空。正确发布为DbGeography类型的参数的正确格式是什么?

1 个答案:

答案 0 :(得分:3)

DBGeography对象不可变的原因,这意味着一旦创建它就无法写入它。在模型绑定器中实例化MapShape类时,MyGEO属性为null。换句话说,您正在尝试在null对象上设置属性。

“创建”DBGeography对象的唯一方法是使用以下工厂方法之一:

FromText - 根据指定的已知文本值创建新的DbGeometry值。 http://msdn.microsoft.com/en-us/library/hh673669(v=vs.110).aspx

因此,要将标题 WellKnownText 值传递给您的控制器,我建议您创建一个数据传输对象( DTO )来执行操作作为信息的代理。

public class MapShapeDTO
{
    public string Title { get; set; } 
    public string WellKnownText { get; set; }
}

你的Ajax像这样简化了

$.ajax({
url: '/api/map',
type: 'POST',
data: {
    Title: 'My Title',
    WellKnownText: 'POLYGON ((30 10, 10 20, 20 40, 40 40, 30 10))'
    }
});

您的控制器,您可以使用DTO创建MapShape对象。

[HttpPost]
[Route("map")]
public JsonResult Post(MapShapeDTO dto)
    {
        MapShape m = new MapShape()
            {
                Title = dto.Title,
                MyGEOG = System.Data.Entity.Spatial.DbGeography.FromText(dto.WellKnownText)
            };
      ...
    }