go区块链培训怎么样?深度讲解椭圆曲线加密算法ECC和椭圆曲线数字签名算法ECDSA

这篇博客介绍了如何在Go中实现椭圆曲线加密算法ECC和椭圆曲线数字签名算法ECDSA。通过示例代码展示了如何生成数字签名、验证签名的过程,并提供了相关函数的详细解释。
摘要由CSDN通过智能技术生成

 区块链培训怎么样?关键还是看其课程质量,下面是我写的一系列课程讲解,大家可以先学习一下!感兴趣的还可以找我要视频哈!

8.1.1 ECC数字签名(ECDSA)核心代码

下面通过一个案例验证数字签名,如例所示。

例1-1 ECDSA

1 package main

2 import (

3  "crypto/ecdsa"

4  "crypto/elliptic"

5  "crypto/rand"

6  "crypto/sha256"

7  "encoding/hex"

8  "fmt"

9  "log"

10  "math/big"

11 )

12 func main() {

13  fmt.Println("生成签名-------------------------------")

14  privKey, pubKey := NewKeyPair()

15  msg := sha256.Sum256([]byte("hello world"))

16  r, s, _ := ecdsa.Sign(rand.Reader, &privKey, msg[:])

17  strSigR := fmt.Sprintf("%x", r)

18  strSigS := fmt.Sprintf("%x", s)

19  fmt.Println("r、s的10进制分别为:", r, s)

20  fmt.Printl

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值