[发明专利]数字签名方法及移动终端和服务器有效
申请号: | 201410835701.7 | 申请日: | 2014-12-26 |
公开(公告)号: | CN104486086B | 公开(公告)日: | 2017-10-20 |
发明(设计)人: | 李常坤;石浩然 | 申请(专利权)人: | 北京奇虎科技有限公司;奇智软件(北京)有限公司 |
主分类号: | H04L9/32 | 分类号: | H04L9/32;H04L29/06 |
代理公司: | 北京市立方律师事务所11330 | 代理人: | 王增鑫 |
地址: | 100088 北京市西城区新*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 数字签名 方法 移动 终端 服务器 | ||
技术领域
本发明涉及移动通信技术领域,具体而言,本发明涉及一种数字签名方法及移动终端和服务器。
背景技术
随着科技的进步和社会发展,移动终端的使用已经相当的广泛。越来越多的程序被技术人员开发出来,以应用于移动终端中。
对于一个适用于移动终端的程序,技术人员通常在开发出该程序的代码文件、配置文件、资源文件、图片等等原始文件后,对原始文件进行数字签名,得到签名相关的文件;将该程序的原始文件和签名相关的文件一起打包成安装包,供用户下载安装。
以适用于安卓操作系统的程序为例,开发方的技术人员对于该程序的代码文件Classex.dex、配置文件AndroidManifest.xml、资源文件、图片等等原始文件,通常利用签名工具程序对各原始文件进行签名:计算出各原始文件的一阶散列值记载到Manifest.mf文件中;根据各原始文件的一阶散列值计算出各原始文件的二阶散列值记载到Cert.sf文件中;对各二阶散列值进行摘要计算得到摘要信息;根据预先生成的私钥对摘要信息进行加密;根据加密结果以及预先生成的公钥生成Cert.rsa文件。之后,将各原始文件,与签名相关的Manifest.mf文件、Cert.sf文件和Cert.rsa文件一起打包成程序的安装包。
移动终端的操作系统接收到安装程序的指令后,从该程序的安装包中解压出该程序的各原始文件、以及Manifest.mf文件、Cert.sf文件和Cert.rsa文件;利用Manifest.mf文件、Cert.sf文件和Cert.rsa文件,对各原始文件进行签名认证,以验证原始文件是否被恶意程序所篡改。
此外,安装于移动终端中的第三方的安全类应用程序,对于安全性未知的程序,通常需要从该程序的安装包中解压出各原始文件,对多个原始文件进行适用于沙箱中运行的修改后,重新进行数字签名,得到重新签名的签名相关的文件。将签名相关的文件、与修改后的原始文件进行二次打包,以便于该安全性未知的程序在创建的沙箱中安装运行。
但是,现有的数字签名方法对程序的原始文件进行数字签名的过程通常是在移动终端中执行;也就是说,数字签名过程中涉及的私钥存放在移动终端中;该方式容易导致恶意程序盗取私钥后,即可随意篡改待安装程序的原始文件,也可以通过对篡改后的原始文件进行重新签名,得到合法的签名相关的文件;现有的数字签名方法可能导致被恶意程序劫持或污染的程序的安装包,可以通过操作系统的签名认证而被允许安装;进一步地,可能造成恶意程序利用移动终端中存储的用户信息执行恶意行为。
因此,综上,现有的数字签名方法安全性较低,可能会给用户带来潜在的安全隐患,造成用户的利益损失,从而降低了用户的体验。
发明内容
本发明针对现有的数字签名方法的缺点,提出一种数据签名方法及移动终端和服务器,用以解决现有的数字签名方法存在的安全性较低的问题。
本发明的技术方案根据一个方面,提供了一种移动终端的数字签名方法,包括:
移动终端对于二阶散列值文件中的二阶散列值序列,对该二阶散列值序列中除了代码文件的二阶散列值之外的各二阶散列值进行摘要计算,得到第一子摘要信息;
将第一子摘要信息和所述代码文件的二阶散列值向服务器上传;
其中,所述二阶散列值对应原始文件;所述原始文件的二阶散列值是根据该原始文件的一阶散列值算得的,该原始文件的一阶散列值是根据该原始文件的内容算得的;所述代码文件是所述原始文件之一。
进一步,所述将该二阶散列值序列中除了代码文件的二阶散列值之外的各二阶散列值进行摘要计算之前,还包括:
将所述代码文件的二阶散列值,移动到所述二阶散列值序列的末尾,得到二阶散列值序列重排后的二阶散列值文件。
进一步,所述移动终端的数字签名方法,还包括:
所述移动终端接收到所述服务器返回的数字签名文件后,对于一阶散列值文件中的一阶散列值序列,将该一阶散列值序列中所述代码文件的一阶散列值,移动到所述一阶散列值序列的末尾,得到一阶散列值序列重排后的一阶散列值文件;
将所述数字签名文件、二阶散列值序列重排后的二阶散列值文件、一阶散列值序列重排后的一阶散列值文件,以及所述二阶散列值序列中各二阶散列值各自对应的原始文件一起打包成安装包。
较佳地,所述一阶散列值文件具体为Manifest.mf文件;所述二阶散列值文件具体为Cert.sf文件;所述数字签名文件具体为Cert.rsa文件。
本发明的技术方案根据另一个方面,还提供了一种服务器端的数字签名方法,包括:
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京奇虎科技有限公司;奇智软件(北京)有限公司,未经北京奇虎科技有限公司;奇智软件(北京)有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201410835701.7/2.html,转载请声明来源钻瓜专利网。