美文网首页go语言
golang中crypto/elliptic包

golang中crypto/elliptic包

作者: ljh123 | 来源:发表于2018-12-09 13:37 被阅读0次

elliptic包实现了几条覆盖素数有限域的标准椭圆曲线。

type Curve

type Curve interface {
    // Params返回椭圆曲线的参数
    Params() *CurveParams
    // IsOnCurve判断一个点是否在椭圆曲线上
    IsOnCurve(x, y *big.Int) bool
    // 返回点(x1,y1)和点(x2,y2)相加的结果
    Add(x1, y1, x2, y2 *big.Int) (x, y *big.Int)
    // 返回2*(x,y),即(x,y)+(x,y)
    Double(x1, y1 *big.Int) (x, y *big.Int)
    // k是一个大端在前格式的数字,返回k*(Bx,By)
    ScalarMult(x1, y1 *big.Int, k []byte) (x, y *big.Int)
    // k是一个大端在前格式的数字,返回k*G,G是本椭圆曲线的基点
    ScalarBaseMult(k []byte) (x, y *big.Int)
}

Curve代表一个短格式的Weierstrass椭圆曲线,其中a=-3。
Weierstrass椭圆曲线的格式:y2 = x3 + a*x + b

这个包实现的函数:
1)func P224() Curve
返回一个实现了P-224的曲线
2)func P256() Curve
返回一个实现了P-256的曲线
3)func P384() Curve
返回一个实现了P-284的曲线
4)func P521() Curve
返回一个实现了P-512的曲线

type CurveParams

type CurveParams struct {
    P       *big.Int // 决定有限域的p的值(必须是素数)
    N       *big.Int // 基点的阶(必须是素数)
    B       *big.Int // 曲线公式的常量(B!=2)
    Gx, Gy  *big.Int // 基点的坐标
    BitSize int      // 决定有限域的p的字位数
}

CurveParams包含一个椭圆曲线的所有参数,也可提供一般的、非常数时间实现的椭圆曲线。

这个类(结构体)实现的方法

func (curve *CurveParams) Params() *CurveParams
func (curve *CurveParams) IsOnCurve(x, y *big,Int) bool
func (curve *CurveParams) Add(x1, y1, x2, y2 *big.Int) (*big,Int, *big,Int)
func (curve *CurveParams) Double(x1, y1 *big.Int) (*big.Int, *big,Int)
func (curve *CurveParams) ScalarMult(Bx, By *big.Int, k []byte) (*big.Int, *big.Int)
func (curve *CurveParams) ScalarBaseMult(k []byte) (*big.Int, *big.Int)
func GenerateKey(curve Curve, rand io.Reader) (priv []byte, x, y *big.Int, err error)
GenerateKey返回一个公钥/私钥对。priv是私钥,而(x,y)是公钥。密钥对是通过提供的随机数读取器来生成的,该io.Reader接口必须返回随机数据
func Marshal(curve Curve, x, y *big.Int) []byte
Marshal将一个点编码为ANSI X9.62指定的格式。
func Unmarshal(curve Curve, data []byte) (x, y *big.Int)
将一个Marshal编码后的点还原;如果出错,x会被设为nil。

相关文章

  • golang中crypto/elliptic包

    elliptic包实现了几条覆盖素数有限域的标准椭圆曲线。 type Curve Curve代表一个短格式的Wei...

  • Golang标准库——crypto(1)

    aes cipher des dsa ecdsa elliptic crypto crypto包搜集了常用的密码(...

  • Go语言:MD5加密

    Golang的加密库都放在crypto目录下,其中MD5库在crypto/md5包中,该包主要提供了New()和S...

  • golang中crypto/rand包

    rand包实现了用于加解密的更安全的随机数生成器。 变量:var Reader io.ReaderReader是一...

  • golang中crypto/aes包

    aes是对称加密算法,这篇博客只介绍怎么使用golang中怎么调用标准库已封装的算法实现,如果是要学习aes算法实...

  • golang中crypto/dsa包

    DSA是用于数字签名的一种算法,私钥进行签名,公钥进行验证。关于更多dsa内容以及dsa实现移步www.baidu...

  • golang中crypto/ecdsa包

    ECDSA和DSA一样也是用于数字签名,同样在go使用上也很类似,RSA、DSA和ECDSA三者的签名的区别,可以...

  • golang中crypto/hmac包

    hmac包实现了U.S.Federal Infomation Processing Standards Publi...

  • golang中crypto/cipher包

    这个包实现了标准的块加密模式。我们可以看一下cipher.Block Go中定义了一个接口BlockMode代表各...

  • golang中crypto/des包

    des是对称加密算法,更多关于des算法以及des算法实现移步百度。 说明,内容转载至:http://blog.s...

网友评论

    本文标题:golang中crypto/elliptic包

    本文链接:https://www.haomeiwen.com/subject/poghhqtx.html