go使用aes加密算法

工具代码

go 复制代码
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
}

测试类

go 复制代码
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)
}
相关推荐
忆~遂愿2 分钟前
GE 引擎进阶:依赖图的原子性管理与异构算子协作调度
java·开发语言·人工智能
沐知全栈开发6 分钟前
API 类别 - 交互
开发语言
PP东9 分钟前
Flowable学习(二)——Flowable概念学习
java·后端·学习·flowable
invicinble18 分钟前
springboot的核心实现机制原理
java·spring boot·后端
人道领域26 分钟前
SSM框架从入门到入土(AOP面向切面编程)
java·开发语言
铅笔侠_小龙虾27 分钟前
Flutter 实战: 计算器
开发语言·javascript·flutter
全栈老石44 分钟前
Python 异步生存手册:给被 JS async/await 宠坏的全栈工程师
后端·python
2的n次方_44 分钟前
Runtime 执行提交机制:NPU 硬件队列的管理与任务原子化下发
c语言·开发语言
space62123271 小时前
在SpringBoot项目中集成MongoDB
spring boot·后端·mongodb
2501_944711431 小时前
JS 对象遍历全解析
开发语言·前端·javascript