技术文摘
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字符串的功能。在实际应用中,可以根据需求调整密钥和明文内容,以满足不同的加密需求。也要注意密钥的安全性和保密性,避免密钥泄露导致数据安全问题。
- 手写 Vue3 响应式系统之 Computed 实现
- 2022 年流行的技术有哪些?
- 一文深析:增长的种种事宜
- 大厂裁员与竞争内卷下,程序员工作还好吗?
- 一日一技:二分偏左,二分搜索于分布式系统是否有用?
- 2022 年开发人员适用的七个优质 Java IDE
- Spring 中字段格式化的详细使用
- 你了解理想中的接口自动化项目吗?
- 共话 Django 框架
- Geopandas 0.11 版本重要新特性概览
- 在 Ubuntu 中安装特定软件包版本的方法
- 为何在 Go 语言错误处理中更推荐使用 Pkg/Errors 三方库?
- Java 开发的九大工作范畴
- 日常开发必备神器 HttpUtil 超详细介绍
- 探讨合并两个已排序链表的方法