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 格式,会看到乱码
相关推荐
独自破碎E2 小时前
【滑动窗口+字符计数数组】LCR_014_字符串的排列
android·java·开发语言
AI逐月2 小时前
tmux 常用命令总结:从入门到稳定使用的一篇实战博客
linux·服务器·ssh·php
想逃离铁厂的老铁2 小时前
Day55 >> 并查集理论基础 + 107、寻找存在的路线
java·服务器
Jack_David2 小时前
Java如何生成Jwt之使用Hutool实现Jwt
java·开发语言·jwt
瑞雪兆丰年兮2 小时前
[从0开始学Java|第六天]Java方法
java·开发语言
小白跃升坊2 小时前
基于1Panel的AI运维
linux·运维·人工智能·ai大模型·教学·ai agent
一点技术2 小时前
基于SpringBoot的选课调查系统
java·spring boot·后端·选课调查系统
datalover2 小时前
CompletableFuture 使用示例
java·开发语言
跃渊Yuey2 小时前
【Linux】线程同步与互斥
linux·笔记