新闻中心

Golang如何使用crypto包实现加密_Golang crypto加密实践

2025-11-27
浏览次数:
返回列表
Go语言crypto包支持SHA-256哈希、AES对称加密和RSA非对称加密;通过sha256.Sum256计算摘要,aes.NewCipher配合cipher.NewCBCEncrypter实现AES加密,rsa.GenerateKey生成密钥对并使用EncryptPKCS1v15进行RSA加密,适用于数据安全、完整性校验与密钥交换场景。

golang如何使用crypto包实现加密_golang crypto加密实践

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。

示例:使用AES-CBC模式加密字符串

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妙多

Motiff妙多是一款AI驱动的界面设计工具,定位为“AI时代设计工具”

Motiff妙多 334 查看详情 Motiff妙多 示例:生成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邮箱国际邮件发送失败原因与解决 

搜索