代码之家  ›  专栏  ›  技术社区  ›  Jeremy Holovacs

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

  •  2
  • Jeremy Holovacs  · 技术社区  · 6 年前

    如果我从windows开发人员计算机上的解决方案目录生成.NET Core应用程序,如下所示:

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

    我可以运行这个并命中我的端点 http://localhost:5000/api/auth/login ,不用担心。

    我对Ubuntu18.04LTS的机器做了一个几乎相同的发布:

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

    …将文件复制到文件夹中,将适当的项目文件设置为可执行文件并运行它,它将在localhost:5000上开始侦听,与此相同。静态页面(比如我的basic index.html)提供。。。但是我所有的api端点都返回404,我不知道这是为什么。似乎没有任何错误消息或其他东西,就像路由没有注册一样。

    有人能告诉我为什么会这样吗?

    这是用.NET Core SDK2.1.302构建的。

    更新

    我将日志记录设置为debug,并使用了一个已知在除此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
    
    1 回复  |  直到 6 年前
        1
  •  1
  •   Jeremy Holovacs    6 年前

    所以这里的问题其实有两点。正如@MarkG所建议的那样,我被自己关于如何使用 curl . 我不应该用 -I 参数,它发送了错误的请求,因此我得到了404。。。换句话说,不是发送 GET /api/groups 请求,我正在发送 HEAD /api/groups ... 这不是一条明确的路线,因此 应该 返回404。

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