技术文摘
Go 语言中使用 AES 加密明文并编码为 base64 字符串的方法
2025-01-09 02:08:51 小编
Go语言中使用AES加密明文并编码为base64字符串的方法
在Go语言开发中,数据加密是保障信息安全的重要手段。AES(Advanced Encryption Standard)作为一种对称加密算法,被广泛应用于数据加密领域。本文将介绍如何在Go语言中使用AES加密明文,并将加密结果编码为base64字符串。
我们需要导入必要的包:
package main
import (
"bytes"
"crypto/aes"
"crypto/cipher"
"encoding/base64"
)
接下来,定义一个函数用于AES加密:
func AESEncrypt(key []byte, plaintext []byte) ([]byte, error) {
block, err := aes.NewCipher(key)
if err!= nil {
return nil, err
}
plaintext = PKCS7Padding(plaintext, block.BlockSize())
ciphertext := make([]byte, len(plaintext))
mode := cipher.NewCBCEncrypter(block, key[:aes.BlockSize])
mode.CryptBlocks(ciphertext, plaintext)
return ciphertext, nil
}
这里的PKCS7Padding函数用于对明文进行填充,使其长度满足AES加密的要求:
func PKCS7Padding(ciphertext []byte, blockSize int) []byte {
padding := blockSize - len(ciphertext)%blockSize
padtext := bytes.Repeat([]byte{byte(padding)}, padding)
return append(ciphertext, padtext...)
}
然后,我们可以编写主函数来进行加密和base64编码:
func main() {
key := []byte("1234567890123456")
plaintext := []byte("Hello, World!")
ciphertext, err := AESEncrypt(key, plaintext)
if err!= nil {
panic(err)
}
encoded := base64.StdEncoding.EncodeToString(ciphertext)
println(encoded)
}
在上述代码中,我们首先定义了加密密钥和明文,然后调用AESEncrypt函数进行加密,最后使用base64.StdEncoding.EncodeToString将加密结果编码为base64字符串。
通过以上步骤,我们就实现了在Go语言中使用AES加密明文并编码为base64字符串的功能。在实际应用中,可以根据需求调整密钥和明文内容,以满足不同的加密需求。也要注意密钥的安全性和保密性,避免密钥泄露导致数据安全问题。
- MySQL 存储过程:数据处理效率提升的得力工具
- MySQL 存储过程:实现数据库操作的高效管理
- 全面剖析MySQL存储过程的应用场景
- MySQL 中怎样合理存储性别信息
- 深入解析MySQL中.ibd文件的作用与相关注意事项
- 探秘MySQL前缀索引的重要意义
- MySQL中.ibd文件的存储机制与调优策略
- MySQL 数据库.ibd 文件:作用与优化建议
- MySQL自动提交功能的深度探究
- MySQL 中用于性别字段的最佳数据类型是啥
- MySQL布尔类型常见问题的解决方法
- 怎样挑选适合自身的MySQL版本
- MySQL中如何使用前缀索引
- 深入剖析MySQL时间戳的原理及实现机制
- MySQL能否支持大小写不敏感查询