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)
}
相关推荐
IT_陈寒11 分钟前
Java的Date类又坑了我一次,改用时间戳真香
前端·人工智能·后端
systemPro1 小时前
2.6亿条设备数据,历史查询从超时到50ms,我做了什么
后端
要阿尔卑斯吗1 小时前
提示词优化启示:为什么“按顺序输出“比“关键度评分“更有效
后端
她的男孩2 小时前
后台接口加密别只会 HTTPS,ForgeAdmin 的 RSA + SM4/AES 源码拆解
后端·面试·开源
极光技术熊2 小时前
Spring AI 从入门到精通:构建你的 AI 开发知识体系
后端·github
程序员cxuan2 小时前
一句话,让你用上 GPT-5.6
人工智能·后端·程序员
远航_2 小时前
OpenSpec 完整详细介绍
前端·后端
AskHarries2 小时前
不用公网 IP,把 Windows 和 Linux 服务器放进同一个局域网:Tailscale 组网实战
后端
神奇小汤圆2 小时前
Java 的1 亿次对象创建:JVM 开启 / 关闭逃逸分析,GC 性能差距巨大
后端
tangdou3690986552 小时前
AI真好玩系列-2分钟快速了解DeepAgents | Quick Guide to DeepAgents in 2 Minutes
前端·javascript·后端