小编And*_*icz的帖子

HttpPost操作中的ASP.Net Core CreatedAtAction返回201,但整个请求以500结尾

我正在关注[1],用于设置我的第一个.NET Core WebAPI(从“旧的” WebAPI移出)。当我执行HttpPost操作时,如教程中所示:

[HttpPost]
public IActionResult Create([FromBody] TodoItem item)
{
    if (item == null)
    {
        return BadRequest();
    }
    TodoItems.Add(item);
    return CreatedAtAction("GetTodo", new { id = item.Key }, item);
}
Run Code Online (Sandbox Code Playgroud)

退出控制器后,我收到HttpError 500。CreatedAtAction如我期望的那样,返回状态代码为201的正确对象,并且在我的方法退出服务器后以某种方式将其变为500。我似乎无法进入其余的管道。跟踪给我以下错误:

81.  -GENERAL_REQUEST_ENTITY 
82.  -NOTIFY_MODULE_COMPLETION 
83.  -MODULE_SET_RESPONSE_ERROR_STATUS [Warning] 171ms

      ModuleName          AspNetCoreModule 
      Notification        EXECUTE_REQUEST_HANDLER 
      HttpStatus          500 
      HttpReason          Internal Server Error 
      HttpSubStatus       0 
      ErrorCode           The operation completed successfully. (0x0) 
      ConfigExceptionInfo
Run Code Online (Sandbox Code Playgroud)

一切(Program.cs,Startup.cs)的设置均与[1]中的设置完全相同。在IISExpress(VS2015 Update 3)和IIS7.5(Windows 7)中的行为完全相同。其他返回类型,200(new ObjectResult(item)用于GET,404用于PUT NotFound()或204 NoContentResult()用于PUT都可以)。所以似乎以某种方式遇到了201的问题。有什么想法吗?

[1] https://docs.asp.net/zh/latest/tutorials/first-web-api.html

更新 每个请求发布其他详细信息:

Startup.cs:

using System;
using …
Run Code Online (Sandbox Code Playgroud)

asp.net iis iis-7.5 iis-express asp.net-core

5
推荐指数
1
解决办法
3691
查看次数

标签 统计

asp.net ×1

asp.net-core ×1

iis ×1

iis-7.5 ×1

iis-express ×1