新闻中心
Golang如何使用crypto包实现加密_Golang crypto加密实践
Go语言crypto包支持SHA-256哈希、AES对称加密和RSA非对称加密;通过sha256.Sum256计算摘要,aes.NewCipher配合cipher.NewCBCEncrypter实现AES加密,rsa.GenerateKey生成密钥对并使用EncryptPKCS1v15进行RSA加密,适用于数据安全、完整性校验与密钥交换场景。

Go语言的crypto包提供了多种加密算法的支持,包括对称加密、非对称加密、哈希函数和数字签名等。实际开发中,合理使用这些工具能有效保障数据安全。下面通过常见场景说明如何在Golang中使用crypto包进行加密操作。
使用crypto/sha256生成消息摘要
SHA-256是常用的哈希算法,适用于密码存储、数据完整性校验等场景。
示例:计算字符串的SHA-256值代码实现:
使用sha256.Sum256()可以直接得到[32]byte类型的摘要,转为十六进制字符串便于展示。
package main
import (
"crypto/sha256"
"fmt"
)
func main() {
data := []byte("hello world")
hash := sha256.Sum256(data)
fmt.Printf("%x\n", hash) // 输出: b94d27b9934d3e08a52e52d7da7dabfac484efe37a5380ee9088f7ace2efcde9
}
使用crypto/aes进行AES对称加密
AES(高级加密标准)是最广泛使用的对称加密算法之一,适合加密大量数据。
关键点:
需要密钥长度为16、24或32字节(分别对应AES-128、AES-192、AES-256),并选择合适的加密模式如CBC或GCM。
package main
import (
"crypto/aes"
"crypto/cipher"
"crypto/rand"
"fmt"
"io"
)
func encrypt(plaintext []byte, key []byte) ([]byte, error) {
block, err := aes.NewCipher(key)
if err != nil {
return nil, err
}
blockSize := block.BlockSize()
plaintext = pad(plaintext, blockSize)
ciphertext := make([]byte, blockSize+len(plaintext))
iv := ciphertext[:blockSize]
if _, err := io.ReadFull(rand.Reader, iv); err != nil {
return nil, err
}
mode := cipher.NewCBCEncrypter(block, iv)
mode.CryptBlocks(ciphertext[blockSize:], plaintext)
return ciphertext, nil
}
func pad(data []byte, blockSize int) []byte {
padding := blockSize - len(data)%blockSize
padtext := make([]byte, padding)
for i := range padtext {
padtext[i] = byte(padding)
}
return append(data, padtext...)
}
func main() {
key := []byte("example key 1234") // 16字节密钥
plaintext := []byte("this is a secret message")
ciphertext, _ := encrypt(plaintext, key)
fmt.Printf("Encrypted: %x\n", ciphertext)
}
使用crypto/rsa实现非对称加密
RSA常用于安全通信中的密钥交换或数字签名,公钥加密,私钥解密。
Motiff妙多
Motiff妙多是一款AI驱动的界面设计工具,定位为“AI时代设计工具”
334
查看详情
示例:生成RSA密钥并对数据加密说明:
使用rsa.GenerateKey生成密钥对,利用公钥加密,私钥可后续用于解密。
package main
import (
"crypto/rand"
"crypto/rsa"
"crypto/x509"
"encoding/pem"
"fmt"
"os"
)
func generateRSAKey() {
privateKey, err := rsa.GenerateKey(rand.Reader, 2048)
if err != nil {
panic(err)
}
derStream := x509.MarshalPKCS1PrivateKey(privateKey)
block := &pem.Block{
Type: "RSA PRIVATE KEY",
Bytes: derStream,
}
pemfile, _ := os.Create("private.pem")
pem.Encode(pemfile, block)
pemfile.Close()
publicKey := &privateKey.PublicKey
pubDer, _ := x509.MarshalPKIXPublicKey(publicKey)
pubBlock := &pem.Block{
Type: "PUBLIC KEY",
Bytes: pubDer,
}
pubFile, _ := os.Create("public.pem")
pem.Encode(pubFile, pubBlock)
pubFile.Close()
}
func encryptWithPubKey(msg []byte, pub *rsa.PublicKey) ([]byte, error) {
return rsa.EncryptPKCS1v15(rand.Reader, pub, msg)
}
func main() {
generateRSAKey()
fmt.Println("RSA密钥已生成")
}
上述代码会生成private.pem和public.pem两个文件,可用于后续加解密流程。
基本上就这些常见用法。实际项目中注意密钥管理、填充模式选择以及避免硬编码敏感信息。crypto包设计严谨,配合标准库使用非常方便。
以上就是Golang如何使用crypto包实现加密_Golang crypto加密实践的详细内容,更多请关注其它相关文章!
# 相关文章
# 廊坊抖音seo搜索公司
# 站内营销推广策略手机壳
# 手表营销推广方案
# 双柏网站优化服务
# 特产网站建设银行
# 石家庄软文推广营销招聘
# 浦东新区seo网站优化
# 新安哪些网站优化
# 深圳抖音seo机构
# 厦门seo内链
# 并对
# 解决问题
# 正则表达式
# 可以直接
# 中文网
# go
# 公钥
# 非对称
# 适用于
# 如何使用
# crypto
# 标准库
# 数据加密
# stream
# ai
# 工具
# 字节
# app
# 编码
# go语言
# golang
相关栏目:
【
科技资讯46185 】
【
网络学院92790 】
相关推荐:
文心一言怎样用插件调度API数据_文心一言用插件调度API数据【API调用】
处理Kafka消费者会话超时:深入理解消息处理语义与幂等性
漫蛙2在线漫画入口 漫蛙正版漫画网页版直达
Golang如何测试channel通信行为_Golang channel通信测试与分析方法
QQ网页版官方账号入口 QQ网页版网页版登录指南
KFC早餐时段怎么领特惠代码_KFC早餐订餐优惠代码获取与使用说明
Surface怎么安装系统 微软Surface Pro U盘重装win11教程
React列表渲染与独立状态管理:避免全局状态影响局部更新
火锅吃太多会怎样 火锅吃太多会上火吗
单射、满射与双射的关系 一文理清所有逻辑
vivo浏览器怎么扫描二维码 vivo浏览器内置扫一扫功能使用方法
手机CPU怎么影响游戏体验_手机CPU对游戏性能的影响分析
CSS Grid如何控制元素对齐_align-items与justify-items组合使用
在J*a项目里如何构建对象之间的契约_接口约束的实际落地
QQ邮箱登录官网首页 腾讯QQ邮箱网页入口
微信群消息显示延迟如何解决 微信群消息刷新优化方法
Pyrogram与g4f集成:异步编程实践与常见错误解决
荣耀Play7T运行卡顿解决_荣耀Play7T性能优化
Golang如何实现容器化日志收集与分析_Golang容器日志收集分析方法
MAC如何安全彻底地删除文件_MAC使用终端命令确保文件无法被恢复
Typer应用中动态命令行参数的解析与处理
CSS图片焦点样式实现教程:理解与应用tabindex属性
Fabric模组开发:自定义物品与物品组的现代管理方法
Golang如何处理RPC请求负载均衡_Golang RPC请求负载均衡策略与实践
Django通过AJAX异步上传图片并保存至模型的完整指南
J*aScript DOM操作:高效清空列表元素的策略与实践
FullCalendar 自定义按钮样式定制指南
绝地鸭卫平a核爆刀流玩法攻略
必由学官网首页入口 必由学教师网页版登录指南
ACG动漫手机版官网入口 手机ACG动漫APP在线观看正版
QQ邮箱官网登录入口 QQ邮箱网页版邮箱快速登录
J*a里如何实现线程安全的懒加载单例_懒加载单例实现方法解析
如何在CSS中使用visited与link控制链接颜色_visited link伪类配合
qq游戏免费畅玩入口_qq游戏电脑版快速启动
在J*a中如何开发简易仓库管理与库存统计_仓库管理库存统计项目实战解析
c++中的std::launder有什么实际用途_c++对象生命周期与指针优化
漫蛙漫画网页端入口 漫蛙2官方正版漫画站点
J*aScript打印功能_j*ascript输出控制
css元素hover动画延迟生效怎么办_使用animation-delay调整触发时间
2025AO3夸克浏览器通道_AO3手机HTTPS安全入口分享
荒野行动PC版怎么注册_荒野行动PC版账号注册详细流程图文教程
J*aScript对象创建方式_J*aScript设计模式应用
凉拌黄瓜怎么拌更入味 凉拌黄瓜简单家常做法
在Qt QML中通过Python字典动态更新TextEdit内容的教程
Golang切片为何属于引用类型_Golang slice底层结构与引用语义说明
AngularJS $http POST请求数据传递与Go后端接收实践
J*aScript异步迭代器_j*ascript异步遍历
Win11怎么开启高性能模式_Windows 11电源计划优化设置
ArchiveofOurOwn小说阅读-ArchiveofOurOwn同人作品访问链接
qq邮箱发邮件给国外发不出去_QQ邮箱国际邮件发送失败原因与解决


2025-11-27
浏览次数:次
返回列表