用于代码安全和文件交换的API和工具

这篇Java教程基于JDK1.8。教程中的示例和实践不会使用未来发行版中的优化建议。
课程:用于代码安全和文件交换的API和工具

这篇课程解释了数字签名、证书和密钥库存在的必要性。该课程还比较了通过命令行工具和JDK Security API来生成数字签名。接下来的两节课将演示这种工具的用法,签名代码并授予它权限文件交换

该课程包含以下几部分:

  • 代码和文档安全
  • 工具和API说明
  • 使用JDK Security API 签名文档
  • 使用工具来签名代码或文档
代码和文档安全

如果您以电子方式向某人发送要运行的重要文档(或多个文档)、applet或应用程序,收件人需要一种方法来验证文档或代码是否来自您,并且在传输过程中没有被修改(例如,被恶意用户拦截)。数字签名、证书和密钥库都有助于确保您发送的文件的安全性。

数字签名

数字签名的基本概念如下所述:

  1. 通过 keytool 命令或者Java Security API生成私钥。接着,用 jarsigner 命令或者Java Security API为文档或者代码生成数字签名。
  2. 将签名后的文档发送给接收人。
  3. 发送文档的同时把公钥也一并发送给接收人,这个公钥是与给文档生成数字签名使用的私钥对应的。
  4. 接收方使用公钥来验证文档来自于你并且没有被修改。

接收方在验证签名前需要确保它收到的公钥是真实的。通常,您将提供一个包含公钥的证书和证书颁发结构的密钥,该机构将确保密钥的真实性。

证书

证书一般包含:

  • 公钥
  • 证书所属实体(个人、公司等)的“可识别名称”的信息。该实体也叫做证书主体或证书所有者。可识别名称包括以下属性(或子集):实体的名称、组织单元、组织、城市或地区、州或省以及国家代码。
  • 数字签名。证书由发行者签名,以保证所包含的公钥是证书所属实体的实际公钥。
  • 证书发行方的可识别名称。

接收方检查证书是否有效的一种方法是使用发行方的公钥验证数字签名。该密钥本身可以存储在一个证书中,该证书的签名也可以通过使用下一个证书颁发者的公钥进行验证,该密钥依然可以存储在另一个证书中,依此类推。直到获取到您信任的公钥,就可以停止迭代并使用该密钥来验证证书的签名。

如果接收方无法建立信任链,还可以使用keytool -import或-printcert命令计算证书指纹。指纹是一个相对较短的数字,它惟一且可靠地标识证书。(从技术上讲,指纹是证书信息的散列值,使用消息摘要函数。)然后,接收方可以和证书所有者沟通,并将收到的证书的指纹值与发送的证书指纹值进行比较。如果指纹相同,证书就是可信的。

通过以上两种方式您可以确保证书在传输过程中没有被修改。但使用证书另一个潜在的不确定性是发送者的身份。有时证书是自签名的,就是说使用证书中与公钥对应的私钥进行签名,证书发行方与证书所有者是同一个。

自签名证书对于开发和测试应用程序非常有用。但是,在部署应用程序给用户使用之前,要从可信的第三方(称为认证机构)获得证书。您需要向CA发送一个自签名证书签名请求(CSR)。CA可能会通过检查您的驾照或其他信息来验证CSR上的签名和您的身份。验证通过之后,CA使用自己的私钥对颁发给您的证书进行签名来保证您是公钥的所有者。任何信任CA公钥的人都可以验证证书上的签名。在许多情况下,CA自身拥有一个在证书等级体系中更高一级的CA证书,这称之为证书链。

您信任的证书通常作为“受信证书”导入密钥库。然后,可以使用每个证书中的公钥来验证之前使用相应私钥生成的签名。这种检查可通过下列方式完成:

  • jarsigner工具(如果文档、代码和签名出现在JAR文件中)
  • Java Security API
  • 在运行时系统中,尝试进行资源访问,并且拥有真实签名的策略文件授权应用程序可以对该资源进行访问。应用的类文件和签名必须在JAR文件中。

如果要将已签名的代码或文档发送给其他人,则需要向他们提供包含公钥(与签名代码/文档的私钥对应的公钥)的证书。使用 keytool -export 命令或API方法可以将证书从密钥库导出到一个文件,该文件可以发送给任何需要它的人。接收到证书的人可以使用API方法或keytool -import 命令将证书作为受信任的证书导入密钥库。

如果使用jarsigner工具为JAR文件生成签名,该工具将从密钥库检索证书及其支持的证书链。然后将它们连同签名一起存储在JAR文件中。

密钥库

私钥及其相关的公钥证书存储在密钥库中,密钥库是基于密码保护的数据库。密钥库可以包含两种类型的条目:上面讨论的可信证书条目和密钥/证书条目:每一种都包含私钥和相应的公钥证书。密钥库中的每个条目都由别名来标识。

密钥库所有者可以在密钥库中拥有多个密钥,通过别名进行访问。别名通常用角色来命名,这个角色是指密钥库所有者使用该密钥的特定场景。别名可以标识秘钥的用途。例如,别名signPersonalEmail用于标识一个条目,该条目的私钥用于签名个人电子邮件;别名signJarFiles用来标识另一个条目,该条目的私钥用于签名JAR文件。

keytool 工具可以用来

  • 创建私钥以及相应的公钥证书
  • 向合适的证书颁发机构发出证书请求
  • 导入您联系的认证颁发结构回复的证书请求
  • 将公钥证书导入受信证书密钥库

还可以使用API方法访问和修改密钥库。

工具和API说明

请注意以下与数字签名相关的工具和API的使用。

  • 您可以使用JDK Security API、工具或组合来生成密钥和签名并导入证书。您可以使用这些API或工具的特性与他人安全地交换文档。
  • 要使用这些工具进行文档交换,必须将文档放在JAR文件中,该文件可以由JAR工具创建。
  • 如果要创建将要签名的applet代码,则需要将其放在JAR文件中。如果您想创建运行在安全管理器下的应用程序代码,那么也需要将其放在JAR文件中。您需要JAR文件的原因是当策略文件指定只有由特定实体签名的代码可以执行一个或多个操作,比如对特定文件的读写,代码被要求来自于签名的JAR文件。(术语“已签名代码”是“已签名JAR文件中出现的类文件中的代码”的缩写。)
  • 为了让运行时系统检查代码签名,运行代码的人/组织首先需要将验证公钥的证书导入到密钥库中,该公钥与用于签名代码的私钥相对应。
  • 为了让jarsigner工具验证JAR文件签名的真实性,接收JAR文件的人/组织首先需要将证书导入到他们的密钥库中,该证书将提供公钥(与签名代码的私钥对应的公钥)进行身份验证。
  • 目前还没有用于创建证书的api。
使用JDK Security API签名文档

生成和验证签名 向您展示了如何使用JDK Security API对文档进行签名。该课展示由拥有原始文档的人执行的程序将会做:

  • 生成秘钥
  • 使用私钥对文档生成数字签名
  • 导出公钥和数字签名

然后,它展示由数据、签名和公钥的接收者执行的另一个程序的示例。程序是这样运行的:

  • 导入公钥
  • 验证签名的真实性

该课还将向您展示导入和提供密钥(包括证书)的其他方法。

使用工具来签名代码或文档

代码签名并授予IT权限一课展示了如何使用Java安全工具将代码放入JAR文件中、签名并导出公钥。然后它展示了您的接收方如何使用同样的Java安全工具导入您的公钥证书,向策略文件添加一个条目,该条目将授予您的代码访问由接收方控制的系统资源所需的权限。

文件交换一课介绍了如何使用Java安全工具对文档签名,使用keytool导出公钥证书。该公钥对应于使用keytool对文档签名使用的私钥。然后,它显示了您的收件人如何通过安装您的公钥证书,再使用jarsigner工具来验证您的签名。

这两个课程有很多共同之处。在这两种情况下,代码或文件发送者的前两个步骤是:

  • 使用JAR工具创建包含文档或类文件的JAR文件。
  • 使用keytool -genkey 命令生成密钥(如果它们还不存在)。

接下来的两步是可选的:

  • 使用keytool -certreq 命令将生成的证书签名请求发送给认证机构(CA),如VeriSign。
  • 使用keytool -import 命令导入CA的响应。

接下来的两步是必要的:

  • 使用jarsigner工具和前面生成的私钥对JAR文件签名。
  • 使用keytool -export 命令导出公钥证书。然后将签名的JAR文件和证书提供给接收方。

在这两种情况下,已签名JAR文件和证书的接收者都应该使用keytool -import 命令将证书作为受信任证书导入。keytool 将尝试从导入的证书到密钥库中已受信任的证书之间构造一个信任链。如果失败,keytool将显示证书指纹并提示您进行验证。

如果发送的是代码,则接收方还需要修改策略文件,对导入证书中的公钥对应的私钥所签名的代码访问所需的资源予以授权。可以使用 Policy Tool 来实现这一点。

如果发送的是文档,那么接收者需要使用 jarsigner 工具验证JAR文件签名的真实性。

本课讨论两个可选步骤。接下来的两节课将介绍其他步骤,代码签名并授予IT权限文件交换

为公钥证书生成一个证书签名请求(CSR)

当 keytool 用于生成公钥/私钥对时,它将创建一个包含私钥和公钥自签名证书的密钥库条目。在开发和测试应用程序时,这已经足够了。

如果证书是由认证机构(CA)颁发的,那么它更有可能被其他人信任。要获得由CA签名的证书,您首先通过以下命令生成证书签名请求(CSR):

keytool -certreq -alias alias -file csrFile

这里 -alias 用于访问包含私钥和公钥证书的密钥库条目,csrFile指定此命令创建的CSR的名称。

将该文件提交给CA,如VeriSign, Inc。CA对请求者进行身份验证,然后签名并返回验证公钥的证书。通过签署证书,CA保证您是公钥的所有者。

在有些情况下,CA将返回一个证书链,每个证书都对链中前一个证书的签名者的公钥进行身份验证。

导入CA应答

向认证机构(CA)提交证书签名请求(CSR)后,需要导入CA返回给您的证书(或证书链),将密钥存储库中的原始自签名证书替换为证书链。

首先需要在密钥存储库中(或在cacerts密钥存储库文件中,如下所述)有一个“可信证书”条目来验证CA的公钥。有了这样一个条目,CA的签名就可以得到验证。也就是说,可以验证CA在证书上的签名,或者CA响应CSR发送给您的链中的最终证书上的签名。

导入CA颁发的证书作为受信证书

在导入CA应答证书之前,您需要在密钥库或cacerts文件中包含一个或多个“受信任证书”。

  • 如果证书应答是一个证书链,则只需要该链的顶部证书——验证该CA公钥的“根”CA证书。
  • 如果证书应答是一个证书,则需要CA颁发结构的证书(签署证书的CA)。如果该证书不是自签名的,则需要为其签名者提供一个证书,以此类推,直到自签名的“根”CA证书为止。

cacerts 文件表示CA证书的系统密钥存储库。该文件位于JRE安全属性目录java.home/lib/security。java.home是JRE安装目录。

cacerts 文件包含许多受信任的CA证书。如果您将CSR发送给这些受信任的供应商之一(例如VeriSign),不需要将供应商的根证书作为受信任证书导入密钥库;您可以到下一节,了解如何从CA应答导入证书。

来自CA的证书通常要么是自签名的,要么是由另一个CA签名的,在这种情况下,还需要一个证书来验证CA的公钥。假设ABC公司是一个CA,并且您获得了一个名为ABCCA.cer的文件,该文件自称是来自ABC的自签名证书,用于验证CA的公钥。

在将证书导入为“受信任证书”之前,要非常小心地确保该证书是有效的!首先要查看它(使用keytool -printcert 命令或使用没有-noprompt选项的 keytool -import 命令),并确保所显示的证书指纹匹配预期的指纹。您可以联系发送证书的人,并将您看到的指纹与他们提供的指纹或安全公钥存储库显示的指纹进行比较。只有当指纹相等时,才能保证证书在传输过程中没有被其他人(例如攻击者)的证书替换。如果发生了这样的攻击,并且您在导入证书之前没有检查证书,那么您将信任攻击者所签名的任何内容。

如果您相信证书是有效的,您可以通过以下命令将其添加到密钥存储库:

keytool -import -alias alias -file ABCCA.cer -keystore storefile

该命令将在密钥存储库中创建一个“受信任证书”仓库,仓库名称通过storefile指定,该仓库包含的内容来自于ABCCA.cer并通过别名alias指定它的条目别名。

导入来自于CA的证书应答

如前一节所述,一旦导入所需的可信证书,或者它们已经存在于密钥存储库或cacerts文件中,就可以导入证书应答,从而用证书链替换自签名证书。这个证书链可能是CA应答您的CSR证书链,或者是通过证书应答与已经存在于密钥库或cacerts文件中的受信证书构造的证书链。

例如,假设您将CSR发送给VeriSign。您可以通过以下方式导入证书应答,假设返回的证书在certReplyFile指定的文件中:

keytool -import -trustcacerts -keystore storefile -alias alias -file certReplyFile

证书应答通过使用密钥存储库中的可信证书进行验证,还可以选择使用在cacerts密钥存储库文件中配置的证书进行验证(如果指定了-trustcacerts选项)。使用链中更高级别的证书验证链中的每个证书。您只需要信任链中的顶级“根”CA证书。如果您不信任顶级证书,keytool将显示该证书的指纹,并询问您是否希望信任它。

通过别名指定条目的新证书链将替换旧证书链。只有提供有效的keypass(用于保护条目私钥的密码),才能替换旧链。如果没有提供密码,并且私钥密码与密钥存储库密码不同,则会提示用户输入密码。

有关生成CSR和导入证书应答的详细信息,请参阅keytool文档:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
********************************* * 网络文件交换工具 v1.0 * 帮助文件 * 作者: 懒猫 * email: kfzd@sina.com ********************************* (目录) 1.介绍 2.版权声明 3.使用指南 4.历史 5.关于作者 ======================================================== 1.介绍 该程序可以让两台计算机通过局域网或互联网传送文件。 它的功能类似于ftp的服务器和客户端,但是操作及其简单, 同时由于加入了数据压缩和加密功能,使得在网络上的文件传送 更快速、更安全。 其具体功能和特点如下: * 既可以传送文件给对方,又可以接收对方的文件 (集服务器和客户机于一身) * 可以查看对方的下载目录中的文件列表 * 可以下载对方的下载目录中的文件 * 可以选择不同的压缩方式进行数据传输 * 可以根据网络状况,选择文件传送时的数据包大小 * 可以自定义接收端口 * 支持地址簿功能,可以将你的朋友和同事的服务器信息方便 的收录进去 使用限制 * 一次只能传送或下载一个文件 ======================================================== 2.版权声明 网络文件交换工具由懒猫开发、维护,并保留所有权利。 它是一个免费软件,你可以自由的下载、使用和分发该软件。 目前不开放源代码。 如果有bug或改进建议,请你用email告诉我,同时可以将 错误日志发给我(在安装目录的log目录下),我将十分感激。 ======================================================== 3.使用指南 A.如何将自己的机器作为服务器? 按下[启动接收服务]按钮即可。如果该按钮已经变为不可按下,则表示 接收服务已经启动了。你可以在标题栏看到这一点。 B.如何发送文件到对方的电脑? 首先,输入对方的<;;;IP地址>;;;和<;;;对方端口号>;;;。或者直接选择通讯录中 的地址也可以。 然后,在<;;;文件名>;;;一栏中填写要发送的文件名称,或者点击[...]按钮 浏览选取文件。 最后,按下[发送文件]按钮即可。 C.如何查看对方计算机上有哪些文件可以下载? 首先,输入对方的<;;;IP地址>;;;和<;;;对方端口号>;;;。或者直接选择通讯录中 的地址也可以。 然后,点击[下载目录]按钮,就可以看到了。 D.如何下载对方计算机上的文件? 首先,需要下载对方的文件目录。 然后,选取一个可以下载的文件。 最后,按[开始下载]按钮即可 E.如何设置参数 首先,点击{设置}页签,进入设置功能界面, 然后,设置相应的参数 最后,按[保存设置]按钮。 F.如何设置通讯录 你可以直接填写地址簿,填写格式为:机器名=IP地址,接收端口号 例如:你的朋友的名为tommy,他的IP地址是192.168.0.1,采用的是默认端口6666 那么你就可以填写 tommy=192.168.0.1,6666 切记,设置完成后,请按[保存设置]按钮 G.请谨慎使用数据压缩功能 在设置项目中有一项是“数据压缩率”,共有4级选项,分别是: 数据压缩率: 0-不压缩 1-快速压缩 2-正常压缩 3-最大压缩 系统的默认选项是0-不压缩。 如果您经常要传送一些文本文件或ms office文档,请选用适当地压缩率 进行压缩。 特别注意:如果您要传送大文件(大于10M),请将数据压缩率置为0-不压缩。 因为如果您的机器配置较低,会造成压缩时间过长的“假死机”现象。 ======================================================== 4.历史 2002/10/22 开始进行设计 2002/11/02 开始动手编写 2002/11/10 推出v0.1版本,并在朋友间测试 2002/11/20 推出v0.4版本,加入下载目录和文件功能 2002/11/24 推出v0.6版本,加入压缩功能 2002/12/02 推出v0.8版本,修改了通讯协议 2002/12/10 推出v0.9版本,修改了小bug 2002/12/30 推出v1.0版本,将原来保存传送数据的内存流方式,改为 文件流方式,从而避免了传送大文件因占用过多内存造成 的死机现象。 ======================================================== 5.关于作者 作者懒猫,是一个普通的程序员,戴着深度眼睛,有着粗粗的腰围和薄薄的荷包。 目前住在上海,喜欢看电影、影碟(D版)和古龙的小说,你可以用以下email联系我 kfzd@sina.com 曾经有N个个人网站,但都被停掉了,呵呵。 http://www.liysoft.com/download/fe.exe ========================================================
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值