Jquery web api-发布对象返回内部服务器错误500

Jquery web api-发布对象返回内部服务器错误500,jquery,ajax,asp.net-web-api,asp.net-web-api2,Jquery,Ajax,Asp.net Web Api,Asp.net Web Api2,我有一个简单的web api,它使用一个数据库优先ADO SQL server实体,其中一个表具有一个自动递增的标识列和一个nvarchar列。我的GET函数工作正常,但我的POST有问题 这是我的控制器,主要是自动生成的: public class CustomersController : ApiController { private MyEntities db = new MyEntities(); // GET: api/Customers public IQ

我有一个简单的web api,它使用一个数据库优先ADO SQL server实体,其中一个表具有一个自动递增的标识列和一个nvarchar列。我的GET函数工作正常,但我的POST有问题

这是我的控制器,主要是自动生成的:

public class CustomersController : ApiController
{
    private MyEntities db = new MyEntities();

    // GET: api/Customers
    public IQueryable<Customer> GetCustomers()
    {
        return db.Customers;
    }

    // GET: api/Customers/5
    [ResponseType(typeof(Customer))]
    public IHttpActionResult GetCustomer(int id)
    {
        Customer customer = db.Customers.FirstOrDefault(x => x.CustomerPk == id);
        if (customer == null)
        {
            return NotFound();
        }

        return Ok(customer);
    }

    // PUT: api/Customers/5
    [ResponseType(typeof(void))]
    public IHttpActionResult PutCustomer(int id, Customer customer)
    {
        if (!ModelState.IsValid)
        {
            return BadRequest(ModelState);
        }

        if (id != customer.CustomerPk)
        {
            return BadRequest();
        }

        db.Entry(customer).State = EntityState.Modified;

        try
        {
            db.SaveChanges();
        }
        catch (DbUpdateConcurrencyException)
        {
            if (!CustomerExists(id))
            {
                return NotFound();
            }
            else
            {
                throw;
            }
        }

        return StatusCode(HttpStatusCode.NoContent);
    }

    // POST: api/Customers
    [ResponseType(typeof(Customer))]
    public IHttpActionResult PostCustomer(Customer customer)
    {
        if (!ModelState.IsValid)
        {
            return BadRequest(ModelState);
        }

        db.Customers.Add(customer);
        db.SaveChanges();

        return CreatedAtRoute("DefaultApi", new { id = customer.CustomerPk }, customer);
    }

    // DELETE: api/Customers/5
    [ResponseType(typeof(Customer))]
    public IHttpActionResult DeleteCustomer(int id)
    {
        Customer customer = db.Customers.FirstOrDefault(x => x.CustomerPk == id);
        if (customer == null)
        {
            return NotFound();
        }

        db.Customers.Remove(customer);
        db.SaveChanges();

        return Ok(customer);
    }

    protected override void Dispose(bool disposing)
    {
        if (disposing)
        {
            db.Dispose();
        }
        base.Dispose(disposing);
    }

    private bool CustomerExists(int id)
    {
        return db.Customers.Count(e => e.CustomerPk == id) > 0;
    }
}
正如我提到的,当我从这个页面调用GET方法时,一切都正常。我尝试过ajax方法的不同变体,基于无数将对象发布到web api在线的示例,主要是更改我发布的对象,忽略标识列,只发送CustomerName列,或者将Pk设置为null,但这些都不起作用。我总是收到500个内部服务器错误

它不适用于自动递增的标识列吗?我看到的示例似乎没有将这些作为模型的一部分,所以我想知道这是否是我的问题


非常感谢您提供的任何帮助或建议。

您是否可以访问服务器端错误日志,因为500内部错误可能有多种原因

日志文件中没有关于它的任何内容。但是,如果我将ajax切换为type:GET并注释掉数据行,我会获得成功,并看到日志文件中反映了这一点不知道为什么在多次打开日志文件后没有看到500个错误,但它们最终显示为500 0 31如果我将CustomerPk更改为null,我会得到400个错误,这让我觉得ModelState是无效的,它是ModelState。将CustomerPk更改为CustomerId,以便模型绑定器将其识别为主键,而不需要值。然后它成功了。谢谢你帮我到达那里。
    var customer = { "CustomerPk": 0, "CustomerName": "TEST2" };

        $.ajax(
        {
            url: "http://serverurl/site/api/customers",
            type: "POST",
            contentType: "application/json; charset=UTF-8",
            data: JSON.stringify(customer),
            dataType: "json",
            success: function (data, textStatus, xhr) { alert("Success"); },
            error: function (xhr, textStatus, errorThrown)
            {
                var msg = "Code: " + xhr.status + "\n";
                msg += "Text: " + xhr.statusText + "\n";
                if (xhr.responseJSON != null)
                {
                    msg += "JSON Message: " + xhr.responseJSON.Message + "\n";
                }

                alert(msg);
            }
        });