go使用aes加密算法

工具代码

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)
}

评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

超维Ai编程

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值