在Netlify函数的文档中,它们向Node展示了如何识别请求是否来自登录用户。
https://www.netlify.com/docs/functions/#identity-and-functions
查看Go结构中的上下文,不会发现Go中的用户数据是可用的。我一定是漏掉了什么。如何在Netlify中使用Go Lamda函数验证用户并从JWT获取他们的信息?
发布于 2021-12-14 19:37:57
查看这个线程:https://answers.netlify.com/t/netlify-identity-and-go-functions/17810
type Bearer struct {
Identity *Identity `json:"identity"`
User *User `json:"user"`
SiteUrl string `json:"site_url"`
Alg string `json:"alg"`
}
type Identity struct {
URL string `json:"url"`
Token string `json:"token"`
}
type User struct {
AppMetaData *AppMetaData `json:"app_metadata"`
Email string `json:"email"`
Exp int `json:"exp"`
Sub string `json:"sub"`
UserMetadata *UserMetadata `json:"user_metadata"`
}
type AppMetaData struct {
Provider string `json:"provider"`
}
type UserMetadata struct {
FullName string `json:"full_name"`
}
func AuthMiddleware(h *Handler) http.Handler {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
lc, ok := lambdacontext.FromContext(r.Context())
if !ok {
err := errors.New("server error")
h.logger.Errorf("error retrieving context %+v", r.Context())
http.Error(w, err.Error(), http.StatusInternalServerError)
return
}
bearer := lc.ClientContext.Custom["netlify"]
raw, err := base64.StdEncoding.DecodeString(bearer)
if err != nil {
h.logger.Error(err)
http.Error(w, err.Error(), http.StatusInternalServerError)
return
}
data := Bearer{}
err = json.Unmarshal(raw, &data)
if err != nil {
h.logger.Error(err)
http.Error(w, err.Error(), http.StatusInternalServerError)
return
}
if data.User == nil {
err := errors.New("forbidden")
h.logger.Errorf("Unauthenticated request bearer: %+v", bearer)
http.Error(w, err.Error(), http.StatusForbidden)
return
}
h.ServeHTTP(w, r)
})
}
还有一个博客:https://matthewkrump.com/2020-07-13-netlify-go-functions/以了解更多细节
https://stackoverflow.com/questions/55975679
复制相似问题