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:
<em>7daaeec6c14a2a1de75d6927514c4f159cc80812a90587691b6312435f47f1b1</em>
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: