data:image/s3,"s3://crabby-images/c5e3f/c5e3f872e36ec5fb2dc0a569067ce4e7031e27ad" alt=""
This article has not been completed yet. However, it may already contain helpful Information and therefore it has been published at this stage.
CSR properties:
Common Name (CN) | The Fully Qualified Domain Name (FQDN). e.g. *.example.com, www.example.com, and mail.example.com. |
---|---|
Organization (O) | The legal name of your organization. Do not abbreviate and include any suffixes, such as Inc., Corp., or LLC. |
Organizational Unit (OU) | The division of your organization handling the certificate. |
City/Locality (L) | The city where your organization is located. This shouldn’t be abbreviated. |
State/County/Region (S) | The state/region where your organization is located. This shouldn’t be abbreviated. |
Country (C) | The two-letter code for the country where your organization is located. |
Email Address | An email address used to contact your organization. |
# Checking Version
openssl version -a
data:image/s3,"s3://crabby-images/49e0c/49e0c991687ae44285524706d0ff7a2523e968c9" alt=""
# Installing OpenSSL
sudo apt install openssl
data:image/s3,"s3://crabby-images/50073/5007391dab4a1c935a8fef6f8e2fc698af85eee8" alt=""
# CSR - Creation
sudo openssl req -new -newkey rsa:2048 -nodes -keyout <key-file>.key -out <csr-file>.csr
# The command creats two files. (1) .key and (2) .cer.
# Remove "-nodes" in a production environment. It avoids key-encryption
# which is not recommended.
data:image/s3,"s3://crabby-images/d4887/d4887669f7fb9d30c7eff477d170e7eaac537ff1" alt=""
# CSR - Creation based on a Custom Config-File
sudo openssl req -new -newkey rsa:2048 -nodes -keyout <key-file>.key -out <csr-file>.csr -config server_cert.cnf
# The command creats two files. (1) .key and (2) .cer.
# Remove "-nodes" in a production environment. It avoids key-encryption
# which is not recommended.
# Config-File Creation
nano server_cert.cnf
# Content server_cert.cnf
[req_distinguished_name]
countryName = Country Name (2 letter code)
stateOrProvinceName = State or Province Name (full name)
localityName = Locality Name (eg, city)
organizationalUnitName = Organizational Unit Name (eg, section)
commonName = Common Name (eg, your name or your server\'s hostname)
emailAddress = Email Address
[req_ext]
subjectAltName = @alt_names
[alt_names]
IP.1 = <IP>
DNS.1 = <FQDN>
data:image/s3,"s3://crabby-images/ee82b/ee82b0af5cc10aa8a41a548e4a179f227764c437" alt=""
# CSR - Verification
openssl req -text -in <csr-file-name>.csr -noout -verify
data:image/s3,"s3://crabby-images/acdfe/acdfeb59b1659cbef1ac4cb98875f426db98364c" alt=""
References:
How To Create A Certificate Signing Request On A Linux Server?
Steps to generate CSR for SAN certificate with openssl | GoLinuxCloud
Step by step instruction to generate Certificate Signing Request (CSR) for Subject Alternative Name (SAN) certificates using openssl with examples in Linux
data:image/s3,"s3://crabby-images/6f935/6f935809f1d56ecd3c680243778751b2725c01bc" alt=""