【发布时间】:2019-06-11 07:45:17
【问题描述】:
我正在尝试在我的网络服务 (golang) 上使用 google oauth2,但无法获取用户个人资料信息(名字、姓氏)。
我正在尝试各种端点,但每次都得到这样的答案:
{
"id":"*************",
"email":"***@gmail.com",
"verified_email":true,
"picture":"https://***/photo.jpg"
}
同时具有这组范围的谷歌游乐场返回这种答案:
{
"family_name": "***",
"name": "****",
"picture": "https://*******/photo.jpg",
"locale": "ru",
"email": "****@gmail.com",
"given_name": "*****",
"id": "************",
"verified_email": true
}
如何在我的网络应用程序中获得相同的答案? 本网站和互联网上的人们建议添加配置文件范围,但我已经这样做了。
这是我的代码(缩短)
"golang.org/x/oauth2"
"golang.org/x/oauth2/google"
func init() {
googleOauthConfig = &oauth2.Config{
RedirectURL: "*******",
ClientID: "*********",
ClientSecret: "******",
Scopes: []string{
"https://www.googleapis.com/auth/userinfo.email",
"https://www.googleapis.com/auth/userinfo.profile",
"openid"},
Endpoint: google.Endpoint,
}
}
var googleOauthConfig *oauth2.Config
//const oauthGoogleURLAPI = "https://www.googleapis.com/oauth2/v1/userinfo"
const oauthGoogleURLAPI = "https://www.googleapis.com/oauth2/v2/userinfo"
//const oauthGoogleURLAPI = "https://www.googleapis.com/oauth2/v3/userinfo"
const oauthGoogleURLAPI2 = "https://people.googleapis.com/v1/people/me?personFields=names,emailAddresses"
//const oauthGoogleURLAPI = "https://openidconnect.googleapis.com/v1/userinfo"
func HandleGoogleCallback(w http.ResponseWriter, r *http.Request) {
...
oauthState, _ := r.Cookie(oauthstateCookieName)
code := r.FormValue("code")
gtoken, err := googleOauthConfig.Exchange(oauth2.NoContext, code)
bearer := "Bearer " + gtoken.AccessToken
req, err := http.NewRequest("GET", oauthGoogleURLAPI, nil)
req.Header.Add("Authorization", bearer)
gresponse, err := http.DefaultClient.Do(req)
contents, err := ioutil.ReadAll(gresponse.Body)
authContent := &AuthContent{}
err = json.Unmarshal(contents, authContent)
log.Println(authContent)
...
}
我也看过这篇文章Google Oauth2 userinfo API not returning user's name data 但结果是一样的:没有个人资料信息。
谢谢。
更新: 根据评论的建议,我稍微更正了“golang.org/x/oauth2”的代码并获得了 id_token。 当我在 jwt.io 上检查这个 id 令牌时,我看到了我需要的所有数据。 但我认为应该通过这样的 API 请求检索个人资料信息
req, err := http.NewRequest("GET", <endPoint>, nil)
gresponse, err := http.DefaultClient.Do(req)
在这个例子中,只使用了标准的 go 库,并且 gresponse 包含整个 http 响应,不是吗?为什么响应不包含我需要的字段?
【问题讨论】:
-
尝试获取 id 令牌并将其放入 jwt.io。 Gtoken 也应该包含一个 id 令牌。我想知道您的库是否只是没有正确解析响应。
-
看来你是对的。当我从库的深处提取 id_token 并通过 jwt.io 进行检查时,我看到了我需要的所有数据。但我不明白出了什么问题。我认为应该通过像
req, err := http.NewRequest("GET", <endPoint>, nil) gresponse, err := http.DefaultClient.Do(req)这样的API 请求来检索个人资料信息。在这个例子中,只使用了标准的 go 库,gresponse包含整个 http 响应,不是吗?为什么响应不包含我需要的字段?
标签: go oauth-2.0 google-oauth userinfo