Go-ecc数字签名详解与代码_ecc算法签名和验签原理代码,2024年最新最新BAT大厂面试者整理的Golang面试题目模板

37 阅读2分钟

使用私钥对任意长度的hash值(必须是较大信息的hash结果)进行签名,返回签名结果(一对大整数)。私钥的安全性取决于密码读取器的熵度(随机程度)。



func Verify(pub *PublicKey, hash []byte, r, s *big.Int) bool


使用公钥验证hash值和两个大整数r、s构成的签名,并返回签名是否合法。


### 签名


* 使用sha256.Sum356获取摘要
* 使用ecdsa.Sign进行签名
* 对r s进行序列化


// Ecc 签名  
 // plainText 明文  
 // priPath 私钥路径  
 // 返回 签名结果



func ECCSign(plainText []byte,priPath string) ([]byte,[]byte,error) { // get pem.Block block,err := util.GetKey(priPath) if err != nil{ _, file, line, _ := runtime.Caller(0) return nil,nil,util.Error(file,line+1,err.Error()) } // x509 priKey,err := x509.ParseECPrivateKey(block.Bytes) if err != nil{ _, file, line, _ := runtime.Caller(0) return nil,nil,util.Error(file,line+1,err.Error()) } hashText := sha256.Sum256(plainText) // sign r,s,err := ecdsa.Sign(rand.Reader,priKey,hashText[:]) if err != nil{ _, file, line, _ := runtime.Caller(0) return nil,nil,util.Error(file,line+1,err.Error()) } // marshal rText,err := r.MarshalText() if err != nil{ _, file, line, _ := runtime.Caller(0) return nil,nil,util.Error(file,line+1,err.Error()) } sText,err := s.MarshalText() if err != nil{ _, file, line, _ := runtime.Caller(0) return nil,nil,util.Error(file,line+1,err.Error()) } return rText,sText,nil }


### 验证签名


* -使用sha256.Sum356获取摘要
* 对r s进行反序列化
* 使用ecdsa.Verify进行签名认证


// ECC 签名验证  
 // plainText 明文  
 // rText,sText 签名  
 // pubPath公钥文件路径  
 // 返回 验签结果 错误



func ECCVerify(plainText,rText,sText []byte,pubPath string) (bool,error) { // get pem.Block block,err := util.GetKey(pubPath) if err != nil{ _, file, line, _ := runtime.Caller(0) return false,util.Error(file,line+1,err.Error()) } // x509 pubInter,err := x509.ParsePKIXPublicKey(block.Bytes) if err != nil{ _, file, line, _ := runtime.Caller(0) return false,util.Error(file,line+1,err.Error()) } // assert pubKey := pubInter.(*ecdsa.PublicKey) hashText := sha256.Sum256(plainText) var r,s big.Int // unmarshal err = r.UnmarshalText(rText) if err != nil{ _, file, line, _ := runtime.Caller(0) return false,util.Error(file,line+1,err.Error()) } err = s.UnmarshalText(sText) if err != nil{ _, file, line, _ := runtime.Caller(0) return false,util.Error(file,line+1,err.Error()) } // verify ok := ecdsa.Verify(pubKey,hashText[:],&r,&s) return ok,nil }


### 测试代码



plainText := []byte("张华考上了北京大学;李萍进了中等技术学校;我在百货公司当售货员:我们都有美好的未来")
rText,sText, \_ := ECCSign(plainText,"./eccPrivate.pem")
ok, err := ECCVerify(plainText,rText,sText,"./eccPublic.pem")
fmt.Println(err)
fmt.Printf("验证成功? %t",ok)

## 截图



![img](https://p3-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/c8e1009d64604deeae653ebf32f63f33~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5py65Zmo5a2m5Lmg5LmL5b-DQUk=:q75.awebp?rk3s=f64ab15b&x-expires=1771252464&x-signature=8YD6iNOMDkTZ3uiPX%2Fwg3wkMQ7U%3D)
![img](https://p3-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/5b29d385b838413487297408852f5a08~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5py65Zmo5a2m5Lmg5LmL5b-DQUk=:q75.awebp?rk3s=f64ab15b&x-expires=1771252464&x-signature=IY%2FmTLj5AhDPntwhXAlPwHzueUU%3D)
![img](https://p3-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/3e6878a83e704f0dae25fe4155a823f2~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg5py65Zmo5a2m5Lmg5LmL5b-DQUk=:q75.awebp?rk3s=f64ab15b&x-expires=1771252464&x-signature=3H0AEVK77efFhZ5u68FtYsxFxyU%3D)

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**

**[如果你需要这些资料,可以戳这里获取](https://gitee.com/vip204888)**