44e304977b
* use io.ReadFull instead of io.Reader's Read()
39 lignes
939 o
Go
39 lignes
939 o
Go
package crypto
|
|
|
|
import (
|
|
"crypto/md5"
|
|
"crypto/rand"
|
|
"fmt"
|
|
"io"
|
|
"strings"
|
|
)
|
|
|
|
// GenerateMD5Hash : Generate a md5 hash from a string
|
|
func GenerateMD5Hash(str string) (string, error) {
|
|
str = strings.ToLower(strings.TrimSpace(str))
|
|
hash := md5.New()
|
|
_, err := hash.Write([]byte(str))
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
return fmt.Sprintf("%x", hash.Sum(nil)), nil
|
|
}
|
|
|
|
// GenerateRandomToken16 : Generates a random token 16bits long
|
|
func GenerateRandomToken16() (string, error) {
|
|
return GenerateRandomToken(16)
|
|
}
|
|
|
|
// GenerateRandomToken32 : Generates a random token 32bits long
|
|
func GenerateRandomToken32() (string, error) {
|
|
return GenerateRandomToken(32)
|
|
}
|
|
|
|
// GenerateRandomToken : Generates a random token int n long
|
|
func GenerateRandomToken(n int) (string, error) {
|
|
token := make([]byte, n)
|
|
_, err := io.ReadFull(rand.Reader, token)
|
|
// %x base 16, lower-case, two characters per byte
|
|
return fmt.Sprintf("%x", token), err
|
|
|
|
}
|