No Ubuntu, não consigo converter o certificado usando openssl com sucesso.
vagrant@dev:/vagrant/keys$ openssl pkcs7 -print_certs -in a.p7b -out a.cer
unable to load PKCS7 object <blah blah>:PEM
routines:PEM_read_bio:no start line:pem_lib.c:696:Expecting: PKCS7
Você já viu esse erro antes?
Tente isto:
Se não funcionar, traga para uma máquina Windows e exporte siga este guia.
Então, para combinar as respostas acima, o comando é:
openssl pkcs7 -in cert.p7b -inform DER -print_certs -out cert.pem
Verificado para funcionar no Windows, usando OpenSSL-Win64
/Obrigado Bogdan por identificar o erro
Eu segui este guia que instrui você a alterar as linhas de cabeçalho/rodapé de
para
Em seguida, execute o comando
openssl pkcs7 -in foo.modified.crt -print_certs -out foo.certs
(ondefoo.modified.crt
está o arquivo no qual você salvou a versão modificada). Isso me deu os mesmos resultados da execução por meio de uma exportação de certificado do Windows, conforme sugerido em outras respostas.Até onde eu sei, o seguinte deve converter um certificado pkcs7 em um pem
solução rápida no meu caso (muitos arquivos com cabeçalho/rodapé faltando):
base64 -d $FILE | openssl pkcs7 -inform DER -print_certs
Eu tive esse problema também. Eu ia verificar um arquivo p7b que copiei de um host Win7.
Descobri que o chaveiro do gnome pode importar o certificado. A partir daí é fácil exportar para o DER
openssl pkcs7 -print_certs -in intermedias.p7b -out intermedias.cer
Meu arquivo de origem estava em texto com -----BEGIN PKCS7----- como o cabeçalho... Este método funcionou para mim enquanto outros não.
Se você receber o seguinte erro:
verifique se o conteúdo do p7b está no formato abaixo (
-----BEGIN PKCS7-----
e-----END PKCS7-----
em linhas separadas).Antes da:
Depois:
Convertendo do formato P7B para PFX.