Maison développement back-end Golang Utilisez le framework Gin pour implémenter des fonctions de génération de code de vérification et de vérification

Utilisez le framework Gin pour implémenter des fonctions de génération de code de vérification et de vérification

Jun 22, 2023 pm 12:01 PM
gin框架 验证码生成 验证功能

Avec le développement d'Internet, les codes de vérification sont de plus en plus devenus une mesure de vérification de sécurité courante pour les sites Web et les applications. Le code de vérification est une technologie d’interaction homme-machine basée sur des images, des sons, du texte, etc., dans le but de prévenir les attaques malveillantes et les abus des robots.

Dans cet article, nous présenterons comment utiliser le framework Gin du langage Go pour implémenter des fonctions de génération de code de vérification et de vérification. Gin est un framework Web léger qui peut créer rapidement des API RESTful et des applications WEB.

  1. Installer le framework Gin

Avant de commencer, nous devons d'abord installer le framework Gin. Vous pouvez utiliser l'outil de ligne de commande Go pour installer :

go get -u github.com/gin-gonic/gin
Copier après la connexion
  1. Implémentez la fonction de génération de code de vérification

Afin de générer l'image du code de vérification, nous devons utiliser la bibliothèque tierce github.com/mojocn/base64Captcha. La bibliothèque fournit plusieurs types de codes de vérification et prend en charge les paramètres personnalisés. Voici un exemple de code pour générer un code de vérification d'image :

package main

import (
    "fmt"
    "time"

    "github.com/gin-gonic/gin"
    "github.com/mojocn/base64Captcha"
)

func main() {
    r := gin.Default()

    // 生成验证码图片
    r.GET("/captcha", func(c *gin.Context) {
        // 配置
        driver := base64Captcha.NewDriverDigit(80, 240, 4, 0.5, 80)
        store := base64Captcha.DefaultMemStore
        captcha := base64Captcha.NewCaptcha(driver, store)

        // 生成验证码
        id, b64s, err := captcha.Generate()
        if err != nil {
            c.JSON(500, gin.H{"error": err.Error()})
            return
        }

        // 返回验证码图片
        c.JSON(200, gin.H{
            "id":      id,
            "image":   b64s,
            "expires": time.Now().Add(time.Minute * 5).Unix(),
        })
    })

    r.Run(":8080")
}
Copier après la connexion

Dans cet exemple, nous utilisons le stockage Memeory par défaut pour stocker les informations du code de vérification (un autre stockage tel que Redis peut également être utilisé). Le pilote CAPTCHA basé sur des nombres crée des CAPTCHA en utilisant une largeur de 80 pixels, une hauteur de 240 pixels, une longueur de quatre caractères et une intensité de bruit de 0,5. La méthode Generate renverra l’ID du code de vérification généré, l’image du code de vérification et les informations d’erreur. Ici, nous renvoyons l'image du code de vérification au client sous forme codée en base64 et spécifions le délai d'expiration dans la réponse.

  1. Implémentez la fonction de vérification du code de vérification

Lorsque le client soumet le code de vérification, il doit être vérifié si l'entrée de l'utilisateur correspond au code de vérification généré. Utilisez toujours la fonction Verify fournie par la bibliothèque github.com/mojocn/base64Captcha pour vérifier le code de vérification. Voici un exemple de code pour vérifier un captcha d'image :

package main

import (
    "fmt"

    "github.com/gin-gonic/gin"
    "github.com/mojocn/base64Captcha"
)

func main() {
    r := gin.Default()

    // 验证验证码
    r.POST("/verify", func(c *gin.Context) {
        var form struct {
            ID   string `form:"id" binding:"required"`
            Code string `form:"code" binding:"required"`
        }
        if err := c.ShouldBind(&form); err != nil {
            c.JSON(400, gin.H{"error": err.Error()})
            return
        }

        // 验证验证码
        if base64Captcha.VerifyCaptcha(form.ID, form.Code) {
            c.JSON(200, gin.H{"success": true})
        } else {
            c.JSON(401, gin.H{"error": "验证码错误"})
        }
    })

    r.Run(":8080")
}
Copier après la connexion

Dans cet exemple, nous définissons une structure pour stocker l'ID du captcha et la valeur du captcha soumis par le client. Utilisez la fonction ShouldBind pour lier le corps de la requête à la structure. Si la liaison échoue, une erreur 400 est renvoyée. Lors de la vérification du code de vérification, vous pouvez utiliser la fonction VerifyCaptcha pour vérifier si la valeur du code de vérification soumise par le client est correcte. Si la vérification réussit, une réponse 200 est renvoyée ; sinon, une erreur 401 est renvoyée et la raison de l'erreur du code de vérification est demandée.

  1. Code complet

En combinant l'exemple de code ci-dessus pour générer le code de vérification et vérifier le code de vérification, nous pouvons obtenir un code complet comme suit :

package main

import (
    "fmt"
    "time"

    "github.com/gin-gonic/gin"
    "github.com/mojocn/base64Captcha"
)

func main() {
    r := gin.Default()

    // 生成验证码图片
    r.GET("/captcha", func(c *gin.Context) {
        // 配置
        driver := base64Captcha.NewDriverDigit(80, 240, 4, 0.5, 80)
        store := base64Captcha.DefaultMemStore
        captcha := base64Captcha.NewCaptcha(driver, store)

        // 生成验证码
        id, b64s, err := captcha.Generate()
        if err != nil {
            c.JSON(500, gin.H{"error": err.Error()})
            return
        }

        // 返回验证码图片
        c.JSON(200, gin.H{
            "id":      id,
            "image":   b64s,
            "expires": time.Now().Add(time.Minute * 5).Unix(),
        })
    })

    // 验证验证码
    r.POST("/verify", func(c *gin.Context) {
        var form struct {
            ID   string `form:"id" binding:"required"`
            Code string `form:"code" binding:"required"`
        }
        if err := c.ShouldBind(&form); err != nil {
            c.JSON(400, gin.H{"error": err.Error()})
            return
        }

        // 验证验证码
        if base64Captcha.VerifyCaptcha(form.ID, form.Code) {
            c.JSON(200, gin.H{"success": true})
        } else {
            c.JSON(401, gin.H{"error": "验证码错误"})
        }
    })

    r.Run(":8080")
}
Copier après la connexion
  1. Résumé

Cet article présente comment utiliser le framework Gin et github La bibliothèque .com/mojocn/base64Captcha implémente des fonctions de génération et de vérification de code de vérification. La technologie des codes de vérification est une méthode de vérification de sécurité largement utilisée, qui peut prévenir efficacement les attaques de robots et les abus malveillants. En pratique, d'autres types de codes de vérification et méthodes de stockage peuvent être sélectionnés en fonction des besoins réels et combinés avec d'autres mesures de sécurité pour améliorer la sécurité et la fiabilité de l'application.

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 de ce site Web
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

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)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Utilisez le framework Gin pour implémenter les fonctions d'analyse de données XML et JSON Utilisez le framework Gin pour implémenter les fonctions d'analyse de données XML et JSON Jun 22, 2023 pm 03:14 PM

Dans le domaine du développement Web, XML et JSON, l'un des formats de données, sont largement utilisés, et le framework Gin est un framework Web léger en langage Go, simple, facile à utiliser et offrant des performances efficaces. Cet article explique comment utiliser le framework Gin pour implémenter les fonctions d'analyse de données XML et JSON. Présentation du framework Gin Le framework Gin est un framework Web basé sur le langage Go, qui peut être utilisé pour créer des applications Web efficaces et évolutives. Le framework Gin est conçu pour être simple et facile à utiliser. Il fournit une variété de middleware et de plug-ins pour effectuer le développement.

Utilisez le framework Gin pour implémenter la génération automatique de documents API et de fonctions de centre de documents Utilisez le framework Gin pour implémenter la génération automatique de documents API et de fonctions de centre de documents Jun 23, 2023 am 11:40 AM

Avec le développement continu des applications Internet, l’utilisation d’interfaces API devient de plus en plus populaire. Au cours du processus de développement, afin de faciliter l'utilisation et la gestion des interfaces, la rédaction et la maintenance des documents API sont devenues de plus en plus importantes. La manière traditionnelle de rédiger des documents nécessite une maintenance manuelle, qui est inefficace et sujette aux erreurs. Afin de résoudre ces problèmes, de nombreuses équipes ont commencé à utiliser la génération automatique de documents API pour améliorer l'efficacité du développement et la qualité du code. Dans cet article, nous présenterons comment utiliser le framework Gin pour implémenter la génération automatique de documents API et de fonctions de centre de documents. Le gin en est un

Utilisez le framework Gin pour implémenter la passerelle API et les fonctions d'authentification et d'autorisation Utilisez le framework Gin pour implémenter la passerelle API et les fonctions d'authentification et d'autorisation Jun 22, 2023 am 08:57 AM

Dans l'architecture Internet moderne, la passerelle API est devenue un composant important et est largement utilisée dans les scénarios d'entreprise et de cloud computing. La fonction principale de la passerelle API est de gérer et de distribuer uniformément les interfaces API de plusieurs systèmes de microservices, de fournir un contrôle d'accès et une protection de sécurité, et peut également effectuer la gestion, la surveillance et la journalisation des documents API. Afin de mieux garantir la sécurité et l'évolutivité de la passerelle API, certains mécanismes de contrôle d'accès et d'authentification et d'autorisation ont également été ajoutés à la passerelle API. Un tel mécanisme peut garantir que les utilisateurs et les services

Utilisez le framework Gin pour implémenter des fonctions de surveillance et d'alarme en temps réel Utilisez le framework Gin pour implémenter des fonctions de surveillance et d'alarme en temps réel Jun 22, 2023 pm 06:22 PM

Gin est un framework Web léger qui utilise les capacités de traitement de coroutine et de routage à grande vitesse du langage Go pour développer rapidement des applications Web hautes performances. Dans cet article, nous explorerons comment utiliser le framework Gin pour implémenter des fonctions de surveillance et d'alarme en temps réel. La surveillance et les alarmes constituent une partie importante du développement de logiciels modernes. Dans un grand système, il peut y avoir des milliers de processus, des centaines de serveurs et des millions d’utilisateurs. La quantité de données générées par ces systèmes est souvent stupéfiante. Il est donc nécessaire de disposer d'un système capable de traiter rapidement ces données et de fournir des alertes en temps opportun.

Explication détaillée du proxy inverse et du transfert de requêtes dans le cadre Gin Explication détaillée du proxy inverse et du transfert de requêtes dans le cadre Gin Jun 23, 2023 am 11:43 AM

Avec le développement rapide des applications Web, de plus en plus d'entreprises ont tendance à utiliser le langage Golang pour le développement. Dans le développement Golang, l’utilisation du framework Gin est un choix très populaire. Le framework Gin est un framework Web hautes performances qui utilise fasthttp comme moteur HTTP et possède une conception d'API légère et élégante. Dans cet article, nous approfondirons l'application du proxy inverse et le transfert de requêtes dans le framework Gin. Le concept de proxy inverse Le concept de proxy inverse consiste à utiliser le serveur proxy pour rendre le client

Explication détaillée des performances de sécurité et de la configuration de la sécurité du framework Gin Explication détaillée des performances de sécurité et de la configuration de la sécurité du framework Gin Jun 22, 2023 pm 06:51 PM

Le framework Gin est un framework de développement Web léger basé sur le langage Go et fournit d'excellentes fonctionnalités telles que de puissantes fonctions de routage, la prise en charge des middlewares et l'évolutivité. Cependant, la sécurité est un facteur crucial pour toute application Web. Dans cet article, nous discuterons des performances de sécurité et de la configuration de la sécurité du framework Gin pour aider les utilisateurs à garantir la sécurité de leurs applications Web. 1. Performances de sécurité du framework Gin 1.1 Prévention des attaques XSS Les attaques par cross-site scripting (XSS) sont les attaques Web les plus courantes.

Explication détaillée du traitement d'internationalisation et prise en charge multilingue du framework Gin Explication détaillée du traitement d'internationalisation et prise en charge multilingue du framework Gin Jun 22, 2023 am 10:06 AM

Le framework Gin est un framework Web léger qui se caractérise par sa rapidité et sa flexibilité. Pour les applications qui doivent prendre en charge plusieurs langues, le framework Gin peut facilement effectuer un traitement d'internationalisation et une prise en charge multilingue. Cet article développera le traitement d'internationalisation et la prise en charge multilingue du framework Gin. Internationalisation Durant le processus de développement, afin de prendre en compte les utilisateurs de différentes langues, il est nécessaire d'internationaliser l'application. Pour faire simple, le processus d’internationalisation signifie modifier et adapter de manière appropriée les fichiers de ressources, les codes, les textes, etc.

Utiliser le framework Gin pour implémenter l'internationalisation et les fonctions de support multilingue Utiliser le framework Gin pour implémenter l'internationalisation et les fonctions de support multilingue Jun 23, 2023 am 11:07 AM

Avec le développement de la mondialisation et la popularité d'Internet, de plus en plus de sites Web et d'applications ont commencé à s'efforcer d'atteindre l'internationalisation et des fonctions de support multilingues pour répondre aux besoins de différents groupes de personnes. Afin de réaliser ces fonctions, les développeurs doivent utiliser des technologies et des frameworks avancés. Dans cet article, nous présenterons comment utiliser le framework Gin pour implémenter des capacités d'internationalisation et de support multilingue. Le framework Gin est un framework web léger écrit en langage Go. Il est efficace, facile à utiliser et flexible, et est devenu le framework préféré de nombreux développeurs. en plus,

See all articles