工具代码
package tool
import (
"bytes"
"crypto/aes"
"crypto/cipher"
)
// AES加密函数
var key []byte = []byte("0@#3456789ABCDEF") //todo 记住这个长度只能是16 24 32 如果不是的话话会报错
func Encrypt(data []byte) ([]byte, error) {
block, err := aes.NewCipher(key)
if err != nil {
return nil, err
}
// 填充明文字节数组
paddingLen := aes.BlockSize - (len(data) % aes.BlockSize)
paddedData := append(data, bytes.Repeat([]byte{byte(paddingLen)}, paddingLen)...)
// 执行加密操作
encrypted := make([]byte, len(paddedData))
iv := make([]byte, aes.BlockSize) // 初始化向量,通常为全零
mode := cipher.NewCBCEncrypter(block, iv)
mode.CryptBlocks(encrypted, paddedData)
return encrypted, nil
}
// AES解密函数
func Decrypt(encryptedData []byte) ([]byte, error) {
block, err := aes.NewCipher(key)
if err != nil {
return nil, err
}
// 执行解密操作
decrypted := make([]byte, len(encryptedData))
iv := make([]byte, aes.BlockSize) // 初始化向量,通常为全零
mode := cipher.NewCBCDecrypter(block, iv)
mode.CryptBlocks(decrypted, encryptedData)
// 去除填充字节
paddingLen := int(decrypted[len(decrypted)-1])
decrypted = decrypted[:len(decrypted)-paddingLen]
return decrypted, nil
}
// 计算加密后的字节数组长度
func CalculateEncryptedLength(dataLen int) int {
paddingLen := aes.BlockSize - (dataLen % aes.BlockSize)
encryptedLen := dataLen + paddingLen
return encryptedLen
}
测试类
package test
import (
"beego_test/tool"
"testing"
)
// todo 字节解密和解密测试
func Test_encryption(t *testing.T) {
originalBytes := []byte{115, 91, 212, 128, 220, 50, 0, 247, 207, 91, 178, 183, 207, 59, 115, 91}
encryptedBytes, err := tool.Encrypt(originalBytes)
if err != nil {
log.Fatal(err)
}
d, err := tool.Decrypt(encryptedBytes)
fmt.Println("原始的字节为", originalBytes)
fmt.Println("加密后的字节为", encryptedBytes)
fmt.Println("加密后的字节的长度为", len(encryptedBytes))
fmt.Println("字节49加密后的长度", tool.CalculateEncryptedLength(49))
fmt.Println("解密后的字节为", d)
fmt.Println("无法根据密文长度推出原文长度")
fmt.Println("可以根据密文退出原文")
fmt.Println("可以根据原文长度推出密文长度")
fmt.Println("如果字节无法解密会报错")
tool.Decrypt(originalBytes)
}
原文地址:https://blog.csdn.net/wsrzsfgst/article/details/134757632
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_34598.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。