Maison > Article > développement back-end > Comment générer des entiers et des jetons aléatoires sécurisés en 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 :
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!