当前位置: 首页 > article >正文

OpenSSL crt key (生成一套用于TLS双向认证的证书密钥)

OpenSSL—— TLS证书

问:如何生成一套TLS证书、密钥呢?

生成一套 TLS 证书,包括 根 CA 证书、服务器证书、客户端证书,可以使用 openssl 命令来完成。完整的步骤如下,包括根 CA、服务器证书和客户端证书的生成。


📌 1. 生成 CA 证书(根证书)

根 CA 证书用于签发服务器和客户端证书,确保它们可以互相验证身份。

# 生成 CA 私钥 (2048-bit)
openssl genrsa -out ca.key 2048

# 生成 CA 证书 (自签名,有效期 10 年)
openssl req -x509 -new -nodes -key ca.key -sha256 -days 3650 -out ca.crt \
    -subj "/C=CN/ST=Beijing/L=Beijing/O=MyCompany/OU=IT Department/CN=MyRootCA"

生成的文件:

  • ca.key → CA 私钥
  • ca.crt → CA 证书(用于签发其他证书)

📌 2. 生成服务器证书

服务器证书用于 TLS 服务器身份认证。

🔹 2.1 生成服务器私钥

openssl genrsa -out server.key 2048

🔹 2.2 生成服务器 CSR(证书签名请求)

openssl req -new -key server.key -out server.csr \
    -subj "/C=CN/ST=Beijing/L=Beijing/O=MyCompany/OU=IT Department/CN=server.example.com"

🔹 2.3 使用 CA 证书签发服务器证书

openssl x509 -req -in server.csr -CA ca.crt -CAkey ca.key -CAcreateserial \
    -out server.crt -days 365 -sha256

生成的文件:

  • server.key → 服务器私钥
  • server.csr → 服务器证书签名请求
  • server.crt → 服务器证书(由 CA 签发)

📌 3. 生成客户端证书

客户端证书用于客户端认证。

🔹 3.1 生成客户端私钥

openssl genrsa -out client.key 2048

🔹 3.2 生成客户端 CSR

openssl req -new -key client.key -out client.csr \
    -subj "/C=CN/ST=Beijing/L=Beijing/O=MyCompany/OU=IT Department/CN=client.example.com"

🔹 3.3 使用 CA 证书签发客户端证书

openssl x509 -req -in client.csr -CA ca.crt -CAkey ca.key -CAcreateserial \
    -out client.crt -days 365 -sha256

生成的文件:

  • client.key → 客户端私钥
  • client.csr → 客户端证书签名请求
  • client.crt → 客户端证书(由 CA 签发)

📌 4. 证书验证

🔹 4.1 验证服务器证书

openssl verify -CAfile ca.crt server.crt

如果成功,输出:

server.crt: OK

🔹 4.2 验证客户端证书

openssl verify -CAfile ca.crt client.crt

如果成功,输出:

client.crt: OK

📌 5. 证书使用

  • 服务器 需要 server.keyserver.crt 进行 TLS 连接,并且需要 ca.crt 验证客户端证书。
  • 客户端 需要 client.keyclient.crt 进行 TLS 连接,并且需要 ca.crt 验证服务器证书。

📌 6. 示例:使用 OpenSSL 进行双向 TLS 认证

🔹 服务器端

openssl s_server -accept 4059 -cert server.crt -key server.key -CAfile ca.crt -verify 1

🔹 客户端

openssl s_client -connect 127.0.0.1:4059 -cert client.crt -key client.key -CAfile ca.crt

📌 总结

证书/密钥作用
ca.key根 CA 私钥
ca.crt根 CA 证书,用于签发其他证书
server.key服务器私钥
server.crt服务器证书(CA 签发)
server.csr服务器证书签名请求
client.key客户端私钥
client.crt客户端证书(CA 签发)
client.csr客户端证书签名请求

该过程完整生成了一套 CA 证书、服务器证书、客户端证书,适用于 TLS 服务器与客户端双向认证。

请添加图片描述


http://www.kler.cn/a/556715.html

相关文章:

  • vue-指令
  • 自然语言处理NLP 04案例——苏宁易购优质评论与差评分析
  • w220周边游平台设计与实现
  • 力扣-回溯-39 组合总和
  • Python 单例模式笔记
  • HarmonyOS NEXT 开发者进阶指南(基于API 12+理论解析)
  • 《Python实战进阶》专栏 No.3:Django 项目结构解析与入门DEMO
  • 如何优化Spark作业的性能
  • 网络通信中的TCP三次握手与四次挥手:新手小白的入门指南
  • OpenHarmony AI业务子系统
  • ncDLRES:一种基于动态LSTM和ResNet的非编码RNA家族预测新方法
  • 【git】合并多个提交记录
  • 【C/C++】合并两个有序链表 (leetcode T21)
  • 【ELK】【Elasticsearch】数据查询方式
  • 排序与算法:插入排序
  • EasyRTC:基于WebRTC与P2P技术,开启智能硬件音视频交互的全新时代
  • 安全面试1
  • 【Python】打造自己的HTTP server
  • OpenGauss MySQL兼容库迁移
  • Java 中 HTTP 协议版本使用情况剖析