@linux系统SSL证书转换(Openssl转换PFX)

在Linux中,你可以使用OpenSSL工具将PFX/P12格式的证书转换为单独的CRT(证书)、KEY(私钥)文件以及提取证书链

1. 提取私钥文件(.key)

bash 复制代码
openssl pkcs12 -in your_certificate.pfx -nocerts -out private.key -nodes

系统会提示你输入PFX文件的密码。

2. 提取证书文件(.crt)

bash 复制代码
openssl pkcs12 -in your_certificate.pfx -clcerts -nokeys -out certificate.crt

3. 提取证书链(如果有)

bash 复制代码
openssl pkcs12 -in your_certificate.pfx -cacerts -nokeys -out chain.crt

4. (可选) 将私钥转换为无密码格式

如果私钥有密码保护而你想移除密码:

bash 复制代码
openssl rsa -in private.key -out private_unencrypted.key

5. (可选) 验证提取的文件

验证私钥和证书是否匹配:如果两个命令输出的MD5值相同,则表示匹配。

bash 复制代码
openssl x509 -noout -modulus -in certificate.crt | openssl md5
openssl rsa -noout -modulus -in private.key | openssl md5

参数说明:

bash 复制代码
-in your_certificate.pfx:指定输入的PFX文件

-nocerts:不输出证书,只输出私钥

-nokeys:不输出私钥,只输出证书

-nodes:不加密私钥

-clcerts:只输出客户端证书(不输出CA证书)

注意事项:

  1. 确保在安全的环境中操作,因为私钥是敏感信息
  2. 如果PFX文件有密码保护,上述命令会提示你输入密码
  3. 某些情况下,证书链可能已经包含在.crt文件中,不需要单独提取
  4. 你可以使用-password pass:yourpassword参数来避免交互式密码输入(不推荐用于生产环境)

完整示例:

bash 复制代码
# 提取私钥
openssl pkcs12 -in example.pfx -nocerts -out example.key -nodes

# 提取主证书
openssl pkcs12 -in example.pfx -clcerts -nokeys -out example.crt

# 提取证书链
openssl pkcs12 -in example.pfx -cacerts -nokeys -out chain.crt

# 合并证书和证书链(某些服务器需要)
cat example.crt chain.crt > fullchain.crt
相关推荐
Juicedata13 分钟前
JuiceFS v1.3-Beta2:集成 Apache Ranger,实现更精细化的权限控制
运维·人工智能·ai
IT成长日记23 分钟前
05【Linux经典命令】Linux 用户管理全面指南:从基础到高级操作
linux·运维·服务器·用户管理·命令
资讯第一线4 小时前
Windows系统工具:WinToolsPlus 之 SQL Server Suspect/质疑/置疑/可疑/单用户等 修复
运维
惊起白鸽4505 小时前
LVS负载均衡
运维·负载均衡·lvs
Sapphire~6 小时前
Linux-07 ubuntu 的 chrome 启动不了
linux·chrome·ubuntu
伤不起bb6 小时前
NoSQL 之 Redis 配置与优化
linux·运维·数据库·redis·nosql
广东数字化转型7 小时前
nginx怎么使用nginx-rtmp-module模块实现直播间功能
linux·运维·nginx
love530love7 小时前
【笔记】在 MSYS2(MINGW64)中正确安装 Rust
运维·开发语言·人工智能·windows·笔记·python·rust
啵啵学习7 小时前
Linux 里 su 和 sudo 命令这两个有什么不一样?
linux·运维·服务器·单片机·ubuntu·centos·嵌入式
半桔7 小时前
【Linux手册】冯诺依曼体系结构
linux·缓存·职场和发展·系统架构