HTTP Let's Encrypt und Java Trust-Store

Maliko

Bekanntes Mitglied
Moin,

ich hab da momentan mal ein etwas nerviges Problem. Und zwar haben wir ein kleines Programm welches regelmäßig eine REST-Schnittstelle über https antriggert. Dazu musste ich das SSL-Zertifikat im Truststore hinterlegen. Das Problem daran ist aber dass das SSL-Certifikat ein Let's Encrypt-Zertifikat ist und alle 3 Monate erneuert wird. Für mich bedeutet das momentan dass ich alle 3 Monate das SSL-Zertifikat neu herunterladen muss und per Hand in den Trust-Store einfügen muss.

Daher meine Frage. Gibt es irgendeine Möglichkeit das irgendwie so zu konfigurieren dass Java sich automatisch alle 3 Monate das aktuelle Zertifikat zieht und in seinen Truststore schmeißt wenn er sieht dass das alte abgelaufen ist?

Vielen Dank schon mal im Voraus.

Viele Grüße
Maliko
 
K

kneitzel

Gast
Wie genau machst Du das denn mit der Zertifikats-Erneuerung? Wenn das bei Dir durch automatische Scripts geht / Cron aufrufe, dann kannst du da alles weiteren Schritte natürlich auch automatisieren:

So startet certbot bei mir regelmäig in einem Script. Nachdem certbot fertig ist, habe ich (für die einzelnen Zertifikate) eine Prüfung, ob das Zertifikat erneuert wurde:
/etc/letsencrypt/scripts/server.kneitzel.de.sh

Bash:
[ /etc/letsencrypt/live/server.kneitzel.de/cert.pem -nt /etc/letsencrypt/live/server.kneitzel.de/keystore.jks ] && /etc/letsencrypt/scripts/server.kneitzel.de.sh

Da kannst Du erkennen: Es liegt zusätzlich ein jks File bei den certbot Dateien des Zertifikats. Die Verarbeitung macht dann ein eigenes Shellscript:
Bash:
#!/bin/bash
# Create new jks file

cd /etc/letsencrypt/live/server.kneitzel.de
rm fullcert.pem
rm fullchain.pkcs12
rm keystore.jks

cat cert.pem chain.pem fullchain.pem privkey.pem > fullcert.pem

openssl pkcs12 -export -out fullchain.pkcs12 -in fullcert.pem -passout pass:mySecret
keytool -importkeystore -srckeystore fullchain.pkcs12 -srcstorepass mySecret -destkeystore keystore.jks -deststoretype JKS -deststorepass mySecret

openssl pkcs12 -export -out fullchain.pkcs12 -in fullcert.pem -passout pass:mySecret -name myAlias
keytool -importkeystore -srckeystore fullchain.pkcs12 -srcstorepass mySecret -destkeystore cert.jks -deststoretype JKS -deststorepass mySecret

cp keystore.jks /opt/tomcat/.../keystore.jks

Also man erkennt glaube ich die ganzen Blöcke:
- löschen alter generierter Dateien (rm Zeilen)
- Erzeugen einer pem, die alles enthält (cat)
Dann zwei Mal:
- Erzeugen pkcs12 Store (openssl) - evtl. reicht das schon so aus für Dich, falls Du nur ein pkcs12 File brauchst
- keytool um ein jks File zu bekommen.

- Am Ende dann dahin kopieren, wo diese hin gehören.

Ich habe da zwei keystore Files erzeugt, da ich das Zertifikat an mehreren Stellen brauche mit unterschiedlichen Passwörtern und einmal mit speziellem Alias ... Passwörter habe ich hoffentlich alle geändert (mySecret). Das kannst Du dann so anpassen, wie Du es brauchst / möchtest.

Also einfaches Scripting - funktioniert auch sehr gut unter Windows mit WSL :)
 

Maliko

Bekanntes Mitglied
An sowas in der Art habe ich bereits gedacht. Das Problem ist nur dass es nicht unser Zertifikat ist. Die REST-Schnittstelle gehört einem externen Partner. Dementsprechend habe ich auch keinen Zugriff auf den Certbot. Wir bekommen bisher überhaupt nur mit, dass das Zertifikat abgelaufen ist weil der Client plötzlich nicht merh funktioniert.
 

mihe7

Top Contributor
Das Problem ist nur dass es nicht unser Zertifikat ist. Die REST-Schnittstelle gehört einem externen Partner. Dementsprechend habe ich auch keinen Zugriff auf den Certbot.
Auf dem Client musst Du normalerweise kein Zertifikat installieren. Entweder habt Ihr eine Uralt-Java-Version (vor 7u111/8u101) oder Ihr solltet mal prüfen, ob Euer Partner das Zertifikat korrekt eingebunden hat.

Wenn Du openssl laufen hast, probier mal openssl s_client -connect <server>:<port> aufrufen, wobei <server> und <port> natürlich entsprechend zu setzen sind. Ansonsten kannst Du auch mal einfach probieren, den REST-Server per Browser anzusteuern. Das sollte ohne irgendwelche Zertifikats-Warnungen funktionieren und Du kannst Dir auch mal das Zertifikat/Zertifikatskette anzeigen lassen.
 
K

kneitzel

Gast
Wenn es um den Client geht (Und nicht um den Server-Part), dann dürfte es ausreichen, wenn man sicher stellt, dass das Root Zertifikat entsprechend vorhanden ist. Bei alten Java Versionen (Java 8) habe ich gesehen, dass da die Zertifikate nicht vorhanden sind.

Das File mit den Zertifikaten der Java Installation findet sich in der Datei cacerts ($JAVA_HOME/jre/lib/security/cacerts - jre als Unterverzeichnis mag es - je nach Installationsquelle - nicht geben)

Passwort des stores ist in der Regel "changeit".

Mittels keytool lässt sich das auslesen und das root Zertifikat bei Bedarf hinzufügen.

Die Übersicht der Zertifikate findet sich unter https://letsencrypt.org/de/certificates/ (incl. Möglichkeit, die Zertifikate herunter zu laden).

Wichtig wären also das ISRG Root X1 Zertifikat. (Wenn Du da schon aktiv bist, auch gleich das ISRG Root X2 Zertifikat prüfen / hinzufügen!)
 

mihe7

Top Contributor
Hat das einen bestimmten Grund, dass Ihr eine Asbach-Version verwendet? Ansonsten würde ich Euch mal ein Update empfehlen, natürlich könnt Ihr Euch auch das Root-Zertifikat installieren, wie @kneitzel es beschrieben hat.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
D HTTP Apache-HttpClient/UNAVAILABLE (java 1.4) Netzwerkprogrammierung 18
M JAX-WS unter Java 17 plötzlich nicht mehr möglich Netzwerkprogrammierung 5
K Java RMI bricht ab wenn Remote eine Methode ausgeführt werden soll Netzwerkprogrammierung 5
JaXnPriVate Java HTTPS Server (Secure Sockets) Netzwerkprogrammierung 15
Tobero Java serversocket nicht nur zuganglich für localhost Netzwerkprogrammierung 6
D path-Variablen in eine URL hinzufügen mit Java 1.8 Netzwerkprogrammierung 2
D WebSocket Server mit HTML Client und Java Server Netzwerkprogrammierung 5
S Von Java auf passwortgeschützten Server zugreifen + Umgang mit Ports Netzwerkprogrammierung 28
S Probleme bei Java-Installation auf Server (Linux/Shell/Terminal) Netzwerkprogrammierung 6
S Java: Anbindung an einen realen Server? (+ Portfreigabe) Netzwerkprogrammierung 8
H Socket Chat entwickeln mit Java Server Client Netzwerkprogrammierung 4
x46 Java SSLContext erstellen mit SSL-Zertifikat Netzwerkprogrammierung 1
P Jenkins Login per Java Download Manager Netzwerkprogrammierung 15
N Java socket Programmierung Filme verschicken Netzwerkprogrammierung 20
S HTTP Post?!? - Java Server Netzwerkprogrammierung 7
F Verbindung zu einem LDAP Server über Java Netzwerkprogrammierung 4
K Java Websocketserver Problem | Android to Pi Netzwerkprogrammierung 1
R Anfängerbeispiel: Suche Java-Anwendung die http-Anfragen in Tomcat liest Netzwerkprogrammierung 8
V Browsergame mit Java(WebSocketServer) als Backend? Netzwerkprogrammierung 5
platofan23 Socket Java Socket mit DynDns nicht erreichbar Netzwerkprogrammierung 6
S Fragen zu Java Webservice mit Axis2 Netzwerkprogrammierung 0
M Mit Java Mail Mails an Webmailer schicken Netzwerkprogrammierung 1
mor16Euro HTTP Php website mit Java aktualisiern Netzwerkprogrammierung 6
T HTTP JAVA Browser Konsolenanfrage(JavaScript) Netzwerkprogrammierung 7
L Socket Wie kann man in Java die Anzahl der Objekte in einem InputStream sehen ohne ihn durchgehen zu müssen Netzwerkprogrammierung 1
M Socket Verbindung Matlab(Server) Java(Client) Netzwerkprogrammierung 1
M Socket peer to peer Verbindung zwischen Java und Matlab Netzwerkprogrammierung 0
L Remote Desktop per Java steuern Netzwerkprogrammierung 4
F Server für Java Applikationen Netzwerkprogrammierung 16
J Webserver mit Java schreiben? Netzwerkprogrammierung 4
D JAVA RMI Netzwerkprogrammierung 1
K HTTP Mit Java HTML Codeauslesen um damit zu arbeiten Netzwerkprogrammierung 7
V Kann man mit Hilfe eines Java-Programms den Zugriff auf bestimmte Internetseiten verhinden? Netzwerkprogrammierung 3
J HTTP [Java 9] Neuer HTTP Client - Tutorial Netzwerkprogrammierung 3
T Mikrofonaudio über Java Server an Webbrowser streamen Netzwerkprogrammierung 13
A Bestimmter URL/Certificate per Java immer vertrauen (Trustmanager/HostnameVerifier) Netzwerkprogrammierung 1
T VPN-Verbindung über Java Netzwerkprogrammierung 4
M HTTP PATCH Request mit Java ausführen Netzwerkprogrammierung 2
Niggo_ Probleme mit Java Mail Netzwerkprogrammierung 14
Aruetiise Socket Java Programm auf Server Netzwerkprogrammierung 3
L FTP Java Interpreter unterbindet SSL Handshake Netzwerkprogrammierung 2
C IFrame mit java auslesen Netzwerkprogrammierung 1
A FTP wie kann ich von java auf datei in fpt://192.168.178.1 lesen/schreiben? Netzwerkprogrammierung 3
C Datensammlung mit Java RMI Netzwerkprogrammierung 0
K Java Jsoup : OnLoad Netzwerkprogrammierung 0
S Java Chat Server Netzwerkprogrammierung 8
Carres HTTP Vorhandenen Session-ID Cookie von Firefox, Chrome oder IE in Java verwenden Netzwerkprogrammierung 2
B Java+Grbl: G-Code Befehle mit Java an Arduino senden und lesen Netzwerkprogrammierung 1
Z HTTP HTML Element auslesen in Java Netzwerkprogrammierung 1
T Socket Java Programm hängt sich auf bei dem versuch von einem Socket scanner Daten zu erhalten. Netzwerkprogrammierung 1
Thallius HTTP HTTPS unter Java 1.6 schlägt fehl Netzwerkprogrammierung 4
Thallius Java Application über ZScaler benutzer? Netzwerkprogrammierung 0
P Chat in Java Netzwerkprogrammierung 3
C java.net.ConnectException: Operation timed out? Netzwerkprogrammierung 2
M Java Eingabe auf FTP Server übergeben Netzwerkprogrammierung 4
T curl request in java umwandeln Netzwerkprogrammierung 4
M Socket Java Server: NullPointerException Netzwerkprogrammierung 4
J Java Server empfängt php inhalt nicht Netzwerkprogrammierung 1
I Socket Kommunikation C / Java Netzwerkprogrammierung 2
H Machbarkeitsfrage: TCP/IP Client (z.B. Netty) für Java Web Applcation Netzwerkprogrammierung 1
L Java RMI Objekt konsistenz Netzwerkprogrammierung 1
H Portforwarding umgehen in Java? Netzwerkprogrammierung 5
D Response in Java Servlet erzeugen Netzwerkprogrammierung 0
X Mit Java eine Applikation auf einem anderen Windows Rechner (Windows Server 2008) starten Netzwerkprogrammierung 1
E HttpUrlConnectionExample cannot be resolved to a type / Java 8 Netzwerkprogrammierung 1
F Socket Java Server mit Android App, Antwort vom Server an App Netzwerkprogrammierung 5
M Java-Programm aus dem Web laden Netzwerkprogrammierung 3
S HTTP-Requeste von Browser mit Java sniffen? Netzwerkprogrammierung 9
J access denied (“java.net.SocketPermission”…) mit Java 8 Netzwerkprogrammierung 1
N CURL requests in Java Netzwerkprogrammierung 6
P Kritische Java-Anwendung und Citrix veröffentlichen Netzwerkprogrammierung 1
F Java Server Scanner oder InputStream kann nicht gelsesen werden! Netzwerkprogrammierung 6
1 Netty NIO oder Java IO Netzwerkprogrammierung 2
1 Via Java mit WLAN Netzwerken verbinden Netzwerkprogrammierung 5
J Java Service Wrapper Netzwerkprogrammierung 1
K Mit Java ASPX Webseite fern steuern Netzwerkprogrammierung 2
H Socket Java | Server sendet Nachricht nur wenn vorher eine JOptionPane-Nachricht ausgegeben wurde. Netzwerkprogrammierung 2
K Emailsenden via Java Applikation Netzwerkprogrammierung 5
L Mit Java über PHP in MySQL anmelden (Login script) Netzwerkprogrammierung 3
C Java Chat Admin Kenzeichnung Netzwerkprogrammierung 14
P PHP Script per Java ausführen Netzwerkprogrammierung 2
P PPTP Protokoll für JAVA Netzwerkprogrammierung 14
T php/java-bridge Netzwerkprogrammierung 16
D Webseite(mit JavaScript-Element) mit Java auslesen Netzwerkprogrammierung 0
G Multiple Clients and one Server --> java.lang.NullPointerException Netzwerkprogrammierung 1
E Java Server übers Internet erreichen Netzwerkprogrammierung 4
D Socket Error: java.lang.NullPointerException Netzwerkprogrammierung 1
windl AirPlay mittels Java Netzwerkprogrammierung 0
R Email mit Java API Netzwerkprogrammierung 1
P Java Deauth / Deauthentication request Netzwerkprogrammierung 10
F Socket Java - Server/Client simple Netzwerkprogrammierung 1
E HTTP java.lang.IllegalArgumentException: protocol = http host = null Netzwerkprogrammierung 1
R Java - Socketprogrammierung Netzwerkprogrammierung 10
B Methoden und Konstruktoren von Java.net package werden nicht geladen Netzwerkprogrammierung 2
L Email versenden mit Java funktioniert nicht, Fehlermeldungen: MessagingException & SocketException Netzwerkprogrammierung 10
V Templates für Java Client rabbitmq Netzwerkprogrammierung 4
N Socket java.net.ConnectException Netzwerkprogrammierung 5
A Java Server - IOS Client Applikation Netzwerkprogrammierung 20
V json_encode in java?? Netzwerkprogrammierung 3
A Caldav und Carddav Java Api - wie fange ich an? Netzwerkprogrammierung 3

Ähnliche Java Themen

Neue Themen


Oben