gpt4 book ai didi

c# - 为什么 ASP.NET Core 在中间件管道的末尾返回 404?

转载 作者:行者123 更新时间:2023-12-04 01:35:40 26 4
gpt4 key购买 nike

我想了解 ASP.NET Core 如何确定我们已到达中间件管道的末端并开始发回响应。这是处理它的代码(来自 GitHub repository ):

public RequestDelegate Build()
{
RequestDelegate app = context =>
{
/*
Some code omitted for clarity
*/
context.Response.StatusCode = 404;
return Task.CompletedTask;
};

foreach (var component in _components.Reverse())
{
app = component(app);
}

return app;
}

我的问题是:context.Response.StatusCode = 404; 这行是做什么的?为什么它甚至在那里?不应该是 200(“OK”)吗?更改此默认值的代码在哪里,这样我们就不会在每次请求时都收到“404 Not Found”错误?

最佳答案

What does the line context.Response.StatusCode = 404; do? Why is it even there?

此调用最终作为中间件管道中的最后一个组件运行。如果传入请求一直到达您配置的管道的末端,则此代码将运行。它用于确保在您的应用程序未处理请求时返回 404。

Shouldn't it be a 200 ("OK")?

不,HTTP 200 OK 响应不适用于此。这表示请求已成功处理,但实际上根本没有处理,因为未找到处理此特定请求的逻辑 (HTTP 404 NotFound)。

Where is the code that changes this default value so that we don't get a "404 Not Found" error on every request?

中间件管道支持短路的概念(参见 docs)。简而言之,这意味着中间件组件决定是否执行管道中的下一个中间件组件。想象一下以下简化的管道设置:

app.UseStaticFiles();

app.UseRouting();
app.UseEndpoints(endpoints =>
{
endpoints.MapControllers();
});

在此管道中,静态文件和端点中间件都可能使管道短路。如果静态文件中间件能够处理请求,它通常会将状态代码设置为 HTTP 200 并返回文件。如果端点中间件找到匹配的 Controller /操作,它可以做很多事情之一,但通常它会设置一个成功状态代码,例如 HTTP 200。

只有当静态文件中间件和端点中间件都无法处理请求时,调用的行 (context.Response.StatusCode = 404;) 才会作为一种后备运行。

关于c# - 为什么 ASP.NET Core 在中间件管道的末尾返回 404?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59694729/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com