如果我从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。我为这将是为什么scratch了。似乎没有任何错误消息或任何东西,就像路由没有注册一样。
有人可以告诉我为什么会这样吗?
这是使用.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所建议的那样,我对如何使用来测试API端点的错误假设误入歧途curl
。我不应该使用该-I
参数,它发送了错误的请求,因此我得到了404 ...换句话说,不是发送GET /api/groups
请求,而是发送了HEAD /api/groups
...,这不是已定义的路由,因此应该返回404。
第二个问题是我的nginx代理配置不正确,因此出于其他原因,我的所有/ api /端点在外部也都返回404。结合我糟糕的curl请求,似乎已经正确配置了nginx ,并且我的api服务只是为所有内容返回404……实际上,这只是我搞砸了多个层次。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句