侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

在go语言中生成DSA私钥、公钥和PEM文件实例示例代码

Go  /  管理员 发布于 2年前   493

在上一篇关于如何保存私钥和公钥文件的教程基础上,学习如何生成DSA私钥、公钥和PEM文件。

https://www.zongscan.com/demo333/96009.html

执行下面的代码将生成3个文件,并将DSA相关数据输出到屏幕上


示例代码:

 package main
 import (
         "crypto/dsa"
         "crypto/md5"
         "crypto/rand"
         "encoding/asn1"
         "encoding/gob"
         "encoding/pem"
         "fmt"
         "hash"
         "io"
         "math/big"
         "os"
 )
 func main() {
         params := new(dsa.Parameters)
         // see http://golang.org/pkg/crypto/dsa/#ParameterSizes
         if err := dsa.GenerateParameters(params, rand.Reader, dsa.L1024N160); err != nil {
                 fmt.Println(err)
                 os.Exit(1)
         }
         privatekey := new(dsa.PrivateKey)
         privatekey.PublicKey.Parameters = *params
         dsa.GenerateKey(privatekey, rand.Reader) // this generates a public & private key pair
         var pubkey dsa.PublicKey
         pubkey = privatekey.PublicKey
         fmt.Println("Private Key :")
         fmt.Printf("%x \n", privatekey)
         fmt.Println("Public Key :")
         fmt.Printf("%x \n", pubkey)
         // save private and public key separately
         privatekeyfile, err := os.Create("DSAprivate.key")
         if err != nil {
                 fmt.Println(err)
                 os.Exit(1)
         }
         privatekeyencoder := gob.NewEncoder(privatekeyfile)
         privatekeyencoder.Encode(privatekey)
         privatekeyfile.Close()
         publickeyfile, err := os.Create("DSApublic.key")
         if err != nil {
                 fmt.Println(err)
                 os.Exit(1)
         }
         publickeyencoder := gob.NewEncoder(publickeyfile)
         publickeyencoder.Encode(pubkey)
         publickeyfile.Close()
         // save DSA public key to PEM encoded file
         pemfile, err := os.Create("DSApublickey.pem")
         if err != nil {
                 fmt.Println(err)
                 os.Exit(1)
         }
         // http://golang.org/pkg/encoding/pem/#Block
         // The decoded bytes of the contents. Typically a DER encoded ASN.1 structure.
         asn1Bytes, err := asn1.Marshal(pubkey)
         if err != nil {
                 fmt.Println(err)
                 os.Exit(1)
         }
         var pemkey = &pem.Block{
                 Type:  "PUBLIC KEY",
                 Bytes: asn1Bytes}
         err = pem.Encode(pemfile, pemkey)
         if err != nil {
                 fmt.Println(err)
                 os.Exit(1)
         }
         pemfile.Close()
         // ------------------------------
         // below here is bonus
         // Sign
         var h hash.Hash
         h = md5.New()
         r := big.NewInt(0)
         s := big.NewInt(0)
         io.WriteString(h, "This is the message to be signed and verified!")
         signhash := h.Sum(nil)
         r, s, err = dsa.Sign(rand.Reader, privatekey, signhash)
         if err != nil {
                 fmt.Println(err)
         }
         signature := r.Bytes()
         signature = append(signature, s.Bytes()...)
         fmt.Printf("Signature : %x\n", signature)
         // Verify
         verifystatus := dsa.Verify(&pubkey, signhash, r, s)
         fmt.Println(verifystatus) // should be true
         // we add additional data to change the signhash
         io.WriteString(h, "This message is NOT to be signed and verified!")
         signhash = h.Sum(nil)
         verifystatus = dsa.Verify(&pubkey, signhash, r, s)
         fmt.Println(verifystatus) // should be false
 }

PEM文件的输出:

 -----BEGIN PUBLIC KEY-----
 MIIBpjCCAR4CgYEA1cKOQUxDRqRHt8yR5vfEunyFB6pblE9W/fyaJHgpWMzkvSHX
 mZvDhN5huH3OM0vC5Y8UbfyplET3x/HfXUbDUgk4bT0CrWHmrANMjdPgStZF+nWP
 Yfa6QUyVbRZumI6iBaCH63107scE8tygmwSW3n1jYLoSv6VItDEiBIdoK18CFQC6
 q4LlyX4YZblOKYw8CFyPShtcAwKBgHAN+TWyUhqCVZmwUdH3pJelT4iT9vkg4NLn
 1h+qJJ1XU+OILAAeuO3z8vLMIpeFaDL5CvUb7S0vSqx2EFj/G67aH9nL0MwtXjn7
 SCy4EOF5dlHbafXj4PnPrvo3/Mr+3a2i5lenlhyyb1Vnd/0VcrGwWleAfDBuGdYu
 S5WCYAj3AoGBAMDl+N8XI3LBi/LUQbi9di0tvA/2t+c6UZTT/CDTkyDucFNEeqWI
 sdOsf+hIbI8pEy81y6yBc50wcf1uqcZxovKsZbuv8vS3NBPaeOT7l6ltYdNxzg/7
 QFfi3qQXXLONWYXW4diWaZu6Kq5XvhfWkoUdGzGiD84UVW7jmeDy/Px6
 -----END PUBLIC KEY-----

参考文章:

https://www.socketloop.com/tutorials/golang-example-for-dsa-functions
https://www.socketloop.com/tutorials/golang-saving-private-and-public-key-to-files

  • 上一条:
    在go语言中DSA(数字签名算法)包函数的示例代码
    下一条:
    在PHP 8.0和8.1版本中的一些特性浅析示例及对旧版的对比
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 近期文章
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2017-09
    • 2020-03
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-12
    • 2021-01
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-03
    • 2022-04
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    • 2024-05
    • 2024-06
    • 2024-07
    • 2024-08
    • 2024-11
    • 2025-02
    • 2025-04
    • 2025-05
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客