我正在尝试公开一个API,该API将允许用户发布多边形以将其保留在服务器上。我正在使用ASP.NET MVC5。如何正确设置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为null。要正确发布为DbGeography类型的参数的正确格式是什么?

最佳答案

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

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

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

因此,为了将Title和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)
            };
      ...
    }

09-25 10:35