openssl将证书从p7b转换为crt格式

主要作用

将 Windows 系统导出的 PKCS#7 格式证书链文件(.p7b)转换为 Linux 系统可用的 PEM 格式证书文件(.crt)

bash 复制代码
openssl pkcs7 -inform DER -print_certs -in certnew.p7b -out Linuxcert.crt

命令结构分解:

复制代码
openssl pkcs7          # 使用 OpenSSL 的 PKCS#7 工具
-inform DER            # 指定输入文件格式为 DER(二进制格式)
-print_certs           # 打印/提取证书内容
-in certnew.p7b        # 输入文件名
-out Linuxcert.crt     # 输出文件名

常见相关操作:

1. 查看证书内容
bash 复制代码
# 查看提取的证书
openssl x509 -in Linuxcert.crt -text -noout

# 查看第一个证书
openssl x509 -in Linuxcert.crt -text -noout
2. 分离证书链中的各个证书
bash 复制代码
# 将证书链拆分为单独的文件
csplit -z Linuxcert.crt '/-----BEGIN CERTIFICATE-----/' '{*}'
# 会生成多个文件:xx00, xx01, xx02 等
3. 验证证书链
bash 复制代码
# 验证证书链的完整性
openssl verify -CAfile ca-bundle.crt Linuxcert.crt

格式对比:

格式 编码 可读性 文件开头 常见扩展名
DER 二进制 不可读 二进制数据 .der, .cer, .p7b
PEM Base64 可读 -----BEGIN... .pem, .crt, .cer

诊断命令:

bash 复制代码
# 检查文件类型
file certnew.p7b

# 如果是 DER 格式,应该显示:data
# 如果是 PEM 格式,应该显示:ASCII text

# 查看文件前几行
head -n 3 certnew.p7b

# 如果是 PEM 格式,会看到:-----BEGIN PKCS7-----
# 如果是 DER 格式,会看到乱码
相关推荐
bush417 小时前
嵌入式linux学习记录七,中断
linux·嵌入式
RisunJan17 小时前
Linux命令-nologin(用于系统账户或需要禁止交互式登录的场景)
linux·运维
是阿建吖!17 小时前
【Linux】信号
android·linux·c语言·c++
城北徐宫17 小时前
Linux信号深度解剖:5种产生、3张表、4次切换
linux·c++·学习
倔强的石头10617 小时前
【Linux指南】Linux快捷键与系统实用技巧
linux·运维·服务器
番茄地瓜17 小时前
Linux 配置静态 IP 步骤
linux·运维·服务器
liulilittle17 小时前
论 Linux 内核态全局稳态带宽的卡尔曼估计与工程实现
linux·服务器·网络·c++·计算机网络·tcp·通信
Irissgwe18 小时前
五、应用层协议HTTP
linux·网络·网络协议·http·状态码·url
心之伊始18 小时前
Java 后端接入大模型:从 Token、并发到推理成本的完整估算方法
java·spring boot·性能优化·大模型·llm
.千余18 小时前
【Linux】 传输层协议UDP:从端口号到传输机制
linux·运维·udp