Linux Golang如何实现数据加密与解密
在Linux环境下使用Go语言实现数据加密与解密
想在Linux环境下用Go语言搞定数据加密和解密?这事儿其实没想象中那么复杂。Go标准库里的crypto包已经为我们准备好了不少趁手的工具。今天,咱们就以最常用的对称加密算法AES(高级加密标准)为例,手把手走一遍完整的加密解密流程。下面的示例代码可以直接拿来用,但有几个关键点需要特别注意。
免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

AES加密与解密示例
package main
import (
"crypto/aes"
"crypto/cipher"
"crypto/rand"
"encoding/base64"
"fmt"
"io"
)
// 加密函数
func encrypt(plainText string, key []byte) (cipherText string, err error) {
// 创建一个AES块
block, err := aes.NewCipher(key)
if err != nil {
return "", err
}
// 生成随机IV
iv := make([]byte, aes.BlockSize)
if _, err := io.ReadFull(rand.Reader, iv); err != nil {
return "", err
}
// 创建一个cipher.BlockMode实例
mode := cipher.NewCBCEncrypter(block, iv)
// 填充明文
plainTextBytes := []byte(plainText)
padding := aes.BlockSize - len(plainTextBytes)%aes.BlockSize
padText := bytes.Repeat([]byte{byte(padding)}, padding)
plainTextBytes = append(plainTextBytes, padText...)
// 加密数据
cipherTextBytes := make([]byte, len(plainTextBytes))
mode.CryptBlocks(cipherTextBytes, plainTextBytes)
// 返回Base64编码的密文和IV
cipherText = base64.StdEncoding.EncodeToString(cipherTextBytes)
return cipherText, nil
}
// 解密函数
func decrypt(cipherText string, key []byte) (plainText string, err error) {
// 解码Base64密文
cipherTextBytes, err := base64.StdEncoding.DecodeString(cipherText)
if err != nil {
return "", err
}
// 创建一个AES块
block, err := aes.NewCipher(key)
if err != nil {
return "", err
}
// 创建一个cipher.BlockMode实例
iv := cipherTextBytes[:aes.BlockSize]
mode := cipher.NewCBCDecrypter(block, iv)
// 解密数据
plainTextBytes := make([]byte, len(cipherTextBytes)-aes.BlockSize)
mode.CryptBlocks(plainTextBytes, cipherTextBytes[aes.BlockSize:])
// 去除填充
padding := plainTextBytes[len(plainTextBytes)-1]
plainTextBytes = plainTextBytes[:len(plainTextBytes)-int(padding)]
// 返回明文
plainText = string(plainTextBytes)
return plainText, nil
}
func main() {
key := []byte("1234567890123456") // 16字节密钥
plainText := "Hello, World!"
// 加密
cipherText, err := encrypt(plainText, key)
if err != nil {
fmt.Println("加密失败:", err)
return
}
fmt.Println("加密后的密文:", cipherText)
// 解密
decryptedText, err := decrypt(cipherText, key)
if err != nil {
fmt.Println("解密失败:", err)
return
}
fmt.Println("解密后的明文:", decryptedText)
}
代码说明
上面的代码虽然不长,但每一步都至关重要。我们来拆解一下:
加密函数
encrypt:- 首先,得用密钥创建一个AES密码块,这是所有操作的基础。
- 接着,生成一个随机的初始化向量(IV)。这一步千万别用固定值,否则会大大降低安全性。
- 然后,选用CBC模式来构造加密器。为什么是CBC?因为它比基础的ECB模式更安全,能有效防止模式分析攻击。
- 接下来是个关键步骤:填充明文。AES是块加密算法,要求数据长度必须是块大小的整数倍,所以不够的部分得补上。这里用的是PKCS#7填充方式。
- 最后,执行加密操作,并把结果转换成Base64编码的字符串返回,这样便于存储和传输。
解密函数
decrypt:- 解密是加密的逆过程。第一步,先把Base64格式的密文解码回字节数组。
- 同样,需要用相同的密钥创建AES密码块。
- 密文的前16个字节(AES块大小)就是之前加密时用的IV,把它提取出来。
- 用密钥和IV构造出CBC模式的解密器。
- 执行解密操作后,得到的是带填充的明文字节,需要根据最后一个字节的值,把填充的部分去掉,才能得到原始数据。
注意事项
代码跑起来不难,但要真正用在生产环境,有几个安全要点必须牢记:
- 密钥长度:AES可不是随便一串字符就能当密钥的。它严格支持三种长度:128位(16字节)、192位(24字节)和256位(32字节)。示例里用了16字节,如果你需要更高强度,记得对应调整。
- IV(初始化向量):IV的作用是确保即使加密相同的明文,每次产生的密文也不同。所以,它必须是随机生成的,并且每次加密都要换新的。好消息是,IV不需要保密,可以和密文一起存、一起传,但必须保证其唯一性。
- 填充:只要用到块加密模式(如CBC),填充就绕不开。PKCS#7是行业内的标准做法,兼容性也最好,通常直接用它就行。
总的来说,在Linux上用Go实现AES加密解密,核心就是理解块加密的原理、选对模式、并妥善处理密钥与IV。把上面这套流程搞明白,大部分对称加密的需求都能应对自如了。
游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。
同类文章
ifconfig命令如何显示路由信息
ifconfig命令如何显示路由信息 开门见山地说,ifconfig 这个命令,它的核心职责是显示和配置网络接口本身的参数,比如我们最关心的 IP 地址、子网掩码、广播地址等等。至于路由信息?它并不直接负责这一块。 那么,问题来了:想查看路由信息,到底该用什么命令呢?别急,下面这两个命令才是你的得力
Ubuntu上phpstorm如何使用终端
在 Ubuntu 上使用 PhpStorm 内置终端 对于在 Ubuntu 环境下进行 PHP 开发的工程师来说,将代码编辑器和终端无缝集成,能极大提升工作流的顺畅度。PhpStorm 内置的终端工具,恰好提供了这种“一站式”的便利。它让你无需离开 IDE,就能轻松执行各种系统命令和项目脚本。 快速
Debian Java如何更新系统依赖
在Debian系统中更新Ja va系统依赖 在Debian系统上维护Ja va环境,保持系统依赖的更新是关键一步。这不仅关乎安全,也影响着应用的稳定性。下面这份操作指南,能帮你系统化地完成这项工作。 1 更新系统包列表 动手之前,得先确保手里的“软件目录”是最新的。打开终端,输入这个基础命令: s
Debian Java日志管理如何高效
Debian Ja va 日志管理高效实践 日志管理这事儿,说大不大,说小不小。处理好了,排查问题事半功倍;处理不好,关键时刻找不到线索,磁盘还可能被撑爆。今天,咱们就来聊聊在 Debian 环境下,如何为 Ja va 应用搭建一套既高效又省心的日志管理体系。 一 架构与组件选型 搭建日志体系,第一
Debian Compton与Gnome Shell兼容吗
Debian 上 Compton 与 Gnome Shell 的兼容性说明 在 Debian 系统上,能否让 Compton 与 Gnome Shell 和谐共处,很大程度上取决于你使用的会话类型。简单来说,这是一个“二选一”的场景:如果你使用的是传统的 Xorg 会话,那么 Compton 通常可
- 日榜
- 周榜
- 月榜
1
2
3
4
5
6
7
8
9
10
1
2
3
4
5
6
7
8
9
10
相关攻略
2015-03-10 11:25
2015-03-10 11:05
2021-08-04 13:30
2015-03-10 11:22
2015-03-10 12:39
2022-05-16 18:57
2025-05-23 13:43
2025-05-23 14:01
热门教程
- 游戏攻略
- 安卓教程
- 苹果教程
- 电脑教程
热门话题

