首页 > 编程语言 >区块链应用:椭圆曲线数字签名算法ECDSA

区块链应用:椭圆曲线数字签名算法ECDSA

时间:2023-05-27 18:11:06浏览次数:45  
标签:椭圆 ECC 数字签名 fmt 曲线 私钥 区块 ECDSA

1 椭圆曲线密码学

  • 椭圆曲线密码学(Elliptic Curve Cryptography,缩写ECC),是基于椭圆曲线数学理论实现的一种非对称加密算法。椭圆曲线在密码学中的使用是在1985年有Neal Koblitz和Victor Miller分别提出来的。

  • 标准的椭圆曲线
    椭圆曲线

  • 椭圆曲线加密

  • 考虑K=kG,其中K、G为椭圆曲线Ep(a,b)上的点,n为G的阶(n G = O∞ ),k为小于n的整数。则给定k和G,根据加法法则,计算K很容易但反过来,给定K和G,求k就非常困难。因为实际使用中的ECC原则上把p取得相当大,n也相当大,要把n个解点逐一算出来列成上表是不可能的。这就是椭圆曲线加密算法的数学依据 。

2 应用场景

  • 比特币使用椭圆曲线算法生产公钥和私钥,选择的是secp256k1曲线。与RSA(Ron Rivest,Adi Shamir,Len Adleman三位天才的名字)一样,ECC(椭圆曲线加密算法)也属于公开秘钥算法。
  • 椭圆曲线数字签名算法,因其高安全性,目前已广发应用在比特币、以太坊、超级账本等区块链项目中。

3 ECC与RSA算法的优势对⽐

与经典的RSA、DSA等公钥密码体制相⽐,椭圆密码体制有以下优点:

  • 安全性能更⾼(ECC可以使⽤更短的密钥):
    160位ECC加密算法的安全强度相当于1024位RSA加密;
    210位ECC加密算法的安全强度相当于2048位RSA加密。
  • 处理速度快:计算量⼩,处理速度快 在私钥的处理速度上(解密和签名),ECC远 ⽐RSA、DSA快得多。
  • 存储空间占⽤⼩: ECC的密钥尺⼨和系统参数与RSA、DSA相⽐要⼩得多, 所以占⽤的存储空间⼩得多。
  • 带宽要求低使得ECC具有⼴泛的应⽤前景。ECC的这些特点使它必将取代RSA,成为通⽤的公钥加密算法。

4 数字签名与验证过程

  • 只有转账人才能生成一段防伪造的字符串。通过验证该字符串,一方面证明改交易是转出方本人发起的,另一方面证明交易信息在传输过程中没有被更改。
  • 数字签名由:数字摘要和非对称加密技术组成。数字摘要把交易信息hash成固定长度的字符串;再用私钥对hash后的交易信息进行加密成数字签名。
  • 交易中,需要将完整的交易信息和数字签名一起广播给矿工。矿工节点用转账人公钥对签名验证,验证成功说明改交易确实是转账人发起;旷工节点将交易信息进行hash后与签名的交易信息摘要进行比对,如果一致则说明交易信息在传输过程中没有被篡改。
    数字签名验证过程

5 代码验证

  • ⽣成私钥和公钥,⽣成的私钥为结构体ecdsa.PrivateKey的指针
func NewKeyPair() (ecdsa.PrivateKey, []byte) {
	// 生产secp256椭圆曲线
	curve := elliptic.P256()

	// 产生一个结构体指针,结构体类型ecdsa.PrivateKey
	private, err := ecdsa.GenerateKey(curve, rand.Reader)

	if err != nil {
		log.Panic(err)
	}

	fmt.Println("私钥:%x\n", private)
	fmt.Println("私钥X:%x\n", private.X.Bytes())
	fmt.Println("私钥Y:%x\n", private.Y.Bytes())
	fmt.Println("私钥D:%x\n", private.D.Bytes())

	// x坐标与y坐标拼接在一起生成公钥
	publicKey := append(private.X.Bytes(), private.Y.Bytes()...)

	fmt.Println("公钥:%x\n", publicKey)

	return *private, publicKey
}
  • ⽣成签名的DER格式
func MakeSignatureDerString(r, s string) string {
	// 获取R和S的⻓度
	lenSigR := len(r) / 2
	lenSigS := len(s) / 2
	// 计算DER序列的总⻓度
	lenSequence := lenSigR + lenSigS + 4
	// 将10进制⻓度转16进制字符串
	strLenSigR := DecimalToHex(int64(lenSigR))
	strLenSigS := DecimalToHex(int64(lenSigS))
	strLenSequence := DecimalToHex(int64(lenSequence))
	// 拼凑DER编码
	derString := "30" + strLenSequence
	derString = derString + "02" + strLenSigR + r
	derString = derString + "02" + strLenSigS + s
	derString = derString + "01"
	return derString
}
  • 生成签名
   privateKey, publicKey := NewKeyPair()

	msg := sha256.Sum256([]byte("ecc数组签名"))

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

	strSigR := fmt.Sprintf("%x", r) // r.MarshalText()
	strSigS := fmt.Sprintf("%x", s) // s.MarshalText()

	fmt.Printf("r、s的10进制:%#v, %#v\n", r, s)
	fmt.Println("r、s的16进制:", strSigR, strSigS)

	//r和s拼接在⼀起,形成数字签名的der格式
	signatureDer := MakeSignatureDerString(strSigR, strSigS)
	//打印数字签名的16进制显示
	fmt.Println("数字签名DER格式为:", signatureDer)
  • 验证签名
func VerifySig(pubKey, message []byte, r, s *big.Int) bool {
	curve := elliptic.P256()
	//公钥的⻓度
	keyLen := len(pubKey)
	//前⼀半为x轴坐标,后⼀半为y轴坐标
	x := big.Int{}
	y := big.Int{}
	x.SetBytes(pubKey[:(keyLen / 2)])
	y.SetBytes(pubKey[(keyLen / 2):])
	rawPubKey := ecdsa.PublicKey{curve, &x, &y}
	//根据交易哈希、公钥、数字签名验证成功:
	// ecdsa.Verify func Verify(pub *PublicKey, hash[] byte, r * big.Int, s * big.Int) bool
	res := ecdsa.Verify(&rawPubKey, message, r, s)
	return res
}

标签:椭圆,ECC,数字签名,fmt,曲线,私钥,区块,ECDSA
From: https://www.cnblogs.com/wolf-song/p/17437112.html

相关文章

  • 区块链的Token机制如何理解?
    区块链的Token机制如何理解?为了更好的理解区块链和Token的关系,今天专门基于互联网中的内容,做了下筛选过滤,从而可以让大家更好的理解,对于Token,如果是从事过开发的同学来说,比如容易理解为用户标识等含义,从而会走一定的弯路。Token机制是区块链技术中的重要概念之一,它指的是在区块......
  • 区块链实验-构建Merkle Tree
      主要内容:1.掌握MerkleTree的基本原理。2.编程实现MerkelTree的构建和数据完整性验证。实验条件:Win系统、Python实验内容:根据上图原理实现如下两个函数:#构建MerkleTreedefBuildTree(data):#验证数据完整性defValidate(hash,data):实现思......
  • web3 产品介绍 etherscan 区块链浏览器 将抽象的数据和理论可视化,小白也能看懂区块链
    Etherscan是一个广泛使用的以太坊区块链浏览器和分析平台,它为用户提供了全面的区块链数据查询和交易分析功能。在本文中,我们将介绍Etherscan的主要特点和功能,以及如何使用它来浏览以太坊区块链。一、Etherscan的特点区块链浏览器:Etherscan提供了完整的以太坊区块链浏览器,用户......
  • 区块链技术在元宇宙中的作用
    元宇宙的概念经过了互联网的宣传和普及,大家都有了很直观的认识,甚至我们在平时的生活中已经体验过类似元宇宙的游戏。从定义上看,元宇宙(Metaverse),是人类运用数字技术构建的,由现实世界映射或超越现实世界,可与现实世界交互的虚拟世界,具备新型社会体系的数字生活空间。区块链对元宇宙最......
  • 区块链基础知识
    nonce规则为了防止交易重播,ETH(ETC)节点要求每笔交易必须有一个nonce数值。每一个账户从同一个节点发起交易时,这个nonce值从0开始计数,发送一笔nonce对应加1。当前面的nonce处理完成之后才会处理后面的nonce。注意这里的前提条件是相同的地址在相同的节点发送交易。以下是nonce使用......
  • 区块链技术与元宇宙
    未来的元宇宙项目将会往两种流派发展,第一,强调感知技术的应用,以炫酷的特技效果作为卖点。第二,强调经济模型的变化,践行Web3.0的理念,将项目收益和治理权更大程度还给用户。区块链技术是元宇宙、web3.0应用落地的基础、底层技术。然而,区块链的落地和应用绝非上述二者。区块链能够为元宇......
  • 当前区块链研究领域的前沿技术和研究方向
     本文分享自天翼云开发者社区《当前区块链研究领域的前沿技术和研究方向》作者:施****庆 区块链在过去几年中引起了巨大的关注,这得益于它们的分散性、透明性、匿名性和不可篡改性,这些特点使得区块链技术可以应用于许多领域。目前,区块链技术已被应用于金融、医疗、供应链等多......
  • 21 19 | 许可型区块链重构:无中心的区块链怎么做到可信任?
    你好,我是李智慧。过去几年,区块链正变成一个日渐热门的词汇,除了广为人知的比特币等数字货币,基于区块链的分布式账本和智能合约技术也越来越受到企业的重视,越来越多的企业也开始使用区块链技术进行跨企业的业务协作。2018年6月25日,香港支付宝和菲律宾钱包Gcash利用区块链技......
  • 区块链原理与技术
    访问【WRITE-BUG数字空间】_[内附完整源码和文档]一、项目背景1.1供应链+金融场景供应链(SupplyChain)是指生产及流通过程中,涉及将产品或服务提供给最终用户活动的上游与下游企业所形成的网链结构。金融机构对不同企业的的信用评级不同,核心企业有很大的风险承担的能力,故信用评级会......
  • 一文带你了解区块链中15种共识算法
    所有主要的区块链共识算法解释区块链技术席卷全球,提供了一种去中心化且安全的信息存储和传输方式。它还彻底改变了交易的执行方式,随之而来的是广泛的共识算法。在这里,共识算法在确保区块链网络的完整性方面发挥着关键作用。在本文中,我们将探讨所有主要类型的区块链共识算法、它们......