代码拉取完成,页面将自动刷新
// Package crypto provides aes 加解密
package crypto
import (
"crypto/aes"
"crypto/cipher"
"errors"
)
type AESCrypter struct {
encryptBlock cipher.BlockMode
decryptBlock cipher.BlockMode
block cipher.Block
key []byte
}
func newAES(key []byte) (Crypter, error) {
block, err := aes.NewCipher(key[0:aes.BlockSize])
if err != nil {
return nil, err
}
cpt := &AESCrypter{
encryptBlock: cipher.NewCBCEncrypter(block, []byte(key)[0:aes.BlockSize]),
decryptBlock: cipher.NewCBCDecrypter(block, []byte(key)[0:aes.BlockSize]),
key: []byte(key)[0:aes.BlockSize],
block: block,
}
return cpt, nil
}
func (cpt *AESCrypter) Encrypt(src []byte) ([]byte, error) {
src = PKCS5Padding(src, aes.BlockSize)
if len(src)%aes.BlockSize != 0 {
//填充错误
return nil, errors.New("Fill error")
}
dst := make([]byte, len(src))
encryptBlock := cipher.NewCBCEncrypter(cpt.block, []byte(cpt.key)[0:aes.BlockSize])
encryptBlock.CryptBlocks(dst, src)
return dst, nil
}
func (cpt *AESCrypter) Decrypt(src []byte) ([]byte, error) {
dst := make([]byte, len(src))
decryptBlock := cipher.NewCBCDecrypter(cpt.block, []byte(cpt.key)[0:aes.BlockSize])
decryptBlock.CryptBlocks(dst, src)
dst = PKCS5UnPadding(dst)
return dst, nil
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。