react 刷新浏览器导致 404 错误
在使用 react 与 envoy 及 go 的环境中,只要浏览器刷新带有路径的页面就会报 404 错误。这个问题是由 react router 引起的,解决方案如下:
由于 envoy 的 prefix 路由已将所有路径请求代理到 go,且 go 的 http.handle 也已处理所有路径的静态文件请求,但仍然出现 404 错误的原因是:
- react router 的哈希路由问题:react 使用哈希路由,将路径信息存储在浏览器的 url 片段中。
- 服务器处理逻辑不当:go 服务器的 http.handle 处理了所有路径,但只返回了静态文件。
解决方案:
修改 go 服务器的路由处理逻辑,使用 http.handlefunc 指定具体路径和处理函数:
func main() { http.HandleFunc( "/", func(w http.ResponseWriter, r *http.Request) { http.ServeFile(w, r, "/path/to/build") }, ) if e := http.ListenAndServe(":80", nil); e != nil { panic(e) } }
这样,所有请求都会被引导到正确的静态文件,从而解决 404 错误。
以上就是React 刷新浏览器页面报 404 错误,如何解决?的详细内容,更多请关注php中文网其它相关文章!
版权声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系 yyfuon@163.com