0

0

如何在Golang中使用crypto加密数据_MD5、SHA和AES加密示例

P粉602998670

P粉602998670

发布时间:2025-12-31 10:42:08

|

171人浏览过

|

来源于php中文网

原创

MD5和SHA是单向哈希算法,不可逆,仅用于校验或密码加盐;AES是对称加密算法,支持加解密,推荐使用AES-GCM模式。

如何在golang中使用crypto加密数据_md5、sha和aes加密示例

Go 语言标准库 crypto 包提供了多种加密算法支持,但需注意:MD5 和 SHA 系列属于**哈希(散列)算法,不可逆,不用于“加密数据”**;而 AES 是真正的对称加密算法,可用于加解密。下面分别说明三者的正确用法、常见误区及实用示例。

MD5 和 SHA:只做哈希,不做加密

MD5、SHA-1、SHA-256 等是单向哈希函数,设计目标是生成固定长度摘要,用于校验、签名、密码存储(配合 salt)等,不能还原原始数据。误称其为“加密”容易引发安全误解。

  • MD5 已被证明不安全,不应用于密码或完整性校验(如文件校验可用但不推荐)
  • SHA-256 是当前主流推荐的哈希算法(属于 SHA-2 家族)
  • 哈希操作无需密钥,输入相同则输出必然相同

示例:计算字符串的 SHA-256 哈希值

(实际代码中应使用 sha256.Sum256hash.Hash 接口)

h := sha256.New()
h.Write([]byte("hello"))
fmt.Printf("%x\n", h.Sum(nil)) // 输出 68e656b255ad44ed79680a3a7d65f3c3a8e3e8c3b7e7a7d6b5c4a3f2e1d0c9b8

AES:标准对称加密,支持加解密

AES(Advanced Encryption Standard)是 Go 中最常用的对称加密算法,需指定密钥(16/24/32 字节对应 AES-128/AES-192/AES-256)、分组模式(如 CBC、GCM)和填充方式(如 PKCS7)。Go 标准库不内置 PKCS7 填充,需手动实现

立即学习go语言免费学习笔记(深入)”;

Cursor
Cursor

一个新的IDE,使用AI来帮助您重构、理解、调试和编写代码。

下载
  • 推荐使用 crypto/aes + crypto/cipher,优先选择 AEAD 模式(如 GCM),它同时保证机密性与完整性
  • CBC 模式需随机 IV(初始化向量),且必须安全传输/存储 IV(IV 不需要保密,但必须唯一且不可预测)
  • 密钥必须保密,且建议通过密钥派生函数(如 crypto/scrypt)从密码生成

示例:AES-GCM 加密(安全、简洁、防篡改)

(密钥 32 字节,随机生成 nonce)

func encryptAESGCM(key, plaintext []byte) ([]byte, error) {
    block, _ := aes.NewCipher(key)
    aesgcm, _ := cipher.NewGCM(block)
    nonce := make([]byte, aesgcm.NonceSize())
    if _, err := rand.Read(nonce); err != nil {
        return nil, err
    }
    ciphertext := aesgcm.Seal(nonce, nonce, plaintext, nil)
    return ciphertext, nil
}

常见错误与安全提醒

很多初学者会踩坑,以下几点务必注意:

  • 用 MD5/SHA 存储密码?❌ —— 必须加盐(salt)并使用专用函数如 golang.org/x/crypto/bcryptscrypt
  • 编码 AES 密钥?❌ —— 密钥应安全管理(环境变量、KMS、配置中心),切勿写死在代码里
  • 忽略 IV 随机性?❌ —— CBC 或 CTR 模式下重复 IV 可导致严重信息泄露
  • 用 ECB 模式?❌ —— ECB 不安全,已淘汰,Go 中甚至没直接封装,切勿自行实现
  • 混淆哈希与加密?❌ —— “MD5 加密”这种说法不专业,也易误导架构设计

实用建议:该用什么?

根据场景选择合适工具

  • 验证文件/数据完整性 → 用 sha256sha512
  • 用户密码存储 → 用 bcrypt(自动加盐+慢哈希)
  • 敏感数据传输或本地存储加解密 → 用 AES-GCM(首选)或 AES-CBC + HMAC(需额外认证)
  • 需要密钥派生(如从密码生成 AES 密钥)→ 用 scryptpbkdf2

Go 生态中更推荐使用成熟封装库(如 github.com/zjhmale/go-cryptogolang.org/x/crypto 子包),而非裸用底层 crypto/aes,以减少出错概率。

相关专题

更多
golang如何定义变量
golang如何定义变量

golang定义变量的方法:1、声明变量并赋予初始值“var age int =值”;2、声明变量但不赋初始值“var age int”;3、使用短变量声明“age :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

174

2024.02.23

golang有哪些数据转换方法
golang有哪些数据转换方法

golang数据转换方法:1、类型转换操作符;2、类型断言;3、字符串和数字之间的转换;4、JSON序列化和反序列化;5、使用标准库进行数据转换;6、使用第三方库进行数据转换;7、自定义数据转换函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

224

2024.02.23

golang常用库有哪些
golang常用库有哪些

golang常用库有:1、标准库;2、字符串处理库;3、网络库;4、加密库;5、压缩库;6、xml和json解析库;7、日期和时间库;8、数据库操作库;9、文件操作库;10、图像处理库。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

335

2024.02.23

golang和python的区别是什么
golang和python的区别是什么

golang和python的区别是:1、golang是一种编译型语言,而python是一种解释型语言;2、golang天生支持并发编程,而python对并发与并行的支持相对较弱等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

206

2024.03.05

golang是免费的吗
golang是免费的吗

golang是免费的。golang是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的开源编程语言,采用bsd开源协议。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

388

2024.05.21

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

193

2025.06.09

golang相关判断方法
golang相关判断方法

本专题整合了golang相关判断方法,想了解更详细的相关内容,请阅读下面的文章。

188

2025.06.10

golang数组使用方法
golang数组使用方法

本专题整合了golang数组用法,想了解更多的相关内容,请阅读专题下面的文章。

191

2025.06.17

vlookup函数使用大全
vlookup函数使用大全

本专题整合了vlookup函数相关 教程,阅读专题下面的文章了解更多详细内容。

26

2025.12.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 2.3万人学习

Git版本控制工具
Git版本控制工具

共8课时 | 1.5万人学习

Git中文开发手册
Git中文开发手册

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号