版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
实验三PGP一、实验目的1、加深理解密码学在网络平安中的重要性;2、了解流行加密软件PGP/GPG4Win的工作原理;3、掌握流行加密软件PGP/GPG4Win的安装和使用。二、实验预习提示1、PGP概述PGP〔PrettyGoodPrivacy〕的创始人是美国的PhilZimmermann〔菲利普·齐默曼〕,他在1991年把RSA公钥体系的方便和传统加密体系的高速度结合起来,并且在数字签名和密钥认证管理机制上有巧妙的设计。因此PGP成为几乎最流行的公匙加密软件包。PGP有不同的实现,如GnuPG和Gpg4win,其中GnuPG〔GnuPrivateGuard,简写为GPG〕的核心算法是PGP,GnuPG本身是为Linux等开源操作系统设计的;而Gpg4win是windows下GnuGPG及图形前端的合集安装包,其核心为GnuPG,包括:〔1〕Kleopatra和GPA:GPG的密钥管理器,用于生成、导入和导出GPG密钥〔包括公钥和私钥〕;〔2〕GpgOL:Outlook的GPG支持插件;〔3〕GpgEX:资源管理器的GPG支持插件;〔4〕ClawsMail:内置GPG支持的邮件客户端。PGP是一个基于RSA公钥加密体系的加密软件,是开源且免费的,后经互联网志愿者开展完善并广泛应用,具有如下特点:〔1〕选择最可用的加密算法作为系统的构造模块,所用算法已被广泛检验过,相当平安;并将这些算法集成到一个通用的应用程序中,该程序独立于操作系统和处理器,并且基于一个使用方便的小命令集;〔2〕是一个开源工程,程序、文档在Internet上公开;〔3〕可以免费得到运行于多种平台上的PGP版本,具有广泛的可用性;〔4〕不由任一政府或标准化组织所控制,使得PGP得到了广泛信任;〔5〕与商业公司(NetworkAssociates)合作,提供一个全面兼容的、低价位的商业版本PGP。2023年6月被赛门铁克公司收购。由于这些特点,使得PGP得到了广泛的应用。PGP常用的版本是PGPDesktopProfessional,它可以用来加密文件,可以用来对邮件保密以防止非授权者阅读,还能对邮件加上数字签名从而使收信人可以确认邮件的发送者,并能确信邮件没有被篡改。同时,通过使用公钥密码算法,可以提供一种事先并不需要任何保密的渠道用来传递密匙的平安通讯方式。PGP功能强大,而且具有很快的速度,PGP提供的主要功能如表2.7.1所示。表2.7.1PGP的功能概述功能使用的算法描述消息加密IDEA、CAST、3DES、TwoFish、ElGamal、RSA发信人产生一次性会话密钥加密,用IDEA或CAST-128或3DES算法对消息进行加密;采用ElGamal或RSA算法用接收方的公钥加密会话密钥数字签名DSS/SHA-1、RSA/MD5采用SHA-1或MD5消息摘要算法计算消息的摘要值〔散列码〕,用发送者的私钥按DSS或RSA算法加密消息摘要压缩PKZIP消息在传送和存储时可使用PKZIP压缩E-mail兼容性Radix-64对E-mail应用提供透明性,采用基数64编码将加密后的消息〔二进制流〕转换为ASCII字符串数据分段-为了适应最大消息长度限制,PGP执行分段和重新组装2、PGP的密钥管理PGP是一种混合密码系统,应用了多个密码算法,包括对称密码算法、非对称密码算法、消息摘要算法、数字签名等经典的密码学算法。为用户生成密钥对之后,可以进行邮件的加密、签名、解密和认证。在PGP中使用的加密算法和用途如表2.7.2所示。表2.7.2PGP中采用的各种密码算法及用途密钥名加密算法用途会话密钥IDEA、AES对传送消息的加解密,随机生成,一次性使用公钥RSA、Diffie-Hellman对会话密钥加密,收信人和发信人共用私钥DSS/SHA、RSA/SHA对消息的杂凑值加密以形成签名,发信人专用口令IDEA对私钥加密以存储于发送端 从上表可以看出,PGP使用了四种类型的密钥:一次性会话传统密钥、公钥、私钥和基于口令短语的传统密钥/通行字短语。 会话密钥按ANSIX9.17标准,采用IDEA算法,以密文反应模式〔CFB〕生成。当PGP用RSA算法为用户生成一个新的公钥/私钥对时,PGP会要求用户提供一个口令短语,对该短语使用MD5/SHA-1消息摘要算法生成一个散列码后,销毁该短语,从而把用户输入的口令短语转化为IDEA/CAST-128密钥,再使用这个密钥加密私钥,然后销毁这个散列码,并将加密后的私钥存储到私钥环中。当用户要访问私钥环中的私钥时,必须提供口令短语。PGP将取出加密后的私钥,生成散列码,解密私钥。 一个用户可能拥有多个公钥/私钥对,正确识别加密会话密钥和签名所用的特定公钥/私钥对的一个最简单的解决方案是将公钥和消息一起传送。但这种方式浪费了不必要的空间。PGP采用的解决方案是给每个公钥分配一个密钥标识〔KeyID〕,并以极大的概率与用户标识〔UserID〕一一对应,即UserID和KeyID标识一个密钥。密钥标识至少为64位,因而密钥标识重复的可能性非常小。PGP提供一种系统化的密钥管理方案来存储和组织这些密钥以保证有效使用这些密钥,它为每个节点〔用户机器〕提供一对数据结构,一个用于存放本节点自身的公钥/私钥对〔即私钥环〕,另一个用于存放本节点知道的其他用户的公钥〔即公钥环〕。私钥环信息:时间戳、KeyID、公钥、私钥、UserID,其中UserID通常是用户的邮件地址。也可以是一个名字,可以重名;公钥环信息:时间戳、KeyID、公钥、对所有者信任度、用户ID、密钥合法度、签名、对签名者信任度,其中UserID为公钥的拥有者。多个UserID可以对应一个公钥。公钥环可以用UserID或KeyID索引。如何保证用户公钥环上的公钥确实是指定实体的合法公钥,这是一个至关重要的问题。PGP提供几种可选的方案以减少用户公钥环中包含错误公钥的可能性:〔1〕物理上得到对方的公钥。这种方式最可靠,但有一定局限性;〔2〕通过验证公钥;〔3〕从双方都信任的第三方〔个体或CA〕处获得对方的公钥。此外,PGP支持密钥管理效劳器,用户可以将公钥发布在集中的密钥效劳器上,供他人访问。3、PGP的消息处理过程PGP消息分成原始消息、签名局部和会话密钥局部三个局部。PGP发送方处理消息的过程为:〔1〕签名:利用UserID作为索引,从私钥环中得到私钥;PGP提示输入口令短语,恢复私钥;构造签名局部;〔2〕加密:PGP产生一个会话密钥,并加密消息;PGP用接收者UserID从公钥环中获取其公钥;构造消息的会话密钥局部。PGP接收方处理消息的过程为:〔1〕解密消息:PGP用消息的会话密钥局部中的KeyID作为索引,从私钥环中获取私钥;PGP提示输入口令短语,恢复私钥;PGP恢复会话密钥,并解密消息;〔2〕验证消息:PGP用消息的签名局部中的KeyID作为索引,从公钥环中获取发送者的公钥;PGP恢复被传输过来的消息摘要;PGP对于接收到的消息计算摘要,并与上一步的结果作比拟。4、PGP的信任模型由于PGP重在广泛地在正式或非正式环境下的应用,所以它没有建立严格的公钥管理模式。尽管PGP没有包含任何建立认证权威机构或建立信任体系的标准,但它提供了一个利用信任关系的方法,将信任关系与公钥联系起来。PGP定义了与基于X.509真实的公钥根底设施〔PKI〕不同的证书模型,即所谓“信任网〔WebofTrust〕〞模型。传统PKI模型依赖于CA层次体系验证证书和其中的密钥。而PGP模型那么允许多重地、独立地而非特殊可信个体签署的“名字/密钥〞关联来证明证书的有效性,其理论是认为“只要有足够的签名,<名字/密钥>关联就是可信的,因为不会所有的签名者都是‘坏’的〞。PGP的信任网就像人际关系网一样,通过下述方式让使用公钥的人相信公钥是其所声称的持有者:〔1〕直接来自所信任人的公钥;〔2〕由所信赖的人为某个自己并不认识的人签署的公钥。因此,在PGP中得到一个公钥后,检验其签名,如果签名人自己认识并信赖他,就认为此公钥可用或合法。这样,通过所认识并信赖的人,就可以和总多不认识的人实现PGP的平安E-mail通信。具体而言,在PGP中是通过在公钥环中的下述3个字段来实现WebofTrust信任模型的:〔1〕密钥合法性字段〔keylegitimacyfield〕:指示用户公钥合法性的可信等级。信任级别越高,那么用户标识UserID与密钥间的绑定关系就越强。这个字段是由PGP计算的;〔2〕签名信任字段〔signaturetrustfield〕:每一个公钥项都有一个或者多个签名,这是公钥环主人收集到的、能够认证该公钥项的签名。每一个签名与一个signaturetrustfield关联,指示PGP用户信任签名者对此公钥证明的程度。keylegitimacyfield是由多个signeturetrustfield导出的;〔3〕所有者信任字段〔ownertrustfield〕:指示此公钥对其他公钥证书进行签名的信任程度。这个信任程度是由用户给出的。PGP使用以个人为中心的信任模型,采取一种“社会信任链〞的方式进行公钥分发。在这种方式下,用户可以自行决定对周围的联系人是否信任,并可以决定信任度的上下。用户只接收信任的朋友传送来的公钥,并且这些公钥都带有签名。这种方式反映了社会交往的本质,比拟适合一般场合下的平安通信。本实验通过实际操作,了解PGP/GPG4Win软件的常用功能,利用PGP/GPG4Win软件实现密钥管理、对文件和电子邮件的签名与加密等操作。下面的实验步骤以中文版PGPDesktop9.9为例进行介绍。三、实验过程和指导〔一〕实验要求利用PGP/GPG4Win软件,完成以下操作:1、密钥的管理:〔1〕生成公钥/私钥对;〔2〕密钥的导出;〔3〕密钥的导入。2、文件操作:〔1〕加密/解密文件;〔2〕签名/验证文件;〔3〕加密和签名/解密和验证文件。3、邮件操作:〔1〕加密/解密邮件;〔2〕签名/验证邮件;〔3〕加密和签名/解密和验证邮件。〔二〕实验准备1、阅读教材有关章节,理解RSA、IDEA、MD5等相关算法的工作原理。2、阅读教材和PGP相关资料,熟悉PGP软件的常用功能及操作步骤。3、准备好相关测试数据和软件。〔三〕上机实验假设通信双方分别为S和R,和。1、密钥管理〔1〕生成公钥/私钥对在使用PGP进行加密或签名之前,必须先生成公钥/私钥对,公私钥对是同时生成的,其中公钥可以分发给需要与之通信的人,让他们用这个公钥来加密或验证签名,私钥由使用者自己保存,使用者可以用此密钥来解密或进行签名。Step1:运行PGP软件后,在如图2.7.1所示的主界面中单击“文件〞菜单。图2.7.1PGP主界面Step2:单击“新建PGP密钥〞菜单项后出现“PGP密钥生成助手〞界面,如图2.7.2所示。图2.7.2PGP密钥生成助手界面Step3:单击“下一步〞后出现“分配名称和邮件〞界面,如图2.7.3所示,在此填入用户名和与之相关联的电子邮件地址。图2.7.3分配名称和邮件界面单击下方的“高级(V)…“按钮,可以对密钥进行更多设置,如图2.7.4所示。图2.7.4高级密钥设置界面Step4:高级密钥设置完毕后,单击“下一步〞后出现“创立密码〞界面,如图2.7.5所示,在此输入对私钥进行保护的口令密码。图2.7.5创立密码界面Step5:单击“下一步〞后出现“密钥生成进度〞界面,如图2.7.6所示图2.7.6密钥生成进度界面Step6:单击“下一步〞后完成密钥对的生成,界面如图2.7.7所示。图2.7.7密钥对生成界面Step7:单击“完成〞按钮将新生成的密钥对添加到密钥环中,界面如图2.7.8所示。图2.7.8PGP密钥界面为平安起见,最好将刚生成的密钥进行备份,以免丧失。〔2〕密钥的导出 为了实现非对称加密,需要将自己的公钥导出后分发给需要与之通信的其他人。Step1:在2.7.8所示界面上右键单击要导出的密钥,选择“导出〔X〕…〞菜单项,如图2.7.9所示。图2.7.9导出密钥界面Step2:在随后弹出的如图2.7.10所示的导出密钥到文件的界面上,设置导出密钥的文件存放路径及文件名。这里仅导出公钥文件,文件名为fengwang.asc。可以用邮件或利用其他平安通道将此公钥分发给需要与之通信的人。图2.7.10导出密钥到文件界面 〔3〕密钥的导入 如果需要阅读他人发送过来的已签名的邮件,或者需要给他人发送加密邮件时,就必须拥有对方的公钥。当接收方收到通信方的公钥并下载到自己的计算机后,需要将其进行导入。Step1:在如图2.7.1所示的PGP主界面中单击“文件〞菜单,选择“导入〔I〕…〞菜单项后出现如图2.7.11所示界面。图2.7.11选择导入包含密钥的文件界面Step2:在图2.7.11所示的对话框中选择要导入的公钥文件〔teaching.asc〕,单击“翻开〔O〕〞按钮后出现如图2.7.12所示界面。图2.7.12选择密钥界面Step3:在图2.7.12所示的对话框中选中通信方的E-mail地址,然后单击“导入〔I〕〞按钮导入通信方的公钥,界面如图2.7.13所示。图2.7.13导入密钥后界面Step4:在图2.7.13所示的对话框中可以看出刚导入的通信方公钥为“未校验〞状态,右键单击通信方的公钥,在弹出的快捷菜单中选择“签名〔S〕…〞菜单项,界面如图2.7.14所示。图2.7.14对可信方的公钥签名界面Step5:在随后弹出的如图2.7.15所示的对话框中对通信方公钥进行签名。图2.7.15PGP签名密钥界面Step6:在图2.7.15所示的对话框中设置好相关签名信息后单击“确定〔O〕〞按钮,出现如图2.7.16所示的选择签名密钥对话框。图2.7.16选择签名密钥界面Step7:在图2.7.16所示的对话框中选择签名所用密钥后单击“确定〔O〕〞按钮,出现如图2.7.17所示的界面,可以看出此时通信方公钥已变为“已校验〞状态。注意:在进行公钥签名时,由于这里当前选择签名密钥的密钥已缓存,因此不需要输入密码;否那么会要求输入私钥保护口令。图2.7.17公钥签名后界面2、文件操作〔1〕加密/解密文件 1〕对文件进行加密Step1:用户S右键单击需要加密传送的文件〔如“工作记录.txt〞〕,在弹出的快捷菜单中选择“PGPDesktop(G)〞“使用密钥保护“工作记录.txt〞…〞,如图2.7.18所示。 Step2:在随后弹出的如图2.7.19所示“添加用户密钥〞界面中,选择通信方R公钥对应的用户名或邮件地址〔如teaching<>〕,添加后的界面如图2.7.20所示。 Step3:单击“下一步〞后生成用通信方R的公钥加密之后的文件,文件名后缀为“.pgp〞〔如“工作记录.txt.pgp〞〕,如图2.7.21所示。图2.7.18文件加密界面图2.7.19添加用户密钥界面图2.7.20选择用户密钥后的界面图2.7.21文件加密结果 2〕对文件进行解密Step1:通信方R右键单击用户S传来的加密文件〔如“工作记录.txt.pgp〞〕,在弹出的快捷菜单中选择“PGPDesktop(G)〞“解密&校验(D)“工作记录.txt.pgp〞〞,如图2.7.22所示。图2.7.22文件解密界面Step2:在随后弹出的如图2.7.23所示“输入密码〞界面中,输入与加密时所用通信方R公钥对应私钥的保护密码。图2.7.23输入密码界面Step3:正确输入私钥保护密码后单击“确定〔O〕〞按钮,在随后弹出的如图2.7.24所示“输入导出文件名〞界面中,选择解密文件的存放路径并输入解密后存放的文件名〔如“工作记录2.txt〞〕,然后单击“保存〔S〕〞按钮,即可实现对加密文件的解密操作。图2.7.24输入导出文件名界面如果用户没有与加密文件时所用公钥相对应的私钥,那么在进行上述解密操作时会失败,并且系统提示“因为您的密钥环不包含任何与上列公钥对应的可用私钥,无法解密此消息〞,如图2.7.25所示。图2.7.25文件解密失败界面〔2〕签名/验证文件1〕对文件进行签名Step1:用户R右键单击需要签名的文件〔如“工作记录.txt〞〕,在弹出的快捷菜单中选择“PGPDesktop(G)〞“签名为teaching<mailteachingwf@163>〞,如图2.7.26所示。图2.7.26文件签名界面 Step2:在随后弹出的如图2.7.27所示“签名并保存〞界面中,选择用户R进行签名时所使用的私钥对应的用户名或邮件地址〔如teaching<>〕,并输入私钥保护密码,设置保存位置,如图2.7.27所示。图2.7.27签名并保存界面 Step3:单击“下一步〞后生成用用户R的私钥签名之后的文件,文件名后缀为“.sig〞〔如“工作记录.txt.sig〞〕,如图2.7.28所示。图2.7.28文件签名后的界面2〕对签名文件进行验证通信方S在对通信方的身份进行真实性校验时,如果没有用户R的公钥或公钥与签名所用私钥不对应,那么无法通过真实性校验,在PGP验证历史中“签名人〞、“已校验〞和“已签名〞等信息为空且“密钥ID〞显示为“无效密钥〞,如图2.7.29所示。图2.7.29签名验证失败界面反之,如果通信方拥有用户R的公钥,那么可以通过真实性校验,并在PGP验证历史中显示与签名相关的信息,如图2.7.30所示。图2.7.30签名验证成功界面〔3〕加密和签名/解密和验证文件此操作实际上是将〔1〕和〔2〕结合在一起,同时实现文件的加密和签名以及解密和验证功能。1〕对文件进行加密和签名Step1:用户S右键单击需要加密和签名的文件〔如“工作记录.txt〞〕,在弹出的快捷菜单中选择“PGPDesktop(G)〞“添加“工作记录.txt〞到新PGP压缩包…〞,如图2.7.31所示。图2.7.31添加新PGP压缩包界面 Step2:在随后弹出的如图2.7.32所示“新建PGP压缩包〞界面中,可以对需要包含在PGP压缩包中的文件进行添加和删除。图2.7.32新建PGP压缩包界面 Step3:单击“下一步〞后对加密选项进行设置,这里选择“接收人密钥〞方式,即用接收方公钥进行加密,如图2.7.33所示。 Step4:单击“下一步〞后对加密所用密钥进行设置,界面与图2.7.19-图2.7.20相同。 Step5:单击“下一步〞后对签名所用密钥进行设置,界面与图2.7.27相同。Step6:单击“下一步〞后显示加密和签名的相关信息,界面如图2.7.34所示,从图中可以看出,这里加密时采用的是接收方R的公钥〔teaching<>〕,而签名时采用的那么是发送方S的私钥〔fengwang<nancyfeng521@163>〕。Step7:单击“完成〞后生成经加密和签名的后缀为“.pgp〞〔如“工作记录.txt.pgp〞〕的PGP压缩包文件,界面与图2.7.21相同。图2.7.33加密选项界面图2.7.34加密和签名相关信息界面2〕对文件进行解密和验证通信方如果拥有正确的密钥,那么可实现对上述PGP压缩包的解密和验证操作,否那么无法解密和验证,操作步骤与上述过程类似,在此不再赘述。3、邮件操作要利用PGP实现对邮件的保护,收发双方需要先在Outlook中对电子邮件账户进行设置。Step1:单击Outlook“工具〞菜单,选择“电子邮件账户〔A〕…〞菜单项,如图2.7.35所示。图2.7.35Outlook电子邮件账户设置界面Step2:在随后弹出的如图2.7.36所示“电子邮件账户设置向导〞界面中,可以对添加或更改电子邮件账户等进行设置。图2.7.36电子邮件账户设置向导界面Step3:单击“下一步〞后在如图2.7.37所示的界面可以对电子邮件相关信息进行设置,电子邮件的详细设置信息如图2.7.38所示。图2.7.37电子邮件账户设置界面图2.7.38电子邮件账户详细信息界面Step4:账户信息设置完毕后可以单击图2.7.38中的“测试账户设置〔T〕…〞按钮,对所设置的电子邮件账户进行设置,测试界面如图2.7.39所示。Step5:单击图2.7.38中的“其他设置〔M〕…〞按钮,可以对电子邮件账户其他相关信息进行设置,对发送效劳器进行设置的界面如图2.7.40所示,高级设置的界面如图2.7.41所示。图2.7.39测试电子邮件账户设置界面图2.7.40发送效劳器设置界面图2.7.41高级设置界面Step6:在图2.7.38中单击“下一步〞即可完成电子邮件账户所需信息的设置。下面的实验中假设发送方为S〔nancyfeng521@163〕,接收方为R〔mailteachingwf@163〕,双方分别按照上面的操作步骤导入自己的公私钥对和通信方的公钥。〔1〕加密/解密邮件Step1:发送方S在Outlook中给接收方S撰写一封电子邮件,标题为“PGP测试〞,正文为“PGP测试邮件!〞。右键单击右下角托盘区的PGP图标,在弹出的快捷菜单中选择“当前窗口〔W〕〞“加密〔E〕〞,如图2.7.42所示。图2.7.42高级设置界面Step2:发送方S在随后弹出的密钥选择对话框中双击接收人对应的邮件地址mailteachingwf@163,如图2.7.43所示,单击“确定〞按钮即可利用接收方的公钥对邮件内容进行加密。图2.7.43密钥选择对话框界面Ste
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024异地恋爱合同范本
- 焊工灭火知识培训课件
- 2024雕塑制作合同协议书范本
- 专业化交通违法车辆拖行服务2024协议范本版B版
- 《畜禽病理学》课件
- 2024年跨区域生态环境保护补偿协议
- 浙江农业商贸职业学院《机械结构创新设计》2023-2024学年第一学期期末试卷
- 中南林业科技大学涉外学院《外景采集与创作》2023-2024学年第一学期期末试卷
- 2024年绿色建筑墙面装饰工程劳务分包合同2篇
- 2024幼儿园施工环保技术咨询服务合同3篇
- CSCEC8XN-SP-安全总监项目实操手册
- 加减乘除混合运算600题直接打印
- 口腔卫生保健知识讲座班会全文PPT
- 成都市产业园区物业服务等级划分二级标准整理版
- 最新监督学模拟试卷及答案解析
- ASCO7000系列GROUP5控制盘使用手册
- 污水处理厂关键部位施工监理控制要点
- 财政投资评审中心工作流程
- 带状疱疹的护理查房
- 男性公民兵役登记表.docx
- 10个地基基础工程质量通病及防治措施
评论
0/150
提交评论