作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个部署到 Google Cloud Run 的简单容器化 Web 应用程序(Nginx 提供 HTML 和 Javascript)。
问题是,即使我已经验证并更新了 DNS 记录,我似乎也无法强制使用 HTTPS 连接。如果用户愿意,他们仍然可以访问我的 Cloud Run 应用程序的不安全的 http 端点。
如何设置强制或重定向用户使用 HTTPS 的 Google Cloud Run 服务?
最佳答案
LB 发送一个名为 X-Forwarded-Proto
的 header 包含 http
或 https
所以你可以轻松地使用 301 Moved Permanently
重定向万一你发现了。
使用 Nginx 编辑问题的示例:
http://scottwb.com/blog/2013/10/28/always-on-https-with-nginx-behind-an-elb/
示例代码:
func main() {
http.HandleFunc("/", func(writer http.ResponseWriter, request *http.Request) {
if request.Header["X-Forwarded-Proto"][0] == "http" {
http.Redirect(writer, request, "https://" + request.Host + request.RequestURI, http.StatusMovedPermanently)
return
}
fmt.Printf("Request: %+v, headers: %+v \n", request, request.Header)
writer.Write([]byte("hello world"))
})
http.ListenAndServe(":"+os.Getenv("PORT"), nil)
}
关于google-cloud-platform - 如何在 Google Cloud Run 中将所有 http 流量重定向到 https,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55699148/
我是一名优秀的程序员,十分优秀!