/
hash.go
89 lines (69 loc) · 1.3 KB
/
hash.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
package hash
import (
"hash"
"encoding/hex"
"encoding/base64"
)
// 默认
var defaultHash Hash
func init() {
defaultHash = NewHash()
}
// 构造函数
func NewHash() Hash {
return Hash{}
}
// 构造函数
func New() Hash {
return NewHash()
}
// 构造函数
func Hashing() Hash {
return NewHash()
}
/**
* hash
*
* @create 2022-3-27
* @author deatil
*/
type Hash struct {
// 数据
data []byte
// hash 接口
hash hash.Hash
// 错误
Error error
}
// Base64 编码
func (this Hash) Base64Encode(src []byte) string {
return base64.StdEncoding.EncodeToString(src)
}
// Base64 解码
func (this Hash) Base64Decode(s string) ([]byte, error) {
return base64.StdEncoding.DecodeString(s)
}
// Hex 编码
func (this Hash) HexEncode(src []byte) string {
return hex.EncodeToString(src)
}
// Hex 解码
func (this Hash) HexDecode(s string) ([]byte, error) {
return hex.DecodeString(s)
}
// NewHash
func (this Hash) NewHash(h hash.Hash) Hash {
this.hash = h
return this
}
// CheckSum
func (this Hash) Checksum(h hash.Hash) Hash {
h.Write(this.data)
this.data = h.Sum(nil)
return this
}
// 自定义方法
func (this Hash) FuncHash(f func([]byte) ([]byte, error)) Hash {
this.data, this.Error = f(this.data)
return this
}