[发明专利]SM2数字签名生成算法的实现方法及装置有效
申请号: | 201310445395.1 | 申请日: | 2013-09-25 |
公开(公告)号: | CN103546288B | 公开(公告)日: | 2017-02-01 |
发明(设计)人: | 林璟锵;潘无穷;余幸杰;王琼霄;荆继武 | 申请(专利权)人: | 中国科学院数据与通信保护研究教育中心 |
主分类号: | H04L9/32 | 分类号: | H04L9/32;H04L9/30 |
代理公司: | 北京德琦知识产权代理有限公司11018 | 代理人: | 牛峥,王丽琴 |
地址: | 100093 *** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | sm2 数字签名 生成 算法 实现 方法 装置 | ||
1.一种SM2数字签名生成算法的实现方法,其特征在于,该方法包括:
将SM2数字签名生成算法中的计算椭圆曲线点步骤由图形处理器GPU预先计算,得到椭圆曲线点及对应的随机数,并存储在设置的存储器中;
将SM2数字签名生成算法中的对用户私钥增1求逆计算步骤由中央处理器CPU预先计算,得到用户私钥增1逆存储在设置的存储器中;
CPU根据SM2数字签名生成算法计算步骤对待签名消息顺序计算时,调用存储器存储的椭圆曲线点及对应的随机数,以及用户私钥增1逆,完成对待签名消息的数字签名。
2.如权利要求1所述的实现方法,其特征在于,所述SM2数字签名生成算法中的对用户私钥增1求逆计算的CPU线程与所述根据SM2数字签名生成算法计算步骤对待签名消息顺序计算的CPU线程相同或不同。
3.如权利要求1所述的实现方法,其特征在于,所述将SM2数字签名生成算法中的对用户私钥增1求逆计算步骤在CPU预先计算为:
对于预先存储了用户私钥的签名请求,在接收SM2数字签名生成请求之前,预先进行用户私钥增1求逆计算,用户私钥表示为dA,用户私钥增1逆表示为(1+dA)-1mod n,其中n为椭圆曲线基点G的阶。
4.如权利要求1所述的实现方法,其特征在于,所述将SM2数字签名生成算法中的对用户私钥增1求逆计算步骤在CPU预先计算为:
对于未预先存储用户私钥的签名请求,在CPU接收到SM2数字签名生成请求之后,CPU根据SM2数字签名生成算法计算步骤对待签名消息顺序计算之前,获取到用户私钥进行增1求逆计算;
所述进行增1求逆计算的CPU线程与根据SM2数字签名生成算法计算步骤对待签名消息顺序计算的CPU线程不同。
5.如权利要求4所述的实现方法,其特征在于,所述获取到用户私钥进行增1求逆计算为:
设定同时增1求逆计算的用户私钥门限数或者设定间隔时刻,当到达同时增1求逆计算的用户私钥门限数或者设定的间隔时刻时,将所获取的多个不同用户私钥同时进行增1求逆操作后得到的不同用户私钥的增1逆。
6.如权利要求5所述的实现方法,其特征在于,所述将所获取的多个不同用户私钥同时进行增1求逆操作后得到的不同用户私钥增1逆为:
计算d1=1+dA1,d2=1+dA2,…,di=1+dAi;
计算d1’=d1,d2’=d1*d2,…,di’=d1*d2*…*di;
计算H=(di’)-1mod n;
计算(d1)-1=H*d2*…*di,(d2)-1=H*d1*d3*…*di,…,(di)-1=H*d1*d2*…*di-1;
其中,dAi为用户私钥,(di)-1为用户私钥的增1逆,n为椭圆曲线基点G的阶。
7.如权利要求1所述的实现方法,其特征在于,所述SM2数字签名生成算法中的计算椭圆曲线点步骤的计算由一个GPU线程顺序完成,或多个GPU线程针对不同的随机数同时计算完成。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于中国科学院数据与通信保护研究教育中心,未经中国科学院数据与通信保护研究教育中心许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201310445395.1/1.html,转载请声明来源钻瓜专利网。
- 上一篇:机械手装置上的移送滚轮与轨道状态的检测装置
- 下一篇:含有瓜氨酸的佐剂组合物