[发明专利]一种生成数字签名的方法及装置有效
申请号: | 201310363349.7 | 申请日: | 2013-08-16 |
公开(公告)号: | CN103427997A | 公开(公告)日: | 2013-12-04 |
发明(设计)人: | 李志勇;万红涛;颜湘 | 申请(专利权)人: | 西安西电捷通无线网络通信股份有限公司 |
主分类号: | H04L9/32 | 分类号: | H04L9/32;G06F19/00 |
代理公司: | 北京同达信恒知识产权代理有限公司 11291 | 代理人: | 黄志华 |
地址: | 710075 陕西省西安市高*** | 国省代码: | 陕西;61 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 生成 数字签名 方法 装置 | ||
技术领域
本发明涉及信息技术领域,尤其涉及一种生成数字签名的方法及装置。
背景技术
SM2数字签名算法作为SM2密码算法的一个组成部分,其在用户身份认证和信息完整性校验功能领域得到很好的应用。在SM2数字签名算法应用过程中,算法运算效率一直是算法应用者们所关注的重点。SM2数字签名算法由SM2数字签名生成算法和SM2数字签名验证算法构成。
设待签名的消息为M,为了获取消息M的数字签名(r,s),当用户A需要使用数字签名时,可通过如下SM2数字签名生成算法实现:
A1:置
其中,‖表示级联运算,ZA为通过密码杂凑函数求得的上述生成数字签名的用户A的杂凑值。
A2:计算并将e的数据类型由比特串转换为整数。
其中,Hv()为消息摘要长度为v比特的密码杂凑函数,如SM3密码杂凑算法。
A3:用随机数发生器产生随机数k∈[1,n-1]。
其中,n为椭圆曲线参数。
A4:计算椭圆曲线点(x1,y1)=[k]G,结果x1为域元素,将x1的数据类型转换为整数。
其中,G为椭圆曲线的基点,[k]G表示k与G点乘。
使用的椭圆曲线方程,其类型可选择素数域方程y2=x3+ax+b或二元扩域方程y2+xy=x3+ax2+b。
A5:计算r=(e+x1)modn 公式一
即使用(e+x1)对n求模。
若r=0或r+k=n则返回A3。
A6:计算s=((1+dA)-1·(k-r·dA))modn 公式二
若s=0则返回A3。
其中,dA为上述用户A的私钥。
A7:将r、s的数据类型由整数转换为字节串,消息M的数字签名为(r,s)。
用户A可以是系统或设备,执行上述SM2数字签名生成算法的可以是设置于用户A内部的子系统、硬件模块、在用户A内可执行的软件模块等等,也可以是与用户A有通信连接、被用户A调用的系统或设备。
用户A具有长度为entlenA比特的可辨别标识IDA,记ENTLA是由整数entlenA转换而成的两个字节。在上述SM2数字签名生成算法中,将G的坐标xG、yG和PA的坐标xA、yA的数据类型转换为比特串,则上述ZA=H256(ENTLA‖IDA‖a‖b‖xG‖yG‖xA‖yA)。其中,PA为用户A的公钥,H256()为消息摘要长度为256比特的密码杂凑函数,如SM3密码杂凑算法。
另外,在具体工程实现过程中,本领域技术人员通常会对公式二采用公式三和公式四两种变形,将公式二中(1+dA)-1求负整数指数幂运算转换为(1+dA)-1modn求模逆运算,便于工程实现。
s=(((1+dA)-1modn)·((k-r·dA)modn))modn 公式三
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于西安西电捷通无线网络通信股份有限公司,未经西安西电捷通无线网络通信股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201310363349.7/2.html,转载请声明来源钻瓜专利网。
- 上一篇:数字识别码生成系统及方法
- 下一篇:一种识别用户的方法和装置