/
crypto.go
79 lines (65 loc) · 1.43 KB
/
crypto.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
package crypticmysql
import (
"crypto/aes"
"crypto/block"
"bytes"
)
const aesKeyLen = 128
func aesKey(key []byte) []byte {
const keyLen = aesKeyLen / 8
if len(key) == keyLen {
return key
}
k := make([]byte, keyLen)
copy(k, key)
for i := keyLen; i < len(key); {
for j := 0; j < keyLen && i < len(key); j, i = j+1, i+1 {
k[j] ^= key[i]
}
}
return k
}
// Encrypt using MySQL AES Encrypt
func AESEncrypt(in, key []byte) []byte {
cipher, err := aes.NewCipher(aesKey(key))
if err != nil {
return nil
}
pBlocks := (len(in) + aes.BlockSize) / aes.BlockSize
pText := make([]byte, pBlocks*aes.BlockSize)
copy(pText, in)
padLen := byte(len(pText) - len(in))
for i := len(in); i < len(pText); i++ {
pText[i] = padLen
}
pBuf := bytes.NewBuffer(pText)
cBuf := bytes.NewBuffer(make([]byte, 0, len(pText)))
cWtr := block.NewECBEncrypter(cipher, cBuf)
_, err = pBuf.WriteTo(cWtr)
if err != nil {
return nil
}
return cBuf.Bytes()
}
// Decrypt using MySQL AES Decrypt
func AESDecrypt(in, key []byte) []byte {
cipher, err := aes.NewCipher(aesKey(key))
if err != nil {
return nil
}
pBuf := bytes.NewBuffer(make([]byte, 0, len(in)))
cRdr := block.NewECBDecrypter(cipher, bytes.NewBuffer(in))
_, err = pBuf.ReadFrom(cRdr)
if err != nil {
return nil
}
pText := pBuf.Bytes()
if len(pText) < 1 {
return nil
}
lenpt := len(pText) - int(pText[len(pText)-1])
if lenpt < 0 {
return nil
}
return pText[:lenpt]
}