Maison  >  Article  >  développement back-end  >  Comment générer des entiers et des jetons aléatoires sécurisés en Go ?

Comment générer des entiers et des jetons aléatoires sécurisés en Go ?

Susan Sarandon
Susan Sarandonoriginal
2024-11-12 21:43:02155parcourir

How to Generate Secure Random Integers and Tokens in Go?

Génération d'entiers aléatoires sécurisés avec "crypto/rand"

Dans Go, générer des entiers aléatoires sécurisés est une tâche critique pour diverses applications cryptographiques. Le package "crypto/rand" fournit un mécanisme pour accomplir cela en toute sécurité.

Pour générer un entier aléatoire compris entre 0 et 27 à l'aide du package "crypto/rand", vous pouvez utiliser la fonction suivante :

func Int(rand io.Reader, max *big.Int) (n *big.Int, err error)

Cette fonction nécessite deux arguments :

  • rand : Une implémentation de io.Reader, tel que crypto/rand.Reader, pour générer des données aléatoires.
  • max : Un big.Int représentant la limite supérieure de l'entier aléatoire.

Pour générer un entier aléatoire compris entre 0 et 27, utilisez ce qui suit code :

nBig, err := rand.Int(rand.Reader, big.NewInt(27))
if err != nil {
    panic(err)
}
n := nBig.Int64()

Génération de jetons cryptographiques

Pour générer des jetons sécurisés, une meilleure approche consiste à utiliser le package "encoding/base32" pour générer une tranche d'octets aléatoire et convertissez-le en chaîne en utilisant l'encodage base32. Voici un exemple :

package main

import (
    "crypto/rand"
    "encoding/base32"
    "fmt"
)

func main() {
    randomBytes := make([]byte, 32)
    _, err := rand.Read(randomBytes)
    if err != nil {
        panic(err)
    }
    token := base32.StdEncoding.EncodeToString(randomBytes)[:27] // Adjust length as needed
    fmt.Println("Here is a random token: ", token)
}

Cette approche est considérée comme sécurisée pour générer des jetons car elle utilise un générateur de nombres aléatoires cryptographiquement sécurisé et convertit le résultat en chaîne à l'aide du codage base32, garantissant que les jetons de sortie sont imprévisibles et difficiles. deviner.

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