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.
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:
Hoy te voy a presentar un creador de credenciales que acabo de programar y que…
Ya te enseñé cómo convertir una aplicación web de Vue 3 en una PWA. Al…
En este artículo voy a documentar la arquitectura que yo utilizo al trabajar con WebAssembly…
En un artículo anterior te enseñé a crear un PWA. Al final, cualquier aplicación que…
Al usar Comlink para trabajar con los workers usando JavaScript me han aparecido algunos errores…
En este artículo te voy a enseñar cómo usar un "top level await" esperando a…
Esta web usa cookies.