当前位置: 首页 > news >正文

golang学习笔记25——golang 实现 MD5加密、RSA加密 和 Base64编码

  • 推荐学习文档
    • golang应用级os框架,欢迎star
    • golang应用级os框架使用案例,欢迎star
    • 案例:基于golang开发的一款超有个性的旅游计划app经历
    • golang实战大纲
    • golang优秀开发常用开源库汇总
    • 想学习更多golang知识,这里有免费的golang学习笔记专栏

文章目录

    • 引言
    • MD5 实现
    • RSA 实现
    • Base64 实现
    • 总结

引言

在开发过程中,经常会涉及到数据加密、编码等操作。本文将详细介绍在 Go 语言中如何实现 MD5 哈希、RSA 加密以及 Base64 编码,并通过代码示例来加深理解。

MD5 实现

  • MD5(Message-Digest Algorithm 5)是一种广泛使用的哈希函数,用于生成数据的固定长度的哈希值。在 Go 语言中,可以使用crypto/md5包来实现 MD5 计算。
    • 源码可直接使用
  • 以下是一个简单的示例代码:
package mainimport ("crypto/md5""fmt""io"
)func main() {data := []byte("This is a test string for MD5.")hash := md5.New()io.WriteString(hash, string(data))md5Sum := hash.Sum(nil)fmt.Printf("MD5 sum: %x\n", md5Sum)
}

在上述代码中,首先创建了一个md5.Hash对象,然后通过io.WriteString将数据写入哈希对象中,最后通过Sum方法获取哈希值。

RSA 实现

  • RSA(Rivest-Shamir-Adleman)是一种非对称加密算法。在 Go 语言中,crypto/rsa包提供了对 RSA 算法的支持。
  • 以下是一个生成 RSA 密钥对并进行加密和解密的示例:
package mainimport ("crypto/rand""crypto/rsa""crypto/x509""encoding/pem""fmt"
)func main() {// 生成 RSA 私钥privateKey, err := rsa.GenerateKey(rand.Reader, 2048)if err!= nil {fmt.Println("Error generating private key:", err)return}// 将私钥转换为 PEM 格式privateKeyPEM := &pem.Block{Type:  "RSA PRIVATE KEY",Bytes: x509.MarshalPKCS1PrivateKey(privateKey),}// 保存私钥到文件(可省略)privateKeyFile, err := os.Create("private.pem")if err!= nil {fmt.Println("Error creating private key file:", err)return}pem.Encode(privateKeyFile, privateKeyPEM)privateKeyFile.Close()// 获取公钥publicKey := privateKey.PublicKey// 将公钥转换为 PEM 格式publicKeyPEM := &pem.Block{Type:  "RSA PUBLIC KEY",Bytes: x509.MarshalPKCS1PublicKey(&publicKey),}// 保存公钥到文件(可省略)publicKeyFile, err := os.Create("public.pem")if err!= nil {fmt.Println("Error creating public key file:", err)return}pem.Encode(publicKeyFile, publicKeyPEM)publicKeyFile.Close()// 要加密的数据data := []byte("This is a test string for RSA.")// 使用公钥加密encryptedData, err := rsa.EncryptPKCS1v15(rand.Reader, &publicKey, data)if err!= nil {fmt.Println("Error encrypting data:", err)return}fmt.Printf("Encrypted data: %x\n", encryptedData)// 使用私钥解密decryptedData, err := rsa.DecryptPKCS1v15(rand.Reader, privateKey, encryptedData)if err!= nil {fmt.Println("Error decrypting data:", err)return}fmt.Printf("Decrypted data: %s\n", decryptedData)
}

在上述代码中,首先生成了 RSA 密钥对,然后将密钥转换为 PEM 格式并可以选择保存到文件中。接着使用公钥对数据进行加密,再使用私钥进行解密。

Base64 实现

  • Base64 是一种用于将二进制数据编码为 ASCII 字符串的编码方式。在 Go 语言中,encoding/base64包提供了对 Base64 编码和解码的功能。
  • 源码可直接使用
  • 以下是一个简单的示例:
package mainimport ("encoding/base64""fmt"
)func main() {data := []byte("This is a test string for Base64.")encodedData := base64.StdEncoding.EncodeToString(data)fmt.Printf("Encoded data: %s\n", encodedData)decodedData, err := base64.StdEncoding.DecodeString(encodedData)if err!= nil {fmt.Println("Error decoding data:", err)return}fmt.Printf("Decoded data: %s\n", decodedData)
}

在上述代码中,使用base64.StdEncoding.EncodeToString方法将数据进行 Base64 编码,使用DecodeString方法进行解码。

总结

通过以上内容,我们详细介绍了在 Go 语言中实现 MD5 哈希、RSA 加密以及 Base64 编码的方法,并给出了相应的代码示例。这些加密和编码技术在实际开发中具有广泛的应用,开发者可以根据具体需求灵活运用。
以上文章内容可以根据你的实际需求进行调整,希望对你有所帮助。

http://www.lryc.cn/news/445274.html

相关文章:

  • 2024海外电商数据分析之印度篇
  • JavaWeb纯小白笔记02:Tomcat的使用:发布项目的三种方式、配置虚拟主机、配置用户名和密码
  • 为什么数据需要 QA 流程
  • Spring Boot 学习之路 -- 基础认知
  • JavaScript --json格式字符串和对象的转化
  • LabVIEW提高开发效率技巧----采用并行任务提高性能
  • 裸土检测算法实际应用、裸土覆盖检测算法、裸土检测算法
  • 深入剖析链表反转:多语言实现与高级语法特性20240924
  • 【数据结构初阶】链式二叉树接口实现超详解
  • 力扣189 轮转数组 Java版本
  • RMAN异机恢复数据库记录
  • JVM 调优篇7 调优案例4- 线程溢出
  • C++类与对象(三)
  • 云栖实录 | 阿里云 OpenLake 解决方案重磅发布:多模态数据统一纳管、引擎平权联合计算、数据共享统一读写
  • 《线性代数》学渣笔记
  • 对网页聊天项目进行性能测试, 使用JMeter对于基于WebSocket开发的webChat项目的聊天功能进行测试
  • 《程序猿之设计模式实战 · 适配器模式》
  • Elasticsearch案例
  • SpringBoot 项目如何使用 pageHelper 做分页处理 (含两种依赖方式)
  • GSR关键词排名系统是针对谷歌seo的吗?
  • HarmonyOS Next开发----使用XComponent自定义绘制
  • 什么是电商云手机?可以用来干什么?
  • Python 2 和 Python 3的差异
  • Leetcode 第 139 场双周赛题解
  • spring 注解 - @NotEmpty - 确保被注解的字段不为空,而且也不是空白(即不是空字符串、不是只包含空格的字符串)
  • 深入理解华为仓颉语言的数值类型
  • WPF 的TreeView的TreeViewItem下动态生成TreeViewItem
  • 使用Go语言的互斥锁(Mutex)解决并发问题
  • Android平台Unity3D下如何同时播放多路RTMP|RTSP流?
  • 网络:TCP协议-报头字段