是否可以使用net / http包和/或任何gorilla库在转到处理程序之前在EVERY URL上执行某些代码?例如,要检查连接是否来自黑名单的IP地址?
答案 0 :(得分:7)
创建一个在检查IP地址后调用另一个处理程序的处理程序:
type checker struct {
h http.Handler
}
func (c checker) ServeHTTP(w http.ResponseWriter, r *http.Request) {
if blackListed(r.RemoteAddr) {
http.Error(w, "not authorized", http.StatusForbidden)
return
}
c.h.ServeHTTP(w, r)
}
将此处理程序传递给ListenAndServe而不是原始处理程序。例如,如果你有:
err := http.ListenAndServe(addr, mux)
将代码更改为
err := http.ListenAndServe(addr, checker{mux})
这也适用于ListenAndServe的所有变体。它适用于http.ServeMux,Gorilla mux和其他路由器。
答案 1 :(得分:0)
如果要使用我发现很常见的默认多路复用器,则可以这样创建中间件:
func mustBeLoggedIn(handler func(http.ResponseWriter, *http.Request)) func(http.ResponseWriter, *http.Request) {
return func(w http.ResponseWriter, r *http.Request) {
// Am i logged in?
if ...not logged in... {
http.Error(w, err.Error(), http.StatusUnauthorized)
return
}
// Pass through to the original handler.
handler(w, r)
}
}
像这样使用它:
http.HandleFunc("/some/priveliged/action", mustBeLoggedIn(myVanillaHandler))
http.ListenAndServe(":80", nil)