it-wiki:ssl:openssl
Unterschiede
Hier werden die Unterschiede zwischen zwei Versionen angezeigt.
Beide Seiten der vorigen RevisionVorhergehende ÜberarbeitungNächste Überarbeitung | Vorhergehende Überarbeitung | ||
it-wiki:ssl:openssl [2017/08/31 18:34] – [Die Zertifikate nutzen] marko | it-wiki:ssl:openssl [2024/03/30 16:10] (aktuell) – [Creating a Private Key] marko | ||
---|---|---|---|
Zeile 1: | Zeile 1: | ||
- | ====== Eine eigene OpenSSL CA erstellen und Zertifikate ausstellen | + | ====== OpenSSL ====== |
+ | ===== Kleine OpenSSL FAQ Ecke ===== | ||
+ | * [[openssl_faq|OpenSSL FAQ]]\\ | ||
+ | * [[allgemeines_zu_zertifikaten|So unterscheiden sich Clientzertifikate von Serverzertifikaten]] | ||
+ | \\ | ||
+ | \\ | ||
+ | ===== Creating a Self-Signed Certificate With OpenSSL ===== | ||
+ | ==== Creating a Private Key ==== | ||
+ | First, we’ll create a private key. A private key helps to enable encryption, and is the most important component of our certificate. | ||
+ | |||
+ | Let’s create a password-protected, | ||
+ | <code bash> | ||
+ | openssl genrsa -des3 -out domain.key 2048 | ||
+ | </ | ||
+ | We’ll enter a password when prompted. The output will look like: | ||
+ | <code bash> | ||
+ | Generating RSA private key, 2048 bit long modulus (2 primes) | ||
+ | .....................+++++ | ||
+ | .........+++++ | ||
+ | e is 65537 (0x010001) | ||
+ | Enter pass phrase for domain.key: | ||
+ | Verifying - Enter pass phrase for domain.key: | ||
+ | </ | ||
+ | If we want our private key unencrypted, | ||
+ | |||
+ | Nun wird die Passphrase aus dem Schlüssel entfernt. | ||
+ | <code bash> | ||
+ | root@linux# openssl rsa -in domain.key -out domain.key | ||
+ | Enter pass phrase for serverkey.pem: | ||
+ | writing RSA key | ||
+ | </ | ||
+ | |||
+ | ==== Creating a Certificate Signing Request ==== | ||
+ | If we want our certificate signed, we need a certificate signing request (CSR). The CSR includes the public key and some additional information (such as organization and country). | ||
+ | |||
+ | Let’s create a CSR (domain.csr) from our existing private key: | ||
+ | <code bash> | ||
+ | openssl req -key domain.key -new -out domain.csr | ||
+ | </ | ||
+ | |||
+ | We’ll enter our private key password and some CSR information to complete the process. The output will look like: | ||
+ | <code bash> | ||
+ | Enter pass phrase for domain.key: | ||
+ | You are about to be asked to enter information that will be incorporated | ||
+ | into your certificate request. | ||
+ | What you are about to enter is what is called a Distinguished Name or a DN. | ||
+ | There are quite a few fields but you can leave some blank | ||
+ | For some fields there will be a default value, | ||
+ | If you enter ' | ||
+ | ----- | ||
+ | Country Name (2 letter code) [AU]:AU | ||
+ | State or Province Name (full name) [Some-State]: | ||
+ | Locality Name (eg, city) []:cityA | ||
+ | Organization Name (eg, company) [Internet Widgits Pty Ltd]: | ||
+ | Organizational Unit Name (eg, section) []: | ||
+ | Common Name (e.g. server FQDN or YOUR name) []:domain | ||
+ | Email Address []: | ||
+ | |||
+ | Please enter the following ' | ||
+ | to be sent with your certificate request | ||
+ | A challenge password []: | ||
+ | An optional company name []: | ||
+ | </ | ||
+ | An important field is “Common Name,” which should be the exact Fully Qualified Domain Name (FQDN) of our domain. | ||
+ | |||
+ | “A challenge password” and “An optional company name” can be left empty. | ||
+ | |||
+ | ==== Creating a Self-Signed Certificate ==== | ||
+ | A self-signed certificate is [b]a certificate that’s signed with its own private key[/b]. It can be used to encrypt data just as well as CA-signed certificates, | ||
+ | |||
+ | Let’s create a self-signed certificate (domain.crt) with our existing private key and CSR: | ||
+ | <code bash> | ||
+ | openssl x509 -signkey domain.key -in domain.csr -req -days 365 -out domain.crt | ||
+ | </ | ||
+ | |||
+ | \\ | ||
+ | \\ | ||
+ | ===== Eine eigene OpenSSL CA erstellen und Zertifikate ausstellen ===== | ||
OpenSSL bringt umfassende Werkzeuge mit, um eine eigene, kleine Certificate Authority (CA) betreiben zu können. Die Nutzung einer eigenen CA ist besonders dann sinnvoll, wenn mehrere Dienste über SSL/TLS kostenlos abgesichert werden sollen. Neben dem Nachteil, dass die eigene CA vor Benutzung zuerst auf den Clientrechnern bekannt gemacht werden muss, gibt es aber auch einen Vorteil: Mit einer CA unter der eigenen Kontrolle ist man im Zweifel auf der sicheren Seite: In den letzten Jahren wurden immer wieder Fälle bekannt, in denen große Certificate Authorities falsche Zertifikate ausgestellt haben. Es gibt Grund genug, die Vertrauenswürdigkeit großer CAs anzuzweifeln. | OpenSSL bringt umfassende Werkzeuge mit, um eine eigene, kleine Certificate Authority (CA) betreiben zu können. Die Nutzung einer eigenen CA ist besonders dann sinnvoll, wenn mehrere Dienste über SSL/TLS kostenlos abgesichert werden sollen. Neben dem Nachteil, dass die eigene CA vor Benutzung zuerst auf den Clientrechnern bekannt gemacht werden muss, gibt es aber auch einen Vorteil: Mit einer CA unter der eigenen Kontrolle ist man im Zweifel auf der sicheren Seite: In den letzten Jahren wurden immer wieder Fälle bekannt, in denen große Certificate Authorities falsche Zertifikate ausgestellt haben. Es gibt Grund genug, die Vertrauenswürdigkeit großer CAs anzuzweifeln. | ||
Mit dieser Anleitung werdet ihr in der Lage sein, beliebig viele Zertifikate für eure Dienste ausstellen zu können, die in jedem Browser als gültig erkannt werden, sofern vorher das Root-Zertifikat eurer CA importiert wurde.\\ | Mit dieser Anleitung werdet ihr in der Lage sein, beliebig viele Zertifikate für eure Dienste ausstellen zu können, die in jedem Browser als gültig erkannt werden, sofern vorher das Root-Zertifikat eurer CA importiert wurde.\\ | ||
---- | ---- | ||
- | ===== Certificate Authority (CA) erstellen ===== | + | ==== Erstellen der CA ==== |
- | Zu Beginn wird die Certificate Authority generiert. Dazu wird ein geheimer Private Key erzeugt: | + | |
+ | Legen Sie zunächst ein Verzeichnis an, in dem Sie das Zertifikat ablegen wollen. Wir nehmen in unserem Beispiel /root/ca: | ||
<code bash> | <code bash> | ||
- | openssl genrsa -aes256 -out ca-key.pem 2048 | + | root@linux# mkdir /root/ca |
+ | root@linux# cd /root/ca | ||
</ | </ | ||
- | Der Key trägt den Namen „ca-key.pem“ und hat eine Länge von 2048 Bit. Wer es besonders sicher haben will, kann auch eine Schlüssellänge von 4096 Bit angeben. Die Option „-aes256“ führt dazu, dass der Key mit einem Passwort geschützt wird. Die Key-Datei | + | Die Gültigkeit setzen wir mit 10 Jahren bewusst sehr hoch an. Läuft die CA aus, so werden nämlich auch alle damit signierten Serverzertifikate ungültig. Die CA enthält einen geheimen Schlüssel, welcher automatisch erzeugt und in der Datei cakey.pem abgelegt wird. Das CA-Zertifikat wird nach cacert.pem geschrieben. Der folgende Befehl erzeugt das einen Schlüssel für das Zertifikat mit einer Länge von 2048 Bit: |
+ | <code bash> | ||
+ | root@linux# openssl req -new -x509 -newkey rsa:2048 -keyout cakey.pem -out cacert.pem -days 3650 | ||
+ | Generating a 2048 bit RSA private key | ||
+ | .............................................................. | ||
+ | .............................................................. | ||
+ | .........................................+++ | ||
+ | ......................................+++ | ||
+ | writing new private key to ' | ||
+ | </ | ||
+ | Wer den geheimen Schlüssel der CA kennt, kann damit beliebige Serverzertifikate signieren. Deshalb wird diese Schlüsseldatei nicht im Klartext auf der Festplatte abgelegt, sondern | ||
+ | <code bash> | ||
+ | Enter PEM pass phrase: wrzlprmpft | ||
+ | Verifying - Enter PEM pass phrase: wrzlprmpft | ||
+ | </ | ||
+ | Nun werden | ||
+ | <code bash> | ||
+ | ----- | ||
+ | You are about to be asked to enter information that will be incorporated | ||
+ | into your certificate request. | ||
+ | What you are about to enter is what is called a Distinguished Name or a DN. | ||
+ | There are quite a few fields but you can leave some blank | ||
+ | For some fields there will be a default value, | ||
+ | If you enter ' | ||
+ | ----- | ||
+ | Country Name (2 letter code) [AU]: DE | ||
+ | State or Province Name (full name) [Some-State]: | ||
+ | Locality Name (eg, city) []: | ||
+ | Organization Name (eg, company) [Internet Widgits Pty Ltd]:Hinz und Kunz AG | ||
+ | Organizational Unit Name (eg, section) []:. | ||
+ | </ | ||
+ | Das Feld Common Name (CN) ist hier der offizielle Name der Zertifizierungsstelle. Für Ihre eigene CA können Sie einfach Ihren eigenen Namen eintragen: | ||
+ | <code bash> | ||
+ | Common Name (eg, YOUR name) []: Adam Hinz | ||
+ | Email Address []: adam@hinzag.eu | ||
+ | </ | ||
+ | Fertig. Folgende zwei Dateien sind entstanden: | ||
+ | <code bash> | ||
+ | root@linux# ll | ||
+ | insgesamt 9 | ||
+ | drwxr-xr-x | ||
+ | drwx------ | ||
+ | -rw-r--r-- | ||
+ | -rw-r--r-- | ||
+ | </ | ||
+ | Vorsichtshalber sollten Sie die Rechte so setzen, dass die Schlüsseldatei nur für root lesbar ist: | ||
+ | <code bash> | ||
+ | root@linux# chmod 600 cakey.pem | ||
+ | </ | ||
+ | Sie können nun ausprobieren, | ||
+ | <code bash> | ||
+ | root@linux# openssl rsa -in cakey.pem -noout -text | ||
+ | Enter pass phrase for cakey.pem: wrzlprmpft | ||
+ | Private-Key: | ||
+ | modulus: | ||
+ | 00: | ||
+ | b5: | ||
+ | 53: | ||
+ | 58: | ||
+ | cf: | ||
+ | </ | ||
+ | usw... | ||
- | Einen geheimen Key für die CA gibt es nun also schon – fehlt noch das Root-Zertifikat, | + | ==== Schlüssel |
+ | Nachdem wir nun eine eigene | ||
<code bash> | <code bash> | ||
- | openssl | + | root@linux# |
+ | Generating RSA private | ||
+ | ....+++ | ||
+ | .......................................+++ | ||
+ | e is 65537 (0x10001) | ||
+ | Enter pass phrase for serverkey.pem: jaja | ||
+ | Verifying | ||
</ | </ | ||
- | In diesem Fall wird die CA 1024 Tage lang gültig bleiben. Während der Generierung werden das Passwort für die CA und einige Attribute abgefragt | + | So. Nun entfernen wir die Passphrase wieder. Warum? Der Serverdienst |
<code bash> | <code bash> | ||
- | Country Name (2 letter code) [AU]:DE | + | root@linux# openssl rsa -in serverkey.pem -out serverkey.pem |
- | State or Province Name (full name) [Some-State]:BY | + | Enter pass phrase for serverkey.pem: jaja |
- | Locality Name (eg, city) []: | + | writing RSA key |
- | Organization Name (eg, company) [Internet Widgits Pty Ltd]: | + | |
- | Organizational Unit Name (eg, section) []:IT | + | |
- | Common Name (eg, YOUR name) []: | + | |
- | Email Address []: | + | |
</ | </ | ||
- | ===== Root-Zertifikat auf den Clients importieren ===== | ||
- | Damit ein Rechner die selbst ausgestellten Zertifikate akzeptiert, muss auf diesem Rechner das Root-Zertifikat (Public Key der CA) importiert worden sein. Die Root-CA Datei ist „ca-root.pem“. | ||
- | ==== Mozilla Firefox / Thunderbird ==== | ||
- | Mozilla Firefox verwaltet Zertifikate selbst. Ein neues Zertifikat wird importiert unter „Einstellungen => Erweitert => Zertifikate => Zertifikate anzeigen => Zertifizierungsstellen => Importieren“. Wählt die Datei „ca-root.pem“ aus. „Wählt die Option „Dieser CA vertrauen, um Websites zu identifizieren“. | ||
- | ==== Chromium / Google Chrome ==== | ||
- | „Einstellungen“ => „Erweiterte Einstellungen anzeigen“ (unten) => „HTTPS/ | ||
- | ==== Debian, Ubuntu | + | ==== Certificate Signing Request erzeugen |
+ | Der nächste Schritt zum eigenen Zertifikat ist ein CSR. Dies muss dann nur noch von der CA signiert werden. Hier sind wieder Angaben analog zum Erstellen der CA nötig, was oft Verwirrung stiftet. Die allgemeinen Daten kann man ggfl. gleich wie oben eingeben: | ||
<code bash> | <code bash> | ||
- | sudo cp ca-root.pem /usr/share/ca-certificates/ | + | root@linux# |
- | sudo dpkg-reconfigure ca-certificates | + | You are about to be asked to enter information that will be incorporated |
+ | into your certificate request. | ||
+ | What you are about to enter is what is called a Distinguished Name or a DN. | ||
+ | There are quite a few fields but you can leave some blank | ||
+ | For some fields there will be a default value, | ||
+ | If you enter ' | ||
+ | ----- | ||
+ | Country Name (2 letter code) [AU]: DE | ||
+ | State or Province Name (full name) [Some-State]: | ||
+ | Locality Name (eg, city) []: | ||
+ | Organization Name (eg, company) [Internet Widgits Pty Ltd]:Hinz und Kunz AG | ||
+ | Organizational Unit Name (eg, section) []:. | ||
+ | </code> | ||
+ | ACHTUNG, jetzt kommt das Wichtige: Beim Serverzertifikat ist der Common Name von entscheidender Bedeutung. Hier muss der DNS-Name stehen, unter dem der Client den Server anspricht! Wird das Zertifikat für eine HTTPS-Verbindung zu www.hinzag.eu verwendet, so muss der Common Name eben genau www.hinzag.eu heißen. Anderfalls wird der Browser das Zertifikat nicht akzeptieren, | ||
+ | <code bash> | ||
+ | Common Name (eg, YOUR name) []: www.hinzag.eu | ||
+ | Email Address []: adam@hinzag.eu | ||
+ | </code> | ||
+ | Weitere Optionen kann man einfach leer lassen: | ||
+ | <code bash> | ||
+ | A challenge password []: | ||
+ | An optional company name []: | ||
+ | </code> | ||
+ | Mittlerweile tummeln sich schon vier Dateien in unserem Verzeichnis: | ||
+ | <code bash> | ||
+ | root@linux# ll | ||
+ | insgesamt 17 | ||
+ | drwxr-xr-x | ||
+ | drwx------ 12 root root 600 2006-04-30 11:54 .. | ||
+ | -rw-r--r-- | ||
+ | -rw------- | ||
+ | -rw-r--r-- | ||
+ | -rw-r--r-- | ||
</ | </ | ||
- | => Neue Zertifikate akzeptieren | ||
- | ===== Ein neues Zertifikat ausstellen ===== | ||
- | Die CA ist nun fertig und kann genutzt werden. Zeit, das erste Zertifikat auszustellen! | ||
- | Grundlage ist immer ein privater Schlüssel. Wie auch bei der CA wird dieser Private Key erzeugt: | + | ==== OpenSSL-Konfiguration anpassen ==== |
+ | Leider kann man bei OpenSSL nicht alle Daten als Kommandozeilenargumente übergeben. Einige Einstellungen muss man lästigerweise in der Datei / | ||
<code bash> | <code bash> | ||
- | openssl | + | /etc/ssl/openssl.cnf: |
+ | dir = . # Where everything is kept | ||
+ | new_certs_dir | ||
+ | private_key | ||
+ | RANDFILE | ||
+ | default_days | ||
</ | </ | ||
- | An dieser Stelle ein Passwort zu setzen | + | Das Feld default_days |
- | Nun wird eine Zertifikatsanfrage erstellt, bei der wieder einige Attribute abgefragt werden. Besonderheit ist hier: Das Feld „Common Name“ muss den Hostnamen des Servers tragen, für den es gültig sein soll. Soll z.B. die Verbindung zum Rechner mit der IP-Adresse „192.168.2.2“ mit dem Zertifikat abgesichert werden, muss die IP-Adresse hier angegeben werden. Soll das Zertifikat dagegen für die Domain thomas-leister.de gelten, muss das ebenso eingetragen werden. Es ist auch möglich, sog. Wildcard-Zertifikate zu erstellen. Wird z.B. „*.thomas-leister.de“ als Common Name angegeben, gilt das Zertifikat für alle Domains von thomas-leister.de, | + | Wenn Sie beim Serverzertifikat keinen Bundesstaat angegeben haben, benötigen Sie noch folgende Änderung unter [ policy_match ]: |
<code bash> | <code bash> | ||
- | openssl req -new -key zertifikat-key.pem -out zertifikat.csr -sha512 | + | stateOrProvinceName |
+ | </ | ||
+ | Nun muss man noch einige Dateien anlegen: | ||
+ | <code bash> | ||
+ | root@linux# echo 01 > serial | ||
+ | root@linux# touch index.txt | ||
</ | </ | ||
- | Sobald die Zertifikatsanfrage „zertifikat.csr“ fertiggestellt ist, kann sie von der CA verarbeitet werden. Dabei entsteht der öffentliche Schlüssel (Public Key) zum angefragten Zertifikat. Dieser wird zusammen mit dem Private Key des Zertifikats für die Verschlüsselung benötigt. | ||
- | Mit folgendem Befehl wird ein Public Key „zertifikat-pub.pem“ausgestellt, | ||
+ | ==== Serverzertifikat signieren ==== | ||
+ | Kommen wir zum feierlichen Abschluss. Damit später Chrome und Chromium Ihr Serverzertifikat akzeptiert, muß ein sogenannter " | ||
<code bash> | <code bash> | ||
- | x509 -req -in zertifikat.csr -CA ca-root.pem -CAkey ca-key.pem -CAcreateserial -out zertifikat-pub.pem -days 365 -sha512 | + | root@linux# vim oats.extensions.cnf |
- | </ | + | |
- | (Das Passwort für die CA wird erneut abgefragt.) Die Zertifizierungsanfrage zertifikat.csr kann gelöscht werden – sie wird nicht mehr benötigt. Übrig bleiben Private Key und Public Key des neuen Zertifikats (zertifikat-key.pem und zertifikat-pub.pem) sowie Private- und Public Key der CA (ca-key.pem und ca-root.pem) | + | |
- | ===== Die Zertifikate nutzen ===== | + | basicConstraints=CA:FALSE |
- | In der Webserver-Konfiguration müssen üblicherweise drei Zertifikatsdateien angegeben werden: | + | subjectAltName=@my_subject_alt_names |
- | * Private Key des Zertifikats (zertifikat-key.pem) | + | subjectKeyIdentifier |
- | * Public Key des Zertifikats (zertifikat-pub.pem) | + | |
- | * Public Key der CA (ca-root.pem) | + | [ my_subject_alt_names ] |
- | Der Public Key der CA kann auch an die Public Key Datei des Zertifikats angehängt werden: | + | DNS.1 = fhem01.tuxnet.local |
+ | DNS.2 = fhem02.tuxnet.local | ||
+ | DNS.3 = fhem01-vpn.tuxnet.local | ||
+ | </ | ||
+ | Unsere | ||
<code bash> | <code bash> | ||
- | cat ca-root.pem >> zertifikat-pub.pem | + | root@linux# openssl |
+ | Enter pass phrase for ./ | ||
+ | |||
+ | ... | ||
+ | |||
+ | Certificate is to be certified until Apr 27 10:45:36 2016 GMT (3650 days) | ||
+ | Sign the certificate? | ||
+ | |||
+ | |||
+ | 1 out of 1 certificate requests certified, commit? [y/n] y | ||
+ | Write out database with 1 new entries | ||
+ | Data Base Updated | ||
</ | </ | ||
- | Diese Integration ist immer dann nötig, wenn es keinen Parameter in der Konfiguration gibt, bei dem man das Rootzertifikat einer CA angeben kann – beim XMPP Server Prosody und beim Webserver Nginx ist das z.B. der Fall: Hier können nur Public- und Private Key des Zertifikats angegeben werden. | ||
- | Wie ihr SSL/TLS für euren Webserver nutzt könnt ihr in diesen beiden Beiträgen nachlesen: | + | |
- | * Apache Webserver mit SSL | + | ==== Zertifikate installieren ==== |
- | * Nginx Webserver mit SSL | + | Wohin sie die Zertifikate installieren, |
+ |
it-wiki/ssl/openssl.1504204494.txt.gz · Zuletzt geändert: von marko