Generar clave hexadecimal segura con crypto y rand en Golang

Introducción

Hoy veremos cómo generar una clave hexadecimal que no pueda ser predecible. Dicha clave podemos utilizarla más tarde como clave de cifrado, id de sesiones, tokens, etcétera.

Generar clave hexadecimal segura

Lo único que tenemos que hacer es leer de rand.Reader y pasar los resultados a un arreglo que guardará la clave. Luego, convertimos esa clave a string, lo que nos dará algo como:

_7daaeec6c14a2a1de75d6927514c4f159cc80812a90587691b6312435f47f1b1_

Obviamente generará una clave diferente cuando lo ejecutemos.

El código queda así:

package main

import (
	"crypto/rand"
	"encoding/hex"
	"fmt"
	"io"
	"log"
)

func main() {
	// La longitud será el doble de la capacidad del arreglo (64 en este caso)
	var clave [32]byte
	_, err := io.ReadFull(rand.Reader, clave[:])
	if err != nil {
		log.Fatal(err)
	}
	fmt.Println("Clave => ", hex.EncodeToString(clave[:]))
}

Lo que imprime en pantalla:

Generar clave hexadecimal de 64 caracteres

En este caso es de 64 caracteres. Si queremos más, hay que cambiar la longitud del arreglo. Para generar una de 128 caracteres:

package main

import (
	"crypto/rand"
	"encoding/hex"
	"fmt"
	"io"
	"log"
)

func main() {
	// La longitud será el doble de la capacidad del arreglo (64 en este caso)
	var clave [64]byte
	_, err := io.ReadFull(rand.Reader, clave[:])
	if err != nil {
		log.Fatal(err)
	}
	fmt.Println("Clave => ", hex.EncodeToString(clave[:]))
}

Lo que da la siguiente salida:

Generar clave hexadecimal de 128 caracteres
Si el post ha sido de tu agrado te invito a que me sigas para saber cuando haya escrito un nuevo post, haya actualizado algún sistema o publicado un nuevo software. Facebook | X | Instagram | Telegram | También estoy a tus órdenes para cualquier contratación en mi página de contacto