1、 陕西理工学院毕业论文(设计)第 1 页 共 41 页公开密钥加密算法 RSA的 Matlab实现摘要RSA 算法是基于数论的公开密钥加密算法,它已经成为现在最流行的公钥加密算法和数字签名算法之一。其算法的安全性基于数论中大素数分解的困难性,所以 RSA 公钥密码体制算法的关键是如何产生大素数和进行大指数模幂运算。本文首先介绍了 RSA 公开密钥加密算法的数学原理,并介绍了几种流行的产生大素数的算法。然后用 matlab 具体实现公钥加密算法 RSA 的加密和解密,从而实现了数据的安全传输。关键词 RSA 算法;加密;素数The Realization of RSA Algorithm for
2、 Public Key Encryption 陕西理工学院毕业论文(设计)第 2 页 共 41 页Based on Matlab(Grade 07,Class 3,Major electronics and information engineering ,Communication engineering Dept.,Shaanxi University of Technology, Hanzhong 723003, Shaanxi)Tutor: abstract :The algorithm is based on the theory of RSA public key encrypti
3、on algorithm, it has become the most popular public key encryption algorithm and digital signature algorithm of one. The safety of the algorithm based on number theory cuhk the difficulty of prime decomposition, so the RSA public key cryptography algorithms is key to how to produce large prime Numbe
4、rs DaZhi and transmit power operation. This paper first introduced the RSA public key encr -yption algorithm of mathematical theory, and introduces several popular produce large prime Numbers of the algorithm. Then use matlab RSA public key encryption algorithm re -alization of encryption and decryp
5、tion is realized, and the safety of the data trans -mission.Key words: RSA algorithm; encryption; prime number 陕西理工学院毕业论文(设计)第 1 页 共 41 页目录引言 .11数据加密概述 .21.1 基本概念 .21.2 数据加密分类 .32 Matlab工具介绍 .62.1 MATLAB 语言的主要特点 .62.2 Matlab 的程序设计 .622.1 脚本文件和函数文件 .622.2 函数调用和参数传递 .822.3 MATLAB 的程序结构和控制流程 .83 RSA公钥密
6、码体制 .103.1 算法简介 .103.2 算法的数学基础 .103.3 RSA 公钥密码算法 .103.3.1 算法步骤 .103.3.2 参数分析 .113.3.3 安全性分析 .123.4 公钥密码体制中安全大素数的生成 .133.4.1 素数筛选 .133.4.2 素数检测 .143.5 RSA 的 Matlab 实现 .16陕西理工学院毕业论文(设计)第 2 页 共 41 页3.5.1 算法原理 .163.5.2 运行过程 .203.5.3 结论分析 .224 基于 RSA的数字签名 .234.1 数字签名概述 .234.2 基于 RSA 的数字签名 .244.3 RSA 数字签名
7、方案的不足 .245 RSA算法的实际应用和发展 .255.1 算法的应用 .255.2 算法的改进 .26结论 .27致谢 .28参考文献 .29附录 .30附录 A:英文资料及翻译 .30附录 B:源程序 .40陕西理工学院毕业论文(设计)第 1 页 共 41 页引言随着 Internet 用户的激增,世界正步入网络经济的新时代。如网上购物、网上银行、网上证券等。然而,有一些人利用利用他们所掌握的技术非法侵入他人的计算机系统,窃取、篡改、破坏一些重要的数据,给社会造成巨大的损失。密码技术的发展与应用,对解决信息交换的安全问题,保障数据信息的安全,起着不可忽视的作用。所谓密码技术,就是针对信
8、息进行重新编码,从而达到隐藏信息的内容,使非法用户无法获取信息真实内容的一种手段。目前在网络中,一般采用两种密码体制:对称密钥体制和非对称密钥体制。对称密钥体制中的加密密钥和解秘密钥是相同的,所以又称密秘密钥密码体制。对称密钥算法运算效率高、使用方便、加密效率高,在处理大量数据时被广泛使用,但其关键是要保证密钥的安全,为安全起见,密钥要定期改变,所以,对称密钥就存在一个如何安全管理密钥的问题。与对称密钥体制相对应的非对称密钥体制又称为公开密钥密码体制,它是在 1976 年由 Diffe 和 Hellman 发表的密码学的新方向一文中提出的,从此打破了长期使用单密钥体制的束缚。自此提出公约密码思
9、想以后,涌现出很多的公约密钥算法体系,经过 20 多年的实践检验,公约系统的应用技术日趋完善,应用领域日趋广泛。公开密钥密码体制,加密密钥和解秘密钥是分开采用一对不同的密钥进行的,分别存在一个公钥和私钥,公钥公开,私钥保密,并且知道其中一个时并不能从中推出另一个。其典型的算法有背包密码、RSA 等。 其中 RSA 公约算法系统因为其可靠安全性,易于实现性,更是受大家的认可和欢迎。RSA 加密算法的最大优点就是不需要对密钥通信进行保密,所需传输的只有公开密钥,这样就省去了一条开销很大的密钥传输信道。其保密性强,密钥管理方便,并且具有数字签名、认证和签别等多种功能,特别适合于现代保密通信的需要。大
10、多数使用公钥密码进行加密和数字签名的产品和标准使用的都是 RSA 算法。RSA 的安全性是基于大数因子分解的困难性。目前一般认为 RSA 需要1024 位以上的字长才有安全保障。由于 RSA 所采用的模幂运算耗时太多,因此它通常只能用于加密少量数据或者加密密钥。需要注意的是,RSA 的安全性只是一种计算安全性,绝对不是无条件的安全性,这是由它的理论基础决定的。所以,在实现 RSA 算法的过程中,每一步都应该尽量从安全性方面考虑。本文就 RSA 算法以及如何用 Matlab 语言实现给于了详细的分析。陕西理工学院毕业论文(设计)第 2 页 共 41 页1 数据加密概述密码学是一门古老而深奥的学科
11、,它对一般人来说是陌生的,因为长期以来,它只在很少的范围内,如军事、外交、情报等部门使用。计算机密码学是研究计算机信息加密、解密及其变换的科学,是数学和计算机的交叉学科,也是一门新兴的学科。随着计算机网络和计算机通讯技术的发展,计算机密码学得到前所未有的重视并迅速普及和发展起来。在国外,它已成为计算机安全主要的研究方向,也是计算机安全课程教学中的主要内容。密码是实现秘密通讯的主要手段,是隐蔽语言、文字、图象的特种符号。凡是用特种符号按照通讯双方约定的方法把电文的原形隐蔽起来,不为第三者所识别的通讯方式称为密码通讯。在计算机通讯中,采用密码技术将信息隐蔽起来,再将隐蔽后的信息传输出去,使信息在传
12、输过程中即使被窃取或载获,窃取者也不能了解信息的内容,从而保证信息传输的安全。 任何一个加密系统至少包括下面四个组成部分: (1)未加密的报文,也称明文。 (2)加密后的报文,也称密文。 (3)加密解密设备或算法。 (4)加密解密的密钥。 发送方用加密密钥,通过加密设备或算法,将信息加密后发送出去。接收方在收到密文后,用解密密钥将密文解密,恢复为明文。如果传输中有人窃取,他只能得到无法理解的密文,从而对信息起到保密作用。1.1 基本概念数据加密技术就是指将一个信息或明文经过加密钥匙及加密函数转换,变成无意义的密文,而接收方则将此密文经过解密函数.解密钥匙还原成明文。加密技术是网络安全技术的基石
13、。明文,即加密前的真实的数据或信息,它是可以被外界所识别,它指代的含义比较广泛,比如用户 A 要将一份文件发送给用户 B,那么我们就将用户 A 手里所拿的那份文件称之为明文。密文,就是对信息经过一定的处理,使它变成无意义的乱码,非指定用户无法对它进行识别,例如 A 使用密钥 K 加密消息并将其发送给 B,B 收到加密的消息后,使用密钥 K 对其解密以恢复原始消息,那么在这一过程当中 A 在途中发送给 B 的东西我们就叫它密文,因为这个文件除 B 外,其他人得到它也没有任何意义,这就保证了信息传送的保密性。完成加密和解密的算法成为为密码体制。人们一方面要把自己的信号隐蔽起来,另一方面则想把别人的
14、隐蔽信息挖掘出来,于是就产生了密码分析的逆科学密码分析。密码分析研究的问题是如何把密文转换成明文。把密文转换成明文的过程称为破译。破译也是进行函数变换,变换过程中使用的参数也叫密钥。一般地,如果求解一个问题需要一定量的计算,但环境所能提供的实际资源却无法实现,则这种问题是计算上不可能的。如果一个密码体制的破译是计算上不可能的。则称该密码体制是计算上安全的。密码体制必须满足三个基本要求:(1)对所有的密钥、加密和解密都必须迅速有效;(2)体制必须容易使用;陕西理工学院毕业论文(设计)第 3 页 共 41 页(3)体制的安全性必须只依赖于密钥的保密性。密码体制要实现的功能可分为保密性和真实性两种。
15、保密性要求密码分析员无法从截获的密文中求出明文。一般情况下一个密码体制的保密性包括两项要求:(1)即使截获了一段密文 C,甚至知道了与它对应的明文 M,密码分析要从系统中求出解密变换,仍然是计算上不可行的。(2)密码分析员要由截获的密文 C 中系统的求出明文 M 是计算上不可能的。数据的真实性要求密码分析员无法用虚假的密文代替真是密文而不被察觉,它也包括两个要求:(1)对于给定的 C,即使密码分析员知道了对应于它的明文 M,要系统的求出加密变换仍然是计算上不可能的。(2)密码分析员要系统地找到密文,使其是明文空间上有意义的明文,这在计算上是不可能的。1.2 数据加密分类专用密钥:又称为对称密钥
16、或单密钥,加密和解密时使用同一个密钥,即同一个算法。如DES和MIT的Kerberos算法。单密钥是最简单方式,通信双方必须交换彼此密钥,当需给对方发信息时,用自己的加密密钥进行加密,而在接收方收到数据后,用对方所给的密钥进行解密。当一个文本要加密传送时,该文本用密钥加密构成密文,密文在信道上传送,收到密文后用同一个密钥将密文解出来,形成普通文体供阅读。在对称密钥中,密钥的管理极为重要,一旦密钥丢失,密文将无密可保。这种方式在与多方通信时因为需要保存很多密钥而变得很复杂,而且密钥本身的安全就是一个问题。公开密钥:又称非对称密钥,加密和解密时使用不同的密钥,即不同的算法,虽然两者之间存在一定的关
17、系,但不可能轻易地从一个推导出另一个。有一把公用的加密密钥,有多把解密密钥,如 RSA 算法。 非对称密钥由于两个密钥(加密密钥和解密密钥)各不相同,因而可以将一个密钥公开,而将另一个密钥保密,同样可以起到加密的作用。 在这种编码过程中,一个密码用来加密消息,而另一个密码用来解密消息。在两个密钥中有一种关系,通常是数学关系。公钥和私钥都是一组十分长的、数字上相关的素数(是另一个大数字的因数)。有一个密钥不足以翻译出消息,因为用一个密钥加密的消息只能用另一个密钥才能解密。每个用户可以得到唯一的一对密钥,一个是公开的,另一个是保密的。公共密钥保存在公共区域,可在用户中传递,甚至可印在报纸上面。而私
18、钥必须存放在安全保密的地方。任何人都可以有你的公钥,但是只有你一个人能有你的私钥。它的工作过程是:“你要我听你的吗?除非你用我的公钥加密该消息,我就可以听你的,因为我知道没有别人在偷听。只有我的私钥(其他人没有)才能解密该消息,所以我知道没有人能读到这个消息。我不必担心大家都有我的公钥,因为它不能用来解陕西理工学院毕业论文(设计)第 4 页 共 41 页密该消息。” 公钥加密体制具有以下优点:(1) 密钥分配简单。(2) 密钥的保存量少。(3) 可以满足互不相识的人之间进行私人谈话时的保密性要求。(4) 可以完成数字签名和数字鉴别。明文M 密文C=E(M, ) M=D(C, )1K2K1K2(
19、密钥本)图1.1 公钥密码体制示意图对称密钥:对称密钥是最古老的,一般说“密电码”采用的就是对称密钥。由于对称密钥运算量小、速度快、安全强度高,因而目前仍广泛被采用。 DES 是一种数据分组的加密算法,它将数据分成长度为 64 位的数据块,其中 8 位用作奇偶校验,剩余的 56 位作为密码的长度。第一步将原文进行置换,得到 64 位的杂乱无章的数据组;第二步将其分成均等两段;第三步用加密函数进行变换,并在给定的密钥参数条件下,进行多次迭代而得到加密密文。 非对称加密技术:数字签名一般采用非对称加密技术(如 RSA),通过对整个明文进行某种变换,得到一个值,作为核实签名。接收者使用发送者的公开密
20、钥对签名进行解密运算,如其结果为明文,则签名有效,证明对方的身份是真实的。当然,签名也可以采用多种方式,例如,将签名附在明文之后。数字签名普遍用于银行、电子贸易等。 数字签名:数字签名不同于手写签字,数字签名随文本的变化而变化,手写签字反映某个人个性特征,是不变的;数字签名与文本信息是不可分割的,而手写签字是附加在文本之后的,与文本用户 A 加密 解密 用户 B公钥空间 私钥空间密码分析陕西理工学院毕业论文(设计)第 5 页 共 41 页信息是分离的。 值得注意的是,能否切实有效地发挥加密机制的作用,关键的问题在于密钥的管理,包括密钥的生存、分发、安装、保管、使用以及作废全过程。陕西理工学院毕
21、业论文(设计)第 6 页 共 41 页2 Matlab工具介绍2.1 MATLAB 语言的主要特点(1) 具有丰富的数学功能。 包括矩阵各种运算。如:正交变换、三角分解、特征值、常见的特殊矩阵等。 包括各种特殊函数。如:贝塞尔函数、勒让德函数、伽码函数、贝塔函数、椭圆函数等。 包括各种数学运算功能。如:数值微分、数值积分、插值、求极值、方程求根、FFT 、常微分方程的数值解等。(2) 具有很好的图视系统。 可方便地画出两维和三维图形。 高级图形处理。如:色彩控制、句柄图形、动画等。 图形用户界面 GUI 制作工具,可以制作用户菜单和控件。使用者可以根据自己的需求编写出满意的图形界面。(3) 可
22、以直接处理声言和图形文件。 声言文件。如: WAV 文件(例:wavread,sound 等) 。 图形文件。如: bmp 、gif 、 pcx 、tif 、jpeg 等文件。(4). 具有若干功能强大的应用工具箱。如:SIMULINK、COMM、DSP、 SIGNAL 等 16 种工具箱。(5). 使用方便,具有很好的扩张功能。 使用 MATLAB 语言编写的程序可以直接运行,无需编译。 可以 M 文件转变为独立于平台的 EXE 可执行文件。 MATLAB 的应用接口程序 API 是 MATLAB 提供的十分重要的组件 ,由 一系列接口指令组成 。用户就可在 FORTRAN 或 C 中 , 把 MATLAB 当作计算引擎使用 。 (6). 具有很好的帮助功能 提供十分详细的帮助文件(PDF 、HTML 、demo 文件) 。 联机查询指令:help 指令(例:help elfun,help exp,help simulink) ,lookfor 关键词(例: lookfor fourier ) 。2.2 Matlab 的程序设计 2.2.1 脚本文件和函数文件