2016-04-17 17 views
3

golang.org/x/oauth2パッケージを使用して、oauth2をサポートするサイトでの認証方法を理解しようとしています。パッケージ "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 

答えて

1

はフォローアップ:私はそれを使用しましたそれを数回微調整して仕事をしています。

関連する問題