Ursprünglich hatte ich den Plan aufgegeben noch ein Whitepaper zum Thema “Exchange und Zertifikate” zu schreiben. Jedoch scheint es noch sehr häufig Probleme bei der Konfiguration der Zertifikate in Verbindung mit Exchange Servern zu geben. Ein paar Artikel und Scripte gibt es hier ja bereits, jetzt folgt also doch noch ein umfangreiches Whitepaper zum Thema Zertifikate.
Das Whitepaper “Zertifikate für Exchange Server 2019” richtet sich an alle Admins, welche noch Probleme beim Konfigurieren der SSL Zertifikate für Exchange Server haben. Ich habe ebenfalls versucht, das Thema Verschlüsselung und Zertifikate möglichst einfach zu erklären. Über 70 Seiten zu diesem Thema sind dabei zusammen gekommen, hier daher mal ein kleiner Auszug aus dem Inhaltsverzeichnis:
- Zertifikate: Einfacher Überblick über die Funktionsweise
- Privater und Öffentlicher Schlüssel
- Überblick: Wie funktioniert die HTTPS Verschlüsselung
- Asymmetrische und symmetrische Verschlüsselung (einfach)
- Zertifizierungsstellen
- Was ist eine Zertifizierungsstelle
- Öffentliche CA
- Eigene CA / PKI
- Vor- und Nachteile
- Let’s Encrypt
- Automatische Zertifikate für Exchange Server
- Dateiformate für Zertifikate
- Welche Formate gibt es
- Konvertierung zwischen den Formaten
- Überblick: Zertifikate und Exchange Server 2019
- Wo verwendet Exchange Zertifikate
- Abhängigkeiten
- Exchange 2019 Beispielkonfigurationen für die eigene PKI / öffentliche CA und Let’s Encrypt
- Besonderheiten wie SSL Offloading und Perfect Forward Secrency
- Hilfreiche Tools und Links
Das Whitepaper ist auch größtenteils für Exchange 2016 und Exchange 2013 gültig. Im Whitepaper wird nicht auf die UM-Rolle eingegangen, welche nicht mehr in Exchange 2019 enthalten ist. Sofern die UM Rolle nicht verwendet wird, lässt sich das Whitepaper auch für Exchange 2013 und Exchange 2016 einsetzen.
Fragen, Verbesserungen, Kritik und Anregungen zu diesem Whitepaper nehme ich gerne über das Kontaktformular entgegen. Auch eine kleine Spende ist willkommen:
Das Whitepaper liegt im PDF Format vor und kann hier kostenlos runtergeladen werden:
Exchange Zertifikate Whitepaper
Bisher gibt es dieses Whitepaper nur als PDF, falls es Bedarf an einer eBook Reader kompatiblen Version gibt, bitte ich um entsprechende Hinweise.
First of all, amazing Whitepaper! really good and useful.
I do have a question: what do you suggest if we have more than one domain in Exchange Server? let say 10 Domains! what would be the best way) what is the best practice? Multi-Domain Certificate for each domain (mail.domainone.com, autodiscover.domainone.com) and then what will happen with the OWA and how we can define a certificate for each domain foe each service like imap?
Greetings
Ganz tolle Arbeit!
Hut ab.
Hello Frank,
leider ist der Download Deines Zertifikate-Whitepapers momentan nicht möglich.
Man bekommt stattdessen einen „WordPress-Fehler auf der Website“.
Wäre toll wenn Du den Download wieder ermöglichen könntest.
Ich hab die Hoffnung, dass das Script mir bei meinem Problem hilft :-)
Thank you.
Hallo Martin,
probier es noch einmal. Ich habe es gerade ausprobiert und der Download klappte problemlos.
Greetings,
Frank
Hallo Frank
Vielen Dank für das super Dokument das sehr viel toll erklärt.
Sollte das Script zum Ermitteln der Hostnamen für das Zertifikat auch auf einem Exchange 2013 oder 2016 funktionieren ?
Ich habe es auf unserem EX 2013 versucht und da bekomme ich diverse Scriptfehler.
Ich habe versucht die Fehler zu beheben aber hab es nicht hingekriegt. Bei Get-ClientAccessService muss es bei EX 2013 zb Get-ClientAccessServer heissen dann läuft das Script weiter.
Aber ich habe dann dauernd noch Fehler „unexpected token „……“ in statement und die kriege ich einfach nicht weg.
Wäre super wenn Du mir da helfen könntest, da wären sicher auch andere sehr dankbar für eine Version die auf EX2013 / 2016 laufen würde.
t C:\Scripts\get-cert-entries.ps1:10 char:56
+ $AutodiscoverFQDN = ((Get-ClientAccessService -Identity
+ ~
Missing closing ‚)‘ in expression.
At C:\Scripts\get-cert-entries.ps1:11 char:1
+ $ExchangeServer).AutoDiscoverServiceInternalUri.Host).ToLower()
+ ~~~~~~~~~~~~~~~
Unexpected token ‚$ExchangeServer‘ in expression or statement.
At C:\Scripts\get-cert-entries.ps1:9 char:5
+ try {
+ ~
Missing closing ‚}‘ in statement block.
At C:\Scripts\get-cert-entries.ps1:11 char:16
+ $ExchangeServer).AutoDiscoverServiceInternalUri.Host).ToLower()
+ ~
The Try statement is missing its Catch or Finally block.
At C:\Scripts\get-cert-entries.ps1:11 char:16
+ $ExchangeServer).AutoDiscoverServiceInternalUri.Host).ToLower()
+ ~
Unexpected token ‚)‘ in expression or statement.
At C:\Scripts\get-cert-entries.ps1:11 char:53
+ $ExchangeServer).AutoDiscoverServiceInternalUri.Host).ToLower()
+ ~
Unexpected token ‚)‘ in expression or statement.
At C:\Scripts\get-cert-entries.ps1:11 char:63
+ $ExchangeServer).AutoDiscoverServiceInternalUri.Host).ToLower()
+ ~
An expression was expected after ‚(‚.
At C:\Scripts\get-cert-entries.ps1:13 char:1
+ }
+ ~
Unexpected token ‚}‘ in expression or statement.
At C:\Scripts\get-cert-entries.ps1:18 char:43
+ $OAExtFQDN = ((Get-OutlookAnywhere -Server
+ ~
Missing closing ‚)‘ in expression.
At C:\Scripts\get-cert-entries.ps1:19 char:1
+ $ExchangeServer).ExternalHostname.Hostnamestring).ToLower()
+ ~~~~~~~~~~~~~~~
Unexpected token ‚$ExchangeServer‘ in expression or statement.
Not all parse errors were reported. Correct the reported errors and try again.
+ CategoryInfo : ParserError: (:) [], ParseException
+ FullyQualifiedErrorId : MissingEndParenthesisInExpression
Hallo Frank
Wie die erste Version sehr gut und ausführlich. Gratuliere! Eine revocation List habe ich in keinem CERT gefunden. Frage mich, ob ein Hinweis darauf etwas bringt. Der Hinweis „Wichtig: Der IIS Manager wird nicht verwendet um die Zertifikate für einen Exchange Server zu konfigurieren.“ ist für mich unverständlich. Als CERT bindings im Exchange kann man SMTP, POP und IMAP anklicken und der bindet dann das CERT auf die. IIS kann individuell konfiguriert werden. Für Let’s Encrypt-Leute wäre vielleicht eine Fussnote auf https://www.abetterinternet.org/documents/letsencryptCCS2019.pdf noch nützlich und bei den Test könnten M$-Leute einen Hinweis auf deren (Remote) Connectivity Analyzer brauchen, der ActiveSync, Inbound etc. testet. Bei Name Server mit IPv6 Adressen scheint er allerdings zu versagen. Das sind nur ziemlich unwichtige Vorschäge im Sinne einer konstruktiven Antwort zu einem Dokument, das viel Arbeit gegeben hat.
Mit Gruss Marcel
Hello,
sehr schönes Dokument.
Das Thema CRL (Certificate Revocation List) habe ich beim überfliegen nicht gesehen.
Dies macht bezüglich Zugriff und Responstime gelegentlich Probleme, wenn die interne CA keine gültige CRL bereit stellt (Besonders bei offline CAs :-( ).
Für Firefox können Zertifikate per GPO vom System importiert werden, so daß die interne CA im FF akzeptiert wird.
Greetings
Erik
Hallo Frank
Find Secrency und Secency.
Gruss Marcel
Danke! Wird korrigiert.
Thank you very much!
Ja, eine umfangreich Arbeit, welche die meisten Schritte, Konfigurationen und Einzelheiten erläutert. Zwei kleine Dinge sind mir aufgefallen: S. 68 „Es ist also nicht nötig, für jeden Exchange Server innerhalb der Organisation ein eigenes Zertifikat auszustellen oder zu kaufen.“ Wenn die SAN’s der einzelnen Exchange Server in den CERT’s enthalten sind, nicht. Und PFS heisst Perfect Forward Secrecy. Gruss Marcel
Hallo Marcel,
die Namen der einzelnen Exchange Server müssen nicht als SAN auf dem Zertifikat vorhanden sein, solange sich die Exchange Server den gleichen Namensraum teilen. Hast du beispielsweise 10 Exchange Server innerhalb der Organisation, können alle Exchange Server das gleiche Zertifikat nutzen (Es kommt hier natürlich ein bisschen auf die Konfiguration an).
Ist PFS irgendwo falsch geschrieben?
Vielen Dank für deinen Hinweis, ich denke das Thema „Mehrere Exchange Server“ werde ich noch etwas genauer beschreiben.
Beste Grüße,
Frank
Moin Frank,
eine super Arbeit, dieses Dokument, klasse! Hier werden endlich auch mal gut die Grundlagen erklärt.
Greetings,
Peter Feige
TechnoSoft Consulting GmbH