Avec la popularité de WeChat, la connexion WeChat est devenue une fonctionnalité incontournable pour de nombreuses applications Web. En se connectant avec l'autorisation WeChat, les utilisateurs peuvent facilement se connecter aux applications Web à l'aide de leur compte WeChat et éviter les processus d'enregistrement fastidieux. Cet article explique comment utiliser Golang pour implémenter la connexion autorisée WeChat pour les applications Web.
Tout d'abord, nous devons nous inscrire et créer une application sur la WeChat Open Platform , récupérez l'application AppID et AppSecret. Sur la page de gestion des applications de la plateforme ouverte WeChat, vous pouvez voir les applications que vous avez créées et obtenir l'AppID et l'AppSecret de l'application.
Lors de la construction de l'URL pour la connexion autorisée à WeChat, vous devez suivre les exigences de l'ouverture de WeChat plate-forme et ajoutez l'AppID, l'URL redirigée et certains autres paramètres sont assemblés selon certaines règles. Voici un exemple d'URL dans lequel "APPID" et "REDIRECT_URI" doivent être remplacés par l'AppID et l'URL de redirection de votre propre application :
https://open.weixin.qq.com/connect/oauth2/authorize?appid=APPID &redirect_uri=REDIRECT_URI &response_type=code &scope=snsapi_userinfo &state=STATE#wechat_redirect
La description du paramètre est la suivante : #🎜🎜 #
func buildAuthURL(appID, redirectURI, state string) string { values := make(url.Values) values.Set("appid", appID) values.Set("redirect_uri", redirectURI) values.Set("response_type", "code") values.Set("scope", "snsapi_userinfo") values.Set("state", state) return "https://open.weixin.qq.com/connect/oauth2/authorize?" + values.Encode() + "#wechat_redirect" }
func getAccessToken(appID, appSecret, code string) (string, error) { url := "https://api.weixin.qq.com/sns/oauth2/access_token?appid=" + appID + "&secret=" + appSecret + "&code=" + code + "&grant_type=authorization_code" resp, err := http.Get(url) if err != nil { return "", err } defer resp.Body.Close() body, err := ioutil.ReadAll(resp.Body) if err != nil { return "", err } var data struct { AccessToken string `json:"access_token"` ExpiresIn int `json:"expires_in"` OpenID string `json:"openid"` Scope string `json:"scope"` } if err := json.Unmarshal(body, &data); err != nil { return "", err } return data.AccessToken, nil }
func getUserInfo(accessToken, openID string) (*userInfo, error) { url := "https://api.weixin.qq.com/sns/userinfo?access_token=" + accessToken + "&openid=" + openID resp, err := http.Get(url) if err != nil { return nil, err } defer resp.Body.Close() body, err := ioutil.ReadAll(resp.Body) if err != nil { return nil, err } var user userInfo if err := json.Unmarshal(body, &user); err != nil { return nil, err } return &user, nil }
func wxLoginHandler(w http.ResponseWriter, r *http.Request) { appID := "your app id" appSecret := "your app secret" state := "random string" redirectURI := url.QueryEscape("http://your_server_url/callback") if r.Method == "GET" { // Redirect to Wechat login page http.Redirect(w, r, buildAuthURL(appID, redirectURI, state), 302) } else if r.Method == "POST" { // Get user info after login succeeds code := r.FormValue("code") if code == "" { http.Error(w, "Missing code parameter", http.StatusBadRequest) return } accessToken, err := getAccessToken(appID, appSecret, code) if err != nil { http.Error(w, "Failed to get access token", http.StatusInternalServerError) return } user, err := getUserInfo(accessToken, openID) if err != nil { http.Error(w, "Failed to get user info", http.StatusInternalServerError) return } // Do something with user info fmt.Fprintf(w, "Hello, %s!", user.Nickname) } else { http.Error(w, "Invalid request method", http.StatusMethodNotAllowed) return } }
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!