.NET核心Web API路由仅在Linux上返回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机器上的命令行窗口调用了这个:

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。。。这不是一个定义的路由,因此应该返回一个404。

第二个问题是我的nginx代理没有正确配置,所以从外部来看,我的/api/端点也都返回404,原因不同。结合我糟糕的curl请求,nginx似乎被正确配置了,而我的api服务只是为所有内容返回404。。。而事实上,只是我在多个层面上搞砸了。

相关内容

  • 没有找到相关文章

最新更新