Golang 椭圆加密算法实现

栏目: Go · 发布时间: 5年前

内容简介:椭圆曲线密码学(英语:Elliptic Curve Cryptography,缩写:ECC)是一种基于椭圆曲线数学的公开密钥加密算法。椭圆曲线在密码学中的使用是在1985年由Neal Koblitz和Victor Miller分别独立提出的。ECC的主要优势是在某些情况下它比其他的算法(比如RSA加密算法)使用更小的密钥并提供相当的或更高等级的安全。ECC的另一个优势是可以定义群之间的双线性映射,基于Weil对或是Tate对;双线性映射已经在密码学中发现了大量的应用,例如基于身份的加密。不过一个缺点是加密和

什么是椭圆加密算法

椭圆曲线密码学(英语:Elliptic Curve Cryptography,缩写:ECC)是一种基于椭圆曲线数学的公开密钥加密算法。椭圆曲线在密码学中的使用是在1985年由Neal Koblitz和Victor Miller分别独立提出的。

ECC的主要优势是在某些情况下它比其他的算法(比如RSA加密算法)使用更小的密钥并提供相当的或更高等级的安全。ECC的另一个优势是可以定义群之间的双线性映射,基于Weil对或是Tate对;双线性映射已经在密码学中发现了大量的应用,例如基于身份的加密。

不过一个缺点是加密和解密操作的实现比其他机制花费的时间长。

代码实现

var Aprivate, Apublic [32]byte
    //产生随机数
    if _, err := io.ReadFull(rand.Reader, Aprivate[:]); err != nil {
        os.Exit(0)
    }
    curve25519.ScalarBaseMult(&Apublic, &Aprivate)
    fmt.Println("A私钥", base64.StdEncoding.EncodeToString(Aprivate[:]))
    fmt.Println("A公钥", base64.StdEncoding.EncodeToString(Apublic[:])) //作为椭圆起点

    var Bprivate, Bpublic [32]byte
    //产生随机数
    if _, err := io.ReadFull(rand.Reader, Bprivate[:]); err != nil {
        os.Exit(0)
    }
    curve25519.ScalarBaseMult(&Bpublic, &Bprivate)
    fmt.Println("B私钥",  base64.StdEncoding.EncodeToString(Bprivate[:]))
    fmt.Println("B公钥",  base64.StdEncoding.EncodeToString(Bpublic[:])) //作为椭圆起点

    var Akey, Bkey [32]byte

    //A的私钥加上B的公钥计算A的key
    curve25519.ScalarMult(&Akey, &Aprivate, &Bpublic)

    //B的私钥加上A的公钥计算B的key
    curve25519.ScalarMult(&Bkey, &Bprivate, &Apublic)

    fmt.Println("A交互的KEY",  base64.StdEncoding.EncodeToString(Akey[:]))
    fmt.Println("B交互的KEY",  base64.StdEncoding.EncodeToString(Bkey[:]))

输出值

A私钥 7i3ADsF/e47UHxdZW1dP5R+OO4wZjK8lHIvW0Y65CZY=
A公钥 DTyAub5yB+ZpPJl0D6jcL7RPu0elDBcWxlBkP9DaCFY=
B私钥 dnkaHZ8BouXCuZTcjDwAmrsZhGd8WMrLhsYsisdd1dQ=
B公钥 ob63R56KbVqQghFDfB6qMX0/8kKYy4ZkIKacAaedw3o=
A交互的KEY yn6TpBZprWR+pr++lFJFOEawNJ/gp2grLvYLBS8pjDY=
B交互的KEY yn6TpBZprWR+pr++lFJFOEawNJ/gp2grLvYLBS8pjDY=

完整演示代码 点击这里

联系 QQ: 3355168235


以上所述就是小编给大家介绍的《Golang 椭圆加密算法实现》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

风口上的汽车新商业

风口上的汽车新商业

郭桂山 / 人民邮电出版社 / 59

本书从互联网+汽车趋势解析、汽车电商困局突围策略、汽车后市场溃败求解等三个篇章详细阐述了作者的观察与思考,当然更多的还是作者在汽车电商行业的实践中得出的解决诸多问题的战略策略,作者站在行业之巅既有战略策略的解决方案,同时也有战术上的实施细则,更有实操案例解析与行业大咖访谈等不可多得的干货。当然,作者一向追崇的宗旨是,书中观点的对错不是最重要的,重在与行业同仁探讨,以书会友,希望作者的这块破砖头,能......一起来看看 《风口上的汽车新商业》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

在线进制转换器
在线进制转换器

各进制数互转换器

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试