recherche
Maisondéveloppement back-endGolangComment utiliser Golang pour implémenter la connexion autorisée WeChat pour les applications Web

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.

  1. Obtenez l'AppID et l'AppSecret de l'application WeChat Open Platform

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.

  1. Construisez l'URL pour la connexion autorisée à WeChat

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 : #🎜🎜 #

    appid : AppID de l'application.
  • redirect_uri : L'adresse du lien de rappel redirigée après autorisation. Veuillez utiliser le code urlen pour traiter le lien.
  • response_type : type de retour, fixé au code.
  • scope : portée de l'autorisation de l'application, snsapi_base signifie obtenir uniquement l'openid de l'utilisateur, snsapi_userinfo signifie obtenir les détails de l'utilisateur.
  • state : Utilisé pour maintenir le statut des demandes et des rappels, et les ramener au tiers tels quels après avoir autorisé la demande.
Dans Golang, vous pouvez utiliser url.Values ​​​​pour créer des paramètres d'URL. Voici un exemple de code :

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"
}

Cette fonction accepte trois paramètres : l'AppID de l'application, l'URL du rappel après autorisation et un état de chaîne aléatoire. La fonction renvoie une URL de connexion autorisée WeChat construite.

    Obtenir le jeton d'accès de l'utilisateur WeChat
Une fois que l'utilisateur a vérifié son identité dans le client WeChat, WeChat renvoie le code d'autorisation et redirige Go à l’URL de rappel prédéfinie. Dans l'URL de rappel, nous devons analyser les paramètres de l'URL, obtenir le code d'autorisation et utiliser le code pour échanger contre access_token. Voici un exemple de code :

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
}

Cette fonction accepte trois paramètres : l'AppID de l'application, l'AppSecret de l'application et le code d'autorisation. La fonction utilise la méthode http.Get() pour envoyer une requête GET au serveur WeChat afin d'obtenir le access_token. Cette fonction renvoie une valeur access_token de type chaîne, ou une erreur si une erreur se produit.

    Obtenir des informations de base sur les utilisateurs de WeChat
Après avoir obtenu access_token, nous pouvons envoyer une demande pour obtenir des informations utilisateur au serveur WeChat et analyser et renvoie les données au format JSON pour obtenir des informations de base sur les utilisateurs de WeChat. Voici un exemple de code :

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
}

Cette fonction accepte deux paramètres : access_token et user openid. La fonction utilise la méthode http.Get() pour envoyer une requête GET au serveur WeChat afin d'obtenir les informations de base de l'utilisateur WeChat. Cette fonction renvoie une variable de type pointeur pointant vers la structure userInfo, ou une erreur si une erreur survient.

    Écrire un gestionnaire pour la connexion autorisée à WeChat
Enfin, nous devons écrire un gestionnaire pour intégrer les fonctions ci-dessus pour obtenir une connexion autorisée à WeChat . Voici un exemple de code :

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
    }
}

Cette fonction implémente l'ensemble du processus de connexion autorisée à WeChat. Lorsque l'utilisateur accède à "/wx_login", la fonction sera redirigée vers la page de connexion d'autorisation WeChat. Une fois que l'utilisateur s'est connecté sur cette page, la fonction sera redirigée vers l'URL de rappel avec le paramètre de code d'autorisation. Dans la fonction de rappel, nous utiliserons le code d'autorisation pour obtenir le access_token et les informations utilisateur de base, et pourrons enregistrer les informations utilisateur sur le serveur ou effectuer un autre traitement.

Résumé

Cet article explique comment utiliser Golang pour implémenter la connexion autorisée WeChat pour les applications Web. Grâce à l'introduction de cet article, nous pouvons comprendre le principe de mise en œuvre de la connexion autorisée WeChat et écrire un simple programme de traitement des connexions autorisées WeChat. Dans les applications pratiques, nous devons également prendre en compte des problèmes tels que la sécurité et les performances, et procéder aux optimisations et améliorations correspondantes en fonction des besoins réels.

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!

Déclaration
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
go语言有没有缩进go语言有没有缩进Dec 01, 2022 pm 06:54 PM

go语言有缩进。在go语言中,缩进直接使用gofmt工具格式化即可(gofmt使用tab进行缩进);gofmt工具会以标准样式的缩进和垂直对齐方式对源代码进行格式化,甚至必要情况下注释也会重新格式化。

go语言为什么叫gogo语言为什么叫goNov 28, 2022 pm 06:19 PM

go语言叫go的原因:想表达这门语言的运行速度、开发速度、学习速度(develop)都像gopher一样快。gopher是一种生活在加拿大的小动物,go的吉祥物就是这个小动物,它的中文名叫做囊地鼠,它们最大的特点就是挖洞速度特别快,当然可能不止是挖洞啦。

聊聊Golang中的几种常用基本数据类型聊聊Golang中的几种常用基本数据类型Jun 30, 2022 am 11:34 AM

本篇文章带大家了解一下golang 的几种常用的基本数据类型,如整型,浮点型,字符,字符串,布尔型等,并介绍了一些常用的类型转换操作。

一文详解Go中的并发【20 张动图演示】一文详解Go中的并发【20 张动图演示】Sep 08, 2022 am 10:48 AM

Go语言中各种并发模式看起来是怎样的?下面本篇文章就通过20 张动图为你演示 Go 并发,希望对大家有所帮助!

tidb是go语言么tidb是go语言么Dec 02, 2022 pm 06:24 PM

是,TiDB采用go语言编写。TiDB是一个分布式NewSQL数据库;它支持水平弹性扩展、ACID事务、标准SQL、MySQL语法和MySQL协议,具有数据强一致的高可用特性。TiDB架构中的PD储存了集群的元信息,如key在哪个TiKV节点;PD还负责集群的负载均衡以及数据分片等。PD通过内嵌etcd来支持数据分布和容错;PD采用go语言编写。

go语言是否需要编译go语言是否需要编译Dec 01, 2022 pm 07:06 PM

go语言需要编译。Go语言是编译型的静态语言,是一门需要编译才能运行的编程语言,也就说Go语言程序在运行之前需要通过编译器生成二进制机器码(二进制的可执行文件),随后二进制文件才能在目标机器上运行。

聊聊Golang自带的HttpClient超时机制聊聊Golang自带的HttpClient超时机制Nov 18, 2022 pm 08:25 PM

​在写 Go 的过程中经常对比这两种语言的特性,踩了不少坑,也发现了不少有意思的地方,下面本篇就来聊聊 Go 自带的 HttpClient 的超时机制,希望对大家有所帮助。

golang map怎么删除元素golang map怎么删除元素Dec 08, 2022 pm 06:26 PM

删除map元素的两种方法:1、使用delete()函数从map中删除指定键值对,语法“delete(map, 键名)”;2、重新创建一个新的map对象,可以清空map中的所有元素,语法“var mapname map[keytype]valuetype”。

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
2 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

DVWA

DVWA

Damn Vulnerable Web App (DVWA) est une application Web PHP/MySQL très vulnérable. Ses principaux objectifs sont d'aider les professionnels de la sécurité à tester leurs compétences et leurs outils dans un environnement juridique, d'aider les développeurs Web à mieux comprendre le processus de sécurisation des applications Web et d'aider les enseignants/étudiants à enseigner/apprendre dans un environnement de classe. Application Web sécurité. L'objectif de DVWA est de mettre en pratique certaines des vulnérabilités Web les plus courantes via une interface simple et directe, avec différents degrés de difficulté. Veuillez noter que ce logiciel

Télécharger la version Mac de l'éditeur Atom

Télécharger la version Mac de l'éditeur Atom

L'éditeur open source le plus populaire

Listes Sec

Listes Sec

SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.

Dreamweaver Mac

Dreamweaver Mac

Outils de développement Web visuel

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP