-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathhashers.go
118 lines (98 loc) · 2 KB
/
hashers.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
package crypto
import (
"crypto/md5"
"crypto/sha1"
"crypto/sha256"
"crypto/sha512"
"encoding/hex"
"hash"
"io"
"strings"
"golang.org/x/crypto/sha3"
)
// Predefine hash algorithm tag
const (
DefineMD5 = "md5"
DefineSHA1 = "sha1"
DefineSHA224 = "sha224"
DefineSHA256 = "sha256"
DefineSHA384 = "sha384"
DefineSHA512 = "sha512"
DefineSHA3224 = "sha3-224"
DefineSHA3256 = "sha3-256"
DefineSHA3384 = "sha3-384"
DefineSHA3512 = "sha3-512"
)
type Hasher struct {
Data []byte
Algorithm string
}
// Hash define algorithm is md5
func Hash(algorithm string, data []byte) (string, error) {
h := &Hasher{
Data: data,
Algorithm: algorithm,
}
return h.ToHex()
}
// GetHasher Get the hasher that you want
func (h *Hasher) GetHasher() hash.Hash {
var hasher hash.Hash
switch strings.ToLower(h.Algorithm) {
case DefineMD5:
hasher = md5.New()
case DefineSHA1:
hasher = sha1.New()
case DefineSHA224:
hasher = sha256.New224()
case DefineSHA256:
hasher = sha256.New()
case DefineSHA384:
hasher = sha512.New384()
case DefineSHA3224:
hasher = sha3.New224()
case DefineSHA3256:
hasher = sha3.New256()
case DefineSHA3384:
hasher = sha3.New384()
case DefineSHA3512:
hasher = sha3.New512()
default:
hasher = md5.New()
}
return hasher
}
// ToBytes Get origin hash data
func (h *Hasher) ToBytes() ([]byte, error) {
hasher := h.GetHasher()
_, err := hasher.Write(h.Data)
if err != nil {
return nil, err
}
return hasher.Sum(nil), nil
}
// ToBase64 Get final hash data by Base64
func (h *Hasher) ToBase64() (string, error) {
data, err := h.ToBytes()
if err != nil {
return "", err
}
return EnBase64(data), nil
}
// ToHex Get final hash data by hex
func (h *Hasher) ToHex() (string, error) {
data, err := h.ToBytes()
if err != nil {
return "", err
}
return EnHex(data), nil
}
// FileMD5 Hash the file stream
func FileMD5(file io.Reader) string {
hash := md5.New()
_, err := io.Copy(hash, file)
if err != nil {
return ""
}
return hex.EncodeToString(hash.Sum(nil))
}