我正在开发一个网络聊天应用程序,我遇到了一个不应该发生的问题。在 main.go 我有这个功能:
http.Handle("/chat", MustAuth(&templateHandler{filename: "chat.html"}))
我刚刚使用 cookie 构建了一个身份验证文件(auth.go,仍在进行中),它是:
package main
import "net/http"
type authHandler struct {
next http.Handler
}
func (h *authHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
_, err := r.Cookie("auth")
if err == http.ErrNoCookie {
//not authenticated
w.Header().Set("Location", "/login")
w.WriteHeader(http.StatusTemporaryRedirect)
return
}
if err != nil {
//some other error
http.Error(w, err.Error(), http.StatusInternalServerError)
return
}
//success - call the next handler
h.next.ServeHTTP(w, r)
}
func MustAuth(handler http.Handler) http.Handler {
return &authHandler{next: handler}
}
问题是,当我运行它并打开 localhost 页面时,cookie 无法正常工作,也没有按应有的方式将我重定向到登录页面。
肥皂起泡泡
相关分类