Golang的crypto库加密解密怎么做 AES与RSA算法实现

Go语言中crypto库支持AES和RSA加密:AES使用GCM模式实现对称加解密,需随机IV和密钥;RSA用于非对称加密,推荐OAEP填充,常结合使用AES加密数据、RSA加密密钥以保障安全传输

golang的crypto库加密解密怎么做 aes与rsa算法实现

在Go语言中,crypto 库提供了强大的加密支持,其中 AES(对称加密)和 RSA(非对称加密)是两种最常用的加密算法。下面介绍如何使用标准库实现 AES 和 RSA 的基本加解密操作。

AES 对称加密(CBC模式示例)

AES 使用同一个密钥进行加密和解密,适合加密大量数据。以下是一个使用 AES-CBC 模式的简单实现:

加密流程:

密钥必须是 16、24 或 32 字节(对应 AES-128、192、256) 使用随机生成的初始化向量(IV)保证安全性 明文需填充至块大小(16字节)的倍数

代码示例:

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

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

解密流程:

从密文中提取 nonce 使用相同密钥和 nonce 进行解密

代码示例:

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

func aesDecrypt(ciphertext []byte, key []byte) ([]byte, error) {    block, err := aes.NewCipher(key)    if err != nil {        return nil, err    }    gcm, err := cipher.NewGCM(block)    if err != nil {        return nil, err    }    nonceSize := gcm.NonceSize()    if len(ciphertext) < nonceSize {        return nil, errors.New("ciphertext too short")    }    nonce, cipherblob := ciphertext[:nonceSize], ciphertext[nonceSize:]    plaintext, err := gcm.Open(nil, nonce, cipherblob, nil)    if err != nil {        return nil, err    }    return plaintext, nil}

RSA 非对称加密(公钥加密,私钥解密)

RSA 适用于加密小数据(如密钥),不适合大文件。以下演示生成密钥对、加密和解密过程。

生成密钥对:

代码示例:

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

func generateRSAKeys() (*rsa.PrivateKey, *rsa.PublicKey, error) {    privateKey, err := rsa.GenerateKey(rand.Reader, 2048)    if err != nil {        return nil, nil, err    }    return privateKey, &privateKey.PublicKey, nil}

使用公钥加密:

数据长度受限(如 2048位密钥最多加密 245 字节) 推荐使用 OAEP 填充(比 PKCS1v15 更安全)

代码示例:

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

func rsaEncrypt(plaintext []byte, pubKey *rsa.PublicKey) ([]byte, error) {    ciphertext, err := rsa.EncryptOAEP(        sha256.New(),        rand.Reader,        pubKey,        plaintext,        nil,    )    return ciphertext, err}

使用私钥解密:

代码示例:

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

func rsaDecrypt(ciphertext []byte, privKey *rsa.PrivateKey) ([]byte, error) {    plaintext, err := rsa.DecryptOAEP(        sha256.New(),        rand.Reader,        privKey,        ciphertext,        nil,    )    return plaintext, err}

实际使用建议

在真实场景中,通常结合使用 AES 和 RSA:

用 AES 加密原始数据(高效) 用 RSA 加密 AES 密钥(安全传输) 接收方先用 RSA 私钥解密出 AES 密钥,再解密数据

注意密钥管理、随机数安全、填充方式选择等细节,避免使用 ECB 模式或弱填充。

基本上就这些,Go 的 crypto 库设计清晰,只要理解加密原理,实现起来并不复杂但容易忽略安全细节。

以上就是Golang的crypto库加密解密怎么做 AES与RSA算法实现的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1398443.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月15日 15:26:38
下一篇 2025年12月15日 15:26:49

相关推荐

  • Go语言如何将字符串转换为字节数组

    go语言中字符串转字节数组常见且高效,通过[]byte(str)实现。1. 字符串是不可变的,转换为可变的[]byte便于修改;2. 底层操作如网络传输和文件读写需基于字节流;3. 转换会分配新内存并复制数据,频繁操作需考虑性能优化;4. 转换回字符串时应验证字节数组是否为有效utf-8编码,可用u…

    2025年12月15日 好文分享
    000
  • Go 语言中函数与方法的区别

    本文旨在阐明 Go 语言中函数和方法之间的关键差异。虽然两者在表面上看起来相似,但它们在定义、调用方式以及与数据关联方面存在根本区别。本文将通过代码示例和详细解释,帮助读者理解 Go 语言中函数和方法的概念,并掌握它们的使用场景。 在 Go 语言中,函数和方法是两个重要的概念,它们都是可执行的代码块…

    2025年12月15日
    000
  • 怎样优化Golang的GC压力 控制堆内存分配的最佳实践

    要优化Golang的GC压力和控制堆内存分配,核心是减少短生命周期对象的堆分配,通过使用值类型、预分配容量、sync.Pool复用对象、避免频繁字符串拼接、减少defer和闭包逃逸,并结合pprof分析内存热点,从而降低GC工作量和内存占用,提升程序性能。 优化Golang的GC压力和控制堆内存分配…

    2025年12月15日
    000
  • Golang并行基准测试怎么做 使用RunParallel方法实践

    runparallel是go中用于并行基准测试的核心方法,它通过启动多个goroutine并利用sync.waitgroup同步,使测试能真实模拟高并发场景下的性能表现;其使用pb.next()控制迭代,确保总执行次数为b.n且由多个goroutine分摊,默认并发数为gomaxprocs,可通过s…

    2025年12月15日
    000
  • Go语言中函数与方法的区别详解

    本文旨在深入解析Go语言中函数(Function)与方法(Method)之间的关键差异。通过对比定义、调用方式以及与接收者(Receiver)的关联,阐明方法作为特殊函数的概念,并辅以代码示例,帮助读者理解Go语言中面向对象编程的实现机制。 在Go语言中,函数和方法是两种不同的代码组织形式,理解它们…

    2025年12月15日
    000
  • 使用 Go 语言检测文件变更

    本文将介绍一种使用 Go 语言检测文件变更的跨平台方法。通过定期检查文件的大小和修改时间,可以有效地检测到文件的变化。这种方法简单易懂,适用于各种操作系统,但效率可能不如系统调用。本文提供示例代码,帮助开发者快速实现文件变更检测功能。 在许多应用场景中,我们需要实时监控文件的变化,例如配置文件更新、…

    2025年12月15日
    000
  • 将 Go 结构体转换为 JSON

    本文介绍了如何使用 encoding/json 包将 Go 结构体转换为 JSON 字符串。重点解释了结构体字段必须是导出的才能被 JSON 编码器访问,并提供了一个示例代码,展示了如何正确地将结构体转换为 JSON 格式。通过本文,读者可以避免在 Go 中进行 JSON 序列化时常见的 &#822…

    2025年12月15日
    000
  • 解决Go并发中的死锁问题:深入分析与实践

    本文旨在帮助开发者理解和解决Go并发编程中常见的死锁问题。通过分析一个包含三个并发goroutine互相通信的示例代码,我们将深入探讨死锁产生的原因,并提供一种通过引入缓冲通道和runtime.Gosched()来避免死锁的有效方法。本文还将强调并发程序设计中确定性和避免忙等待的重要性。 死锁的原因…

    2025年12月15日
    000
  • 解决Go并发程序中的死锁问题:深入分析与实践

    本文旨在帮助开发者理解和解决Go并发程序中常见的死锁问题,特别是当程序抛出 “throw: all goroutines are asleep – deadlock!” 错误时。我们将分析导致死锁的常见原因,并提供修改后的代码示例,展示如何通过缓冲通道和runti…

    2025年12月15日
    000
  • Go 并发程序死锁排查与避免:深入剖析与实践

    本文旨在帮助开发者理解和解决 Go 并发程序中常见的死锁问题。通过分析一个包含三个 Goroutine 相互通信的示例程序,我们将深入探讨死锁产生的原因,并提供有效的调试和修复策略,包括使用 runtime.Gosched() 和缓冲 Channel 来避免死锁,同时强调并发程序设计的复杂性和潜在的…

    2025年12月15日
    000
  • Golang微服务中的RPC调用如何保证安全性 Golang微服务RPC调用的安全机制解析

    保障golang微服务中rpc调用的安全需从身份认证、数据加密、访问控制入手。1. 使用tls加密通信,如通过grpc配置grpc.creds启用tls防止数据被窃听或篡改;2. 实现请求的身份认证,在上下文中传入token并服务端验证,阻止非法用户伪装调用;3. 配合rbac做细粒度权限控制,在拦…

    2025年12月15日 好文分享
    000
  • 怎样理解Golang的值传递特性 分析函数参数传递的底层机制

    Go函数参数始终值传递,即传递数据副本。基本类型修改不影响原值;传指针时地址副本指向同一内存,可修改原内容;slice、map等引用类型传递结构体副本,但内部指针仍指向原数据,故修改元素有效,扩容则不影响原变量;大结构体建议传指针以避免开销。 Golang 中的函数参数传递始终是值传递,也就是说,函…

    2025年12月15日
    000
  • Golang测试如何验证日志输出内容 使用logrus/hook等日志捕获技术

    在 golang 项目中验证日志输出内容,可使用 logrus 提供的 hook 或 buffer 方法进行捕获和断言。1. 实现 testhook 结构体并注册到 logger,可在 fire 方法中记录日志条目,用于验证日志内容和级别;2. 将 logger 输出设置为 bytes.buffer…

    2025年12月15日 好文分享
    000
  • Go语言结构体中的无效递归类型错误及解决方案

    本文旨在帮助Go语言初学者理解并解决结构体中出现的“invalid recursive type”错误。该错误通常发生在结构体包含自身类型的字段时,导致编译器无法确定结构体的大小。本文将详细解释错误原因,并提供有效的解决方案,同时提供示例代码进行演示。 在Go语言中,结构体是一种复合数据类型,允许将…

    2025年12月15日
    000
  • Go 模板处理二维数组:Web 开发实用指南

    本文旨在解决在 Go Web 开发中使用模板引擎处理二维数组的问题。通过示例代码,详细介绍了如何使用 text/template 包在模板中遍历和访问二维数组,并提供了使用 range 关键字进行嵌套循环的清晰示例,帮助开发者高效地将二维数组数据渲染到 HTML 页面。 在 Go Web 开发中,模…

    2025年12月15日
    000
  • Go 语言中结构体递归类型的正确使用方法

    在 Go 语言中,定义包含自身类型字段的结构体时,需要特别注意递归类型的处理。直接定义包含自身类型的结构体,会导致编译器无法确定结构体的大小,从而产生 “invalid recursive type” 错误。 例如,以下代码会导致编译错误: type Environment …

    2025年12月15日
    000
  • 如何提升Golang网络编程性能 调整TCP参数与连接池配置

    要显著提升go语言网络应用性能,需从两方面入手:一是操作系统层面优化tcp协议栈参数,二是应用层实施连接池策略。1.调整tcp_nodelay禁用nagle算法以降低延迟;2.启用so_reuseaddr避免端口占用问题;3.合理设置so_rcvbuf和so_sndbuf提升吞吐量;4.在http客…

    2025年12月15日 好文分享
    000
  • Go 模板访问二维数组:Web 开发实践指南

    本文旨在帮助开发者掌握如何在 Go 模板中访问和渲染二维数组数据。通过学习本文,你将能够有效地利用 text/template 包,将结构化的数据以表格或其他形式呈现在 Web 页面上。 在 Go Web 开发中,经常需要将数据传递到 HTML 模板中进行渲染。当数据包含二维数组时,如何正确地在模板…

    2025年12月15日
    000
  • Go语言结构体中的无效递归类型错误解析与解决方案

    在Go语言编程中,我们可能会遇到“invalid recursive type”的编译错误,尤其是在定义包含自身类型字段的结构体时。 这个问题源于Go语言在编译时需要确定结构体的大小,而递归类型会导致无限循环,无法确定结构体的大小。下面我们将详细解释这个问题,并提供解决方案。 问题分析 考虑以下代码…

    2025年12月15日
    000
  • Go 结构体中的无效递归类型

    Go 结构体中的无效递归类型 在 Go 语言中,结构体(struct)是一种复合数据类型,允许将不同类型的字段组合在一起。然而,在定义结构体时,如果结构体中包含自身类型的字段,就会遇到“invalid recursive type”错误。这是因为编译器无法确定这种递归结构体的大小。 考虑以下示例: …

    2025年12月15日
    000

发表回复

登录后才能评论
关注微信