.NET Core Web API 路由仅在 Linux 上返回 404?
.NET Core Web API routes returning 404 only on Linux?
如果我从我的 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 机器上从命令行 window 调用了这个:
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
所以这里的问题实际上是两件事。正如@MarkG 所建议的那样,我对如何使用 curl
测试 API 端点的错误假设让我误入歧途。我不应该使用 -I
参数,它发送了错误的请求,因此我收到了 404... 换句话说,我没有发送 GET /api/groups
请求,而是发送了 HEAD /api/groups
...这不是定义的路线,因此 应该 return 404.
第二个问题是我的 nginx 代理配置不正确,所以在外部,我的所有 /api/ 端点也是 returning 404,原因不同。结合我糟糕的 curl 请求,似乎 nginx 被 配置正确,而我的 api 服务只是 returning 404 的一切......当在事实上,这只是我在多个层面上搞砸了。
如果我从我的 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 机器上从命令行 window 调用了这个:
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
所以这里的问题实际上是两件事。正如@MarkG 所建议的那样,我对如何使用 curl
测试 API 端点的错误假设让我误入歧途。我不应该使用 -I
参数,它发送了错误的请求,因此我收到了 404... 换句话说,我没有发送 GET /api/groups
请求,而是发送了 HEAD /api/groups
...这不是定义的路线,因此 应该 return 404.
第二个问题是我的 nginx 代理配置不正确,所以在外部,我的所有 /api/ 端点也是 returning 404,原因不同。结合我糟糕的 curl 请求,似乎 nginx 被 配置正确,而我的 api 服务只是 returning 404 的一切......当在事实上,这只是我在多个层面上搞砸了。