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:

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:

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