您能否从 Web API POST 读取不在数据模型中的其他数据字符串?
Can you read additional data strings from Web API POST which are not in the data model?
在 Entity Framework 我有一个 DBGeography 对象:
using System.Data.Entity.Spatial;
...
public DbGeography Location { get; set; }
由于我还没有发现通过 JSON 发送 POINT
对象的更好方法,我打算从 'lat' 和 'lng' 发送字符串值我的 Javascript 代码并在 POST 方法期间在服务器上使用它们:
public async Task<IHttpActionResult> PostI4Item(myEntity item)
{
var lat = (VALUE TO BE SOURCED);
var lng = (VALUE TO BE SOURCED);
string Point = String.Format("POINT({0} {1})", lat, lng);
item.Location = DbGeography.PointFromText(Point, 4326);
myEntity current = await InsertAsync(item);
return CreatedAtRoute("Tables", new { id = current.Id }, current);
}
问题是我不知道如何检索发送到 POST 的值,这些值在数据模型中不是预期的。 item.Location
是可访问的,因为它已被声明。但是,即使我在 'lat' 和 'lng' 的正文中发送了额外的 key/value 对, 我如何才能在代码 中发现这些值?我不能使用 item.lat
和 item.lng
因为它们没有声明,而且我不希望这些值有额外的数据库列......我只希望它们被接受为输入,但不保存。
数据模型中是否有一种方法,我可以在其中声明一个值(可能是只读的或内部的),该值在请求中是预期的并且可以在 POST 方法中使用,但不是实际上正在保存到我的数据库中?
来自 haim770 的 post from Mohamed Badr & Niels R, and this post 解决了我的问题。
我不知道有一个 [NotMapped]
属性可用于我的数据模型,这意味着我可以期望 lat 和 lng 的值,而无需它们在 Entity Framework.[=14= 中创建数据库列]
所以我的 class 变成:
using System.Data.Entity.Spatial;
using System.ComponentModel.DataAnnotations.Schema;
...
public DbGeography Location { get; set; }
[NotMapped]
public double lng { get; set; }
[NotMapped]
public double lat { get; set; }
我的代码变成:
public async Task<IHttpActionResult> PostI4Item(myEntity item)
{
var Point = DbGeography.FromText($"POINT({item.lng} {item.lat})");
item.Location = Point;
myEntity current = await InsertAsync(item);
return CreatedAtRoute("Tables", new { id = current.Id }, current);
}
在 Entity Framework 我有一个 DBGeography 对象:
using System.Data.Entity.Spatial;
...
public DbGeography Location { get; set; }
由于我还没有发现通过 JSON 发送 POINT
对象的更好方法,我打算从 'lat' 和 'lng' 发送字符串值我的 Javascript 代码并在 POST 方法期间在服务器上使用它们:
public async Task<IHttpActionResult> PostI4Item(myEntity item)
{
var lat = (VALUE TO BE SOURCED);
var lng = (VALUE TO BE SOURCED);
string Point = String.Format("POINT({0} {1})", lat, lng);
item.Location = DbGeography.PointFromText(Point, 4326);
myEntity current = await InsertAsync(item);
return CreatedAtRoute("Tables", new { id = current.Id }, current);
}
问题是我不知道如何检索发送到 POST 的值,这些值在数据模型中不是预期的。 item.Location
是可访问的,因为它已被声明。但是,即使我在 'lat' 和 'lng' 的正文中发送了额外的 key/value 对, 我如何才能在代码 中发现这些值?我不能使用 item.lat
和 item.lng
因为它们没有声明,而且我不希望这些值有额外的数据库列......我只希望它们被接受为输入,但不保存。
数据模型中是否有一种方法,我可以在其中声明一个值(可能是只读的或内部的),该值在请求中是预期的并且可以在 POST 方法中使用,但不是实际上正在保存到我的数据库中?
来自 haim770 的 post from Mohamed Badr & Niels R, and this post 解决了我的问题。
我不知道有一个 [NotMapped]
属性可用于我的数据模型,这意味着我可以期望 lat 和 lng 的值,而无需它们在 Entity Framework.[=14= 中创建数据库列]
所以我的 class 变成:
using System.Data.Entity.Spatial;
using System.ComponentModel.DataAnnotations.Schema;
...
public DbGeography Location { get; set; }
[NotMapped]
public double lng { get; set; }
[NotMapped]
public double lat { get; set; }
我的代码变成:
public async Task<IHttpActionResult> PostI4Item(myEntity item)
{
var Point = DbGeography.FromText($"POINT({item.lng} {item.lat})");
item.Location = Point;
myEntity current = await InsertAsync(item);
return CreatedAtRoute("Tables", new { id = current.Id }, current);
}