区块链应用:椭圆曲线数字签名算法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
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,794评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,050评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,587评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,861评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,901评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,898评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,832评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,617评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,077评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,349评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,483评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,199评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,824评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,442评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,632评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,474评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,393评论 2 352

推荐阅读更多精彩内容