data:image/s3,"s3://crabby-images/05b45/05b4522663e695f304461460fe748ff74269b3ac" alt=""
This article has not been completed yet. However, it may already contain helpful information and therefore it has been published at this stage.
data:image/s3,"s3://crabby-images/53bd9/53bd9ed465b57391486db06bc3a08a9a01c74fc6" alt=""
PEM
PEM ("Privacy Enhanced Mail") is the common format for X.509 certificates, CSRs ("Certificate Signing Request"), and cryptographic keys. A PEM file is a text file containing one or more items in Base64 ASCII encoding, each with plain-text headers and footers (e.g. -----BEGIN CERTIFICATE-----
and -----END CERTIFICATE-----
). A single PEM file could contain an end-entity certificate, a private key, or multiple certificates forming a complete chain of trust.
PEM Filename Extensions
PEM files are usually seen with the extensions .crt
, .pem
, .cer
, and .key
(for private keys)
# You can read the contents of a PEM certificate (<file>.cer) using the
# 'openssl' command on Linux or Windows as follows:
openssl x509 -in <file>.cer -text
data:image/s3,"s3://crabby-images/7c39e/7c39ec053690fbabec78ff9e0ae8222009a077bd" alt=""
DER
DER ("Distinguished Encoding Rules") is a binary encoding for X.509 certificates and private keys. Unlike PEM, DER-encoded files do not contain plain text statements such as -----BEGIN CERTIFICATE-----
. DER files are most commonly seen in Java contexts.
DER Filename Extensions
DER-encoded files are usually found with the extensions .der
and .cer
.
# You can't read the contents of a DER certificate (<file>.der) in the
# way as descriped for the PEM certificat. You will get an error if you do so:
openssl x509 -in <file>.cer -text
data:image/s3,"s3://crabby-images/772b1/772b152390ff9a5bf87e1dcbcf767b6b10407f33" alt=""
# You have to use the following 'openssl' command:
openssl x509 -inform der -in <file>.der -text -noout
data:image/s3,"s3://crabby-images/4a7be/4a7bec7eac717210faf0b8ce3d67497154050c9a" alt=""
P7B
PKCS#7 (also known as P7B) is a container format for digital certificates that is most found in Windows and Java server contexts, and usually has the extension .p7b
. PKCS#7 files are not used to store private keys. In the example below, you can see that the PB7- file contains 3 certificates (in this case a complete chain - the server - , intermediate - and root - certificate).
data:image/s3,"s3://crabby-images/0d03a/0d03a34425ee71efb977b10629dc39b50e4e94bb" alt=""
# You can read the contents of a PB7 File (<file>.pb7) using the
# 'openssl' command on Linux or Windows as follows:
openssl pkcs7 -print_certs -in <file>.p7b
data:image/s3,"s3://crabby-images/708d0/708d043ee1f8d9aafbb554d4010a25e2766723be" alt=""
PFX
PKCS#12 (also known as PKCS12 or PFX) is a common binary format for storing a certificate chain and private key in a single, encryptable file, and usually have the filename extensions .p12
or .pfx
.
# You can read the contents of a PFX File (<file>.pfx) using the
# 'openssl' command on Linux or Windows as follows:
openssl pkcs12 -info -in <file>.pfx
data:image/s3,"s3://crabby-images/657c8/657c8e0312f8c2cbffbc4d0c48c21d7cfcef46c3" alt=""
Certificate conversion
# Conversion of PKCS#12 ( .pfx .p12, typically used on Microsoft Windows)
# files with private key and certificate to PEM (typically used on Linux):
openssl pkcs12 -nodes -in <file>.pfx -out <file>.crt
data:image/s3,"s3://crabby-images/86519/8651935bd1441f15ec7961e9bb6b7efcda1dc66b" alt=""
# PKCS#12 Key Extraction
openssl pkcs12 -in <file>.pfx -out <file>.key -nodes -nocerts
data:image/s3,"s3://crabby-images/31294/312943e0b1b1ba0ea8d4fb63434498f977b79237" alt=""
# Conversion of PEM to PKCS#12:
openssl pkcs12 -export -in <file>.crt -inkey <file>.key -out <file>.pfx
data:image/s3,"s3://crabby-images/8f1ba/8f1ba63e2f7d8d455fddd3b33f893070100bf381" alt=""
# Conversion of PKCS#7 format ( .p7b .p7c ) to PEM:
openssl pkcs7 -print_certs -in <file>.p7b -out <file>.cer
data:image/s3,"s3://crabby-images/068ca/068cac4559127c9d8b1e5d083b0a1f44a7295e4e" alt=""
# Conversion of PEM format to PKCS#7:
openssl crl2pkcs7 -nocrl -certfile <file>.crt -out <file>.p7b
data:image/s3,"s3://crabby-images/65dcb/65dcb8d91c0a9f0d9d5567e7988881e9166b8fbe" alt=""
# Conversion of DER (.crt .cer or .der) to PEM:
openssl x509 -inform der -in <file>.der -out <file>.pem
data:image/s3,"s3://crabby-images/9c0b7/9c0b7ae1b194d35d91bac45d0cd758cc7b6b5559" alt=""
# Conversion from PEM to DER format:
openssl x509 -outform der -in certificate.pem -out certificate.cer
data:image/s3,"s3://crabby-images/e42c4/e42c466fa3e7ec784794c2c76e1c6f630fe3067b" alt=""
References:
data:image/s3,"s3://crabby-images/4bb19/4bb190375376270160b051c84672f010aa99167a" alt=""
data:image/s3,"s3://crabby-images/028e3/028e31591c0da69808b0ef17e5d8350ca60cb0aa" alt=""
PEM, DER, CRT, and CER: X.509 Encodings and Conversions
What Is an X.509 Certificate?
data:image/s3,"s3://crabby-images/26d6b/26d6bdbbc1c34c371fe17ebaaaa7ed9b8ca0bf84" alt=""