ssl什么是公钥和私钥?

公钥(Public Key)与私钥(Private Key)是通过加密算法得到的一个密钥对(即一个公钥和一个私钥,也就是非对称加密方式)。公钥可对会话进行加密、验证数字签名,只有使用对应的私钥才能解密会话数据,从而保证数据传输的安全性。公钥是密钥对外公开的部分,私钥则是非公开的部分,由用户自行保管。

通过加密算法得到的密钥对可以保证在世界范围内是唯一的。使用密钥对的时候,如果用其中一个密钥加密一段数据,只能使用密钥对中的另一个密钥才能解密数据。例如:用公钥加密的数据必须用对应的私钥才能解密;如果用私钥进行加密也必须使用对应的公钥才能解密,否则将无法成功解密。

SSL证书的原理

SSL证书采用公钥体制,即利用一对互相匹配的密钥对进行数据加密和解密。每个用户自己设定一把特定的、仅为本人所知的私有密钥(私钥),并用它进行解密和签名;同时设定一把公共密钥(公钥)并由本人公开,为一组用户所共享,用于加密和验证签名。

由于密钥仅为本人所有,可以产生其他人无法生成的加密文件,也就是形成了数字签名。

SSL证书是一个经证书授权中心(CA)数字签名的、包含公开密钥拥有者信息以及公开密钥的文件。最简单的证书包含一个公开密钥、名称以及证书授权中心的数字签名。数字证书还有一个重要的特征就是只在特定的时间段内有效。

创建私钥

阿里云SSL证书服务对您私钥的加密算法和长度要求如下。

  • 加密算法使用RSA算法

  • 加密长度至少2,048位

您可以通过以下两种方式创建您的私钥。

  • 使用OpenSSL工具生成私钥

    1. 您可以从 OpenSSL官网网站 下载最新的OpenSSL工具安装包。

      说明

      OpenSSL版本必须是1.0.1g或以上版本。

    2. 安装OpenSSL工具后,在命令行模式下运行openssl genrsa -out myprivate.pem 2048生成您的私钥文件。生成后的私钥文件名称为myprivate.pem,加密长度为2,048。

  • 使用Keytool工具生成并导出私钥

    Keytool工具是JDK中自带的密钥管理工具,可以制作Keystore(jks)格式的证书文件,您可以从 官方地址 下载JDK工具包来获取Keytool工具。

    由于使用Keytool工具制作的公钥和私钥默认是不可以导出的,您需要从已经创建好的.keystore文件中导出私钥。

    在导出的文件中,以下部分的内容即是您的私钥:

    -----BEGIN RSA PRIVATE KEY-----
    ......
    -----END RSA PRIVATE KEY-----

    或者

    -----BEGIN PRIVATE KEY-----
    ......
    -----END PRIVATE KEY-----

    说明

    无论您通过哪种方式生成密钥,请您妥善地保管好您的私钥文件。私钥文件一旦丢失或者损坏,您申请的公钥及数字证书将无法使用。

相关推荐

  1. ssl什么

    2023-12-08 10:36:03       46 阅读
  2. 怎么验证一对

    2023-12-08 10:36:03       40 阅读
  3. SSH的使用

    2023-12-08 10:36:03       15 阅读
  4. php 函数 三

    2023-12-08 10:36:03       34 阅读
  5. SSL生成/证书 各种格式

    2023-12-08 10:36:03       23 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-08 10:36:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-08 10:36:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-08 10:36:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-08 10:36:03       18 阅读

热门阅读

  1. Gateway:微服务架构中的关键组件

    2023-12-08 10:36:03       39 阅读
  2. 什么是https加密协议

    2023-12-08 10:36:03       45 阅读
  3. 代码随想录-刷题第二十天

    2023-12-08 10:36:03       44 阅读
  4. 【WPF】弹出一个弹窗并显示一个列表

    2023-12-08 10:36:03       42 阅读
  5. C++异常

    C++异常

    2023-12-08 10:36:03      29 阅读
  6. 芯知识 | 如何选择合适的单片机语音芯片?

    2023-12-08 10:36:03       51 阅读
  7. Narayana 事务 begin 流程

    2023-12-08 10:36:03       29 阅读
  8. Docker快速入门(编译源码辅助技)

    2023-12-08 10:36:03       40 阅读
  9. 数组实现循环队列(新增一个空间)

    2023-12-08 10:36:03       44 阅读
  10. 【数据结构】并查集算法总结

    2023-12-08 10:36:03       42 阅读
  11. extern “C“使用方法__演变过程

    2023-12-08 10:36:03       40 阅读
  12. swiper和video实现抖音刷视频功能

    2023-12-08 10:36:03       43 阅读
  13. Django的回顾的第4天

    2023-12-08 10:36:03       25 阅读
  14. Django二转Day06

    2023-12-08 10:36:03       33 阅读