.NET Core Web API 路由仅在 Linux 上返回 404?

问题描述 投票:0回答:2

如果我从 Windows 开发计算机上的解决方案目录构建我的 .NET Core 应用程序,如下所示:

dotnet publish --configuration Release --output \myproject --self-contained --runtime win7-x64

我可以运行它并达到我的终点

http://localhost:5000/api/auth/login
,不用担心。

我对 ubuntu 18.04 LTS 机器进行了几乎相同的发布:

dotnet publish --configuration Release --output /ubuntu-myproject --self-contained --runtime ubuntu-x64

...将文件复制到该文件夹,将正确的项目文件设置为可执行文件并运行它,它开始在 localhost:5000 上监听。静态页面(如我的基本index.html)服务...但我所有的api端点都返回404。我摸不着头脑不知道为什么会这样。似乎没有任何错误消息或任何东西,就像路由没有注册或其他东西一样。

有人可以告诉我为什么会出现这种情况吗?

这是使用 .NET Core SDK 2.1.302 构建的。

更新

我将日志记录设置为调试,并使用了一条已知在除此 Linux 机器之外的任何地方都有效的路由:

GET /api/groups
。我从 Linux 机器上的命令行窗口调用了它:

curl -I  http://localhost:5000/api/groups

我的回答是这样的:

HTTP/1.1 404 Not Found 
Date: Wed, 01 Aug 2018 02:15:48 GMT 
Server: Kestrel

我的日志文件包含以下事件信息:

2018/08/01 02:15:49.241|INFO|Request starting HTTP/1.1 HEAD http://localhost:5000/api/groups   |Microsoft.AspNetCore.Hosting.Internal.WebHost|Protocol=HTTP/1.1, Method=HEAD, ContentType=, ContentLength=, Scheme=http, Host=localhost:5000, PathBase=, Path=/api/groups, QueryString=, EventId_Id=1, EventId_Name=, EventId=1
2018/08/01 02:15:49.535|INFO|Request finished in 292.2005ms 404  |Microsoft.AspNetCore.Hosting.Internal.WebHost|ElapsedMilliseconds=292.2005, StatusCode=404, ContentType=, EventId_Id=2, EventId_Name=, EventId=2
ubuntu asp.net-core asp.net-core-webapi self-contained
2个回答
1
投票

所以这里的问题实际上是两件事。正如 @MarkG 所建议的,我因对如何使用

curl
测试 API 端点的错误假设而误入歧途。我不应该使用
-I
参数,它发送了错误的请求,因此我得到了 404...换句话说,我不是发送
GET /api/groups
请求,而是发送了
HEAD /api/groups
...不是定义的路线,因此应该返回 404。

第二个问题是我的 nginx 代理没有正确配置,因此在外部我的所有 /api/ 端点也返回 404,原因不同。结合我糟糕的卷曲请求,似乎 nginx 已正确配置,而我的 api 服务只是返回 404 的所有内容......而事实上,这只是我在多个级别上搞砸了。


0
投票

我想在这里发帖,因为当我将 .Net Core 8 应用程序发布到 Ubuntu 实例时,我遇到了同样的问题。我在日志中收到以下错误:“请求到达中间件管道的末尾,而没有由应用程序代码处理”。

事实证明,当我发布应用程序时,我启用了“修剪未使用的代码”选项。一旦我禁用它并重新发布它就可以正常工作。

© www.soinside.com 2019 - 2024. All rights reserved.