非常教程

Go参考手册

加密 | crypto

crypto/elliptic

  • import "crypto/elliptic"
  • 概述
  • 索引

概述

椭圆包实现了在素数域上的几个标准椭圆曲线。

索引

  • func GenerateKey(curve Curve, rand io.Reader) (priv []byte, x, y *big.Int, err error)
  • func Marshal(curve Curve, x, y *big.Int) []byte
  • func Unmarshal(curve Curve, data []byte) (x, y *big.Int)
  • type Curve
  • func P224() Curve
  • func P256() Curve
  • func P384() Curve
  • func P521() Curve
  • type CurveParams
  • 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) IsOnCurve(x, y *big.Int) bool
  • func (curve *CurveParams) Params() *CurveParams
  • func (curve *CurveParams) ScalarBaseMult(k []byte) (*big.Int, *big.Int)
  • func (curve *CurveParams) ScalarMult(Bx, By *big.Int, k []byte) (*big.Int, *big.Int)

包文件

elliptic.go p224.go p256_amd64.go

func GenerateKey(查看源代码)

func GenerateKey(curve Curve, rand io.Reader) (priv []byte, x, y *big.Int, err error)

GenerateKey 返回一个公钥/私钥对。私钥是使用给定的阅读器生成的,它必须返回随机数据。

func Marshal(查看源代码)

func Marshal(curve Curve, x, y *big.Int) []byte

Marshal 将点转换为 ANSI X9.62 的4.3.6节中指定的形式。

func Unmarshal(查看源代码)

func Unmarshal(curve Curve, data []byte) (x, y *big.Int)

Unmarshal将由Marshal序列化的点转换为x,y对。如果该点不在曲线上,这是一个错误。出错时,x =nil。

type Curve(查看源代码)

曲线代表a=-3的短型Weierstrass曲线。请参阅http://www.hyperelliptic.org/EFD/g1p/auto-shortw.html

type Curve interface {
        // Params返回曲线的参数。
        Params() *CurveParams
        // IsOnCurve报告给定的(x,y)是否在曲线上。
        IsOnCurve(x, y *big.Int) bool
        // Add返回(x1,y1)和(x2,y2)的和
        Add(x1, y1, x2, y2 *big.Int) (x, y *big.Int)
        // Double返回 2*(x,y)
        Double(x1, y1 *big.Int) (x, y *big.Int)
        // ScalarMult返回k*(Bx,By)其中k是大端形式(big-endian)的数字。
        ScalarMult(x1, y1 *big.Int, k []byte) (x, y *big.Int)
        // ScalarBaseMult返回 k*G, G是组的基点。
        // k是大端形式的整数。
        ScalarBaseMult(k []byte) (x, y *big.Int)
}

func P224(查看源代码)

func P224() Curve

P224返回一个实现P-224的曲线(参见FIPS 186-3,D.2.2节)。

密码操作使用恒定时间算法实现。

func P256(查看源代码)

func P256() Curve

P256 返回一个实现 P-256 的曲线(参见 FIPS 186-3,D.2.3节)

密码操作使用恒定时间算法实现。

func P384(查看源代码)

func P384() Curve

P384 返回一个实现 P-384 的曲线(参见 FIPS 186-3,D.2.4节)

加密操作不使用恒定时间算法。

func P521(查看源代码)

func P521() Curve

P521 返回一个实现 P-521 的曲线(参见 FIPS 186-3,D.2.5 节)

加密操作不使用恒定时间算法。

type CurveParams(查看源代码)

CurveParams 包含一个椭圆曲线的参数,并且还提供了一个通用的,非常量的 Curve 实现。

type CurveParams struct {
        P       *big.Int // 基础领域的顺序
        N       *big.Int // 基点的顺序
        B       *big.Int // 曲线方程的常数
        Gx, Gy  *big.Int // (x,y)的基点
        BitSize int      // 底层字段的大小
        Name    string   // 曲线的规范名称
}

func (*CurveParams) Add(查看源代码)

func (curve *CurveParams) Add(x1, y1, x2, y2 *big.Int) (*big.Int, *big.Int)

func (*CurveParams) Double(查看源代码)

func (curve *CurveParams) Double(x1, y1 *big.Int) (*big.Int, *big.Int)

func (*CurveParams) IsOnCurve(查看源代码)

func (curve *CurveParams) IsOnCurve(x, y *big.Int) bool

func (*CurveParams) Params(查看源代码)

func (curve *CurveParams) Params() *CurveParams

func (*CurveParams) ScalarBaseMult(查看源代码)

func (curve *CurveParams) ScalarBaseMult(k []byte) (*big.Int, *big.Int)

func (*CurveParams) ScalarMult(查看源代码)

func (curve *CurveParams) ScalarMult(Bx, By *big.Int, k []byte) (*big.Int, *big.Int)
Go

Go 是一种编译型语言,它结合了解释型语言的游刃有余,动态类型语言的开发效率,以及静态类型的安全性。它也打算成为现代的,支持网络与多核计算的语言。要满足这些目标,需要解决一些语言上的问题:一个富有表达能力但轻量级的类型系统,并发与垃圾回收机制,严格的依赖规范等等。这些无法通过库或工具解决好,因此Go也就应运而生了。

主页 https://golang.org/
源码 https://go.googlesource.com/go
发布版本 1.9.2

Go目录

1.档案 | archive
2.缓冲区 | bufio
3.内置 | builtin
4.字节 | bytes
5.压缩 | compress
6.容器 | container
7.上下文 | context
8.加密 | crypto
9.数据库 | database
10.调试 | debug
11.编码 | encoding
12.错误 | errors
13. expvar
14.flag
15. fmt
16. go
17.散列 | hash
18.html
19.图像 | image
20.索引 | index
21.io
22.日志 | log
23.数学 | math
24. math/big
25.math/bits
26.math/cmplx
27.math/rand
28.拟态 | mime
29.net
30.net/http
31. net/mail
32. net/rpc
33.net/smtp
34. net/textproto
35. net/url
36.os
37.路径 | path
38.插件 | plugin
39.反射 | reflect
40.正则表达式 | regexp
41.运行时 | runtime
42.排序算法 | sort
43.转换 | strconv
44.字符串 | strings
45.同步 | sync
46.系统调用 | syscall
47.测试 | testing
48.文本 | text
49.时间戳 | time
50.unicode
51.不安全性 | unsafe
52.Go 语言数据类型
53.Go 语言基础语法
54.Go 语言结构
55.Go 语言 select 语句
56.Go 语言 switch 语句
57.Go 语言 if 语句嵌套
58.Go 语言 if…else 语句
59.Go 语言 if 语句
60.Go 语言运算符
61.Go 语言常量
62.Go 语言函数闭包
63.Go 语言函数作为实参
64.Go 语言函数引用传递值
65.Go 语言函数值传递值
66.Go 语言函数
67.Go 语言 goto 语句
68.Go 语言 continue 语句
69.Go 语言 break 语句
70.Go 语言循环嵌套
71.Go 语言 for 循环
72.Go 语言结构体
73.Go 语言指针作为函数参数
74.Go 语言指向指针的指针
75.Go 语言指针数组
76.Go 语言指针
77.Go 语言向函数传递数组
78.Go 语言多维数组
79.Go 语言变量作用域
80.Go 语言函数方法
81.Go 错误处理
82.Go 语言接口
83.Go 语言类型转换
84.Go 语言递归函数
85.Go 语言Map(集合)
86.Go 语言范围(Range)
87.Go 语言切片(Slice)
88.Go 并发
89.Go fmt.Sprintf 格式化字符串