3

我试图弄清楚如何使用该包golang.org/x/oauth2在支持 oauth2 的站点上进行身份验证。

我在下面编写的代码有效,我只是好奇这是否是正确的方法,使用这个特定的库来获取 *http.Client:

func handleCallback(w http.ResponseWriter, r *http.Request) {
    state := r.FormValue("state")
    if state != oauthStateString {
        fmt.Printf("invalid oauth state, expected '%s', got '%s'\n", oauthStateString, state)
        http.Redirect(w, r, "/", http.StatusTemporaryRedirect)
        return
    }

    code := r.FormValue("code")
    token, err := oauthConf.Exchange(oauth2.NoContext, code)
    if err != nil {
        fmt.Printf("oauthConf.Exchange() failed with '%s'\n", err)
        http.Redirect(w, r, "/", http.StatusTemporaryRedirect)
        return
    }

    ts := oauth2.StaticTokenSource(
        &oauth2.Token{AccessToken: token.AccessToken},
    )

    tc := oauth2.NewClient(oauth2.NoContext, ts) // got *http.Client
4

1 回答 1

0

跟进:我已经使用它并对其进行了多次调整,它完成了这项工作。

于 2016-12-24T20:26:37.320 回答