如何通过 .Handle() 定向提供静态文件?

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

编辑:我使用

chi
作为路由器。它的工作原理与标准的不同。请参阅答案了解与我的问题相关的关键区别。

我对应用程序提供的静态站点中的文件如何作为检索目标感到困惑。

我有一个典型的

r.Handle("/", http.FileServer(http.Dir("spa")))

spa
的内容是

│   favicon.ico
│   index.html
│
├───css
│       510.e095f672.css
│       app.f05c50d3.css
│       vendor.9add3052.css
│
├───fonts
│       flUhRq6tzZclQEJ-Vdg-IuiaDsNa.1dd1bb36.woff
│       flUhRq6tzZclQEJ-Vdg-IuiaDsNcIhQ8tQ.f54bbe10.woff2
│       KFOkCnqEu92Fr1MmgVxIIzQ.9391e6e2.woff
│       KFOlCnqEu92Fr1MmEU9fBBc-.ddd11dab.woff
│       KFOlCnqEu92Fr1MmSU5fBBc-.877b9231.woff
│       KFOlCnqEu92Fr1MmWUlfBBc-.0344cc3c.woff
│       KFOlCnqEu92Fr1MmYUtfBBc-.b555d228.woff
│       KFOmCnqEu92Fr1Mu4mxM.9b78ea3b.woff
│
├───icons
│       favicon-128x128.png
│       favicon-16x16.png
│       favicon-32x32.png
│       favicon-96x96.png
│
└───js
        361.136e16c3.js
        510.546967b6.js
        898.3690f332.js
        997.92f440f8.js
        app.42bde279.js
        app.578482b2.js
        vendor.8c20bf3b.js

访问时

http://localhost:15555/
我进入我的日志

2022-03-31T20:20:10+02:00 | INFO  | / → [::1]:23750
2022-03-31T20:20:10+02:00 | INFO  | /js/vendor.8c20bf3b.js → [::1]:23750
2022-03-31T20:20:10+02:00 | INFO  | /js/app.42bde279.js → [::1]:23751
2022-03-31T20:20:10+02:00 | INFO  | /css/vendor.9add3052.css → [::1]:23752
2022-03-31T20:20:10+02:00 | INFO  | /css/app.f05c50d3.css → [::1]:23753

只有第一次调用成功(200),其他都是404

第一个调用最终应该检索

index.html
,而且确实如此。这就是访问链接的
.js
.css
文件的原因。

这就是说,尝试

http://localhost:15555/
我在检索时也得到了404

2022-03-31T20:26:58+02:00 | INFO  | /index.html → [::1]:24233

我的问题:

  • 为什么
    /
    会成功,最终会得到
    /index.html
  • 为什么其他文件都是404?
go httpserver go-chi
1个回答
2
投票

我发现问题了,一定是handler

r.Handle("/*", http.FileServer(http.Dir("spa")))

我认为

/
会匹配所有内容,并且不需要通配符。

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