Jetty mit Client-Zertifikat nur bei spezifischer URL

threadi

Mitglied
Hi,

ich stehe vor folgender Herausforderung:
Ich habe eine Anwendung die über Jetty im Web bereitgestellt wird. Eine spezifische URL dieser Anwendung soll nun mit einem Client-Zertifikat geschützt werden.

Beispiel:
Beim Aufruf von https://www.example.com ist kein Client-Zertifikat erforderlich.
Beim Aufruf von https://www.example.com/api/ ist ein Client-Zertifikat erforderlich.

Die start.ini von Jetty sieht so aus:
Code:
--module=server
jetty.httpConfig.sendServerVersion=false
--module=jsp
--module=annotations
--module=deploy
--module=logging-jetty
--module=console-capture
--module=ext
--module=requestlog
--module=http-forwarded
--module=plus
--module=rewrite
--module=jstl
--module=servlets
--module=http
--module=ssl
--module=https
jetty.sslContext.keyStorePath=credentials/server.keystore
jetty.sslContext.keyStorePassword=mypassword
jetty.sslContext.keyManagerPassword=mypassword
jetty.sslContext.trustStorePath=credentials/server.keystore
jetty.sslContext.trustStorePassword=mypassword
jetty.sslContext.needClientAuth=true

Die Anwendung wird per xml-Datei in Jetty eingebunden:
XML:
<?xml version="1.0"?>
<!DOCTYPE Configure PUBLIC "-//Jetty//Configure//EN" "http://www.eclipse.org/jetty/configure_9_0.dtd">
<Configure class="org.eclipse.jetty.webapp.WebAppContext">
  <Set name="war">/path/to/app.war</Set>
  <Set name="contextPath">/</Set>
  <Set name="extractWAR">false</Set>
  <Set name="copyWebDir">false</Set>
  <Set name="copyWebInf">true</Set>
  <Set name="persistTempDirectory">false</Set>
</Configure>

Es gibt eine Java-Datei die per Servlet die API-URL bereitstellt. Hier der Kopf:

Java:
@WebServlet(
        name = "api",
        urlPatterns = {"spapi"},
        loadOnStartup = 1
)
public class api extends HttpServlet {
   // Logging-Objekt
   private MyLogging logging = null;

  /**
   * Initialisierung des Servlet-Containers beim Starten von diesem.
   * Hier werden für die Funktionalität der API wichtige Vorbereitungen getroffen.
   *
   * @param config die ServletConfig-Konfiguration
   */
  public void init(ServletConfig config) {
      // Lade das Logging als Objekt ein.
      logging = vioLogging.getInstance();
  }

    /**
     * Verarbeitung von GET-Requests an den Endpunkt.
     *
     * @param request  der Request als HttpServletRequest-Objekt
     * @param response die Antwort als HttpServletResponse-Objekt
     */
    protected void doGet(HttpServletRequest request, HttpServletResponse response) {
      extractCertificate(request,response);
    }

    /**
     * Verarbeitung von POST-Requests an den Endpunkt.
     *
     * @param request  der Request als HttpServletRequest-Objekt
     * @param response die Antwort als HttpServletResponse-Objekt
     */
    protected void doPost(HttpServletRequest request, HttpServletResponse response) {
       
    }

    /**
     * Verarbeitung von PUT-Requests an den Endpunkt.
     *
     * @param request  der Request als Objekt
     * @param response die Antwort als Objekt
     */
    protected void doPut(HttpServletRequest request, HttpServletResponse response) {
       
    }

   protected X509Certificate extractCertificate(HttpServletRequest req, HttpServletResponse res) {
        SslContextFactory.Server sslFactory = new SslContextFactory.Server();
        sslFactory.setNeedClientAuth(true);
        sslFactory.setWantClientAuth(true);

        logging.write("api", "clientcert: " + req.getHeader("ssl_client_cert"));
        logging.write("api", "authtype: " + req.getAuthType());
        boolean authResult = false;
        try{
            authResult = req.authenticate(res);
        }
        catch (Exception e){
            logging.write("api auth Exception", e.getMessage());
        }
        logging.write("api auth result", "result: " + authResult);
        X509Certificate[] certs = (X509Certificate[]) req.getAttribute("javax.servlet.request.X509Certificate");
        logging.write("api", "certs: " + certs);
        if (null != certs && certs.length > 0) {
            return certs[0];
        }
        throw new RuntimeException("No X.509 client certificate found in request");
    }
}

Damit die JVM das Client-Zertifikat aus dem Request ausliest muss meines Wissens entweder setNeedClientAuth() oder setWantClientAuth() auf true gesetzt werden (oder beides).

Meine Frage:
Wie verbinde ich SslContextFactory.Server mit dem HttpServletRequest? Ohne eine Verbindung wird diese Konfiguration doch völlig ignoriert.

Ich suche leider schon sehr lange nach einer Lösung. Vlt. hat einer von euch einen Hinweis?

Danke schonmal im Voraus
 

mihe7

Top Contributor
Da der TLS Handshake noch stattfindet, bevor HTTP zum Tragen kommt, kann die Client-Authentication nicht auf eine HTTP-Ressource beschränkt werden. Entweder baust Du eine TLS-Verbindung mit Client-Authentication auf oder eben nicht.

Das ganze dürfte also eine grundsätzliche Konfiguration des Jetty-Servers (bzw. des betreffenden Connectors) sein.

Was funktionieren könnte: wantClientAuth statt needClientAuth setzen. In dem Fall dürfte die HTTP-Verbindung auch zustandekommen, wenn der Client kein Zertifikat schickt und Du könntest abfragen, ob sich Client authentisiert hat.

Frag mich aber bitte nicht, wie das alles genau mit Jetty funktioniert :)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
B HttpClient - Server (Jetty) - getInputStream - EOF Netzwerkprogrammierung 3
T Jetty Server LOGGING Netzwerkprogrammierung 1
C Jetty 9 Non Blocking Handler Frage... Netzwerkprogrammierung 1
B Einfacher Server mit Jetty Netzwerkprogrammierung 3
M Jetty Konfiguration mehrere Handler? Netzwerkprogrammierung 2
I Performanteste Kommunikationsmethode zwischen Client u. Server Netzwerkprogrammierung 4
L Socket Automatische Zuweisung von Server und Client Rolle Netzwerkprogrammierung 12
ExceptionOfExpectation Server/Client-Kommunikation Netzwerkprogrammierung 34
M Server-Client-System für Browsergame Netzwerkprogrammierung 5
B Axis2 Webservice mit Client Zertifikat Authentifizierung Netzwerkprogrammierung 3
Yonnig Threads mit Client/Server und GUI (laufend bis button-click) Netzwerkprogrammierung 9
J Einlesen von Servernachrichten von TCP-Client Netzwerkprogrammierung 17
J Client-Server und SOAP Netzwerkprogrammierung 23
L30nS RMI Aufruf einer Client-Methode von einem RMI-Server Netzwerkprogrammierung 3
T String von Client zu Server kommt nicht an Netzwerkprogrammierung 92
D WebSocket Server mit HTML Client und Java Server Netzwerkprogrammierung 5
D Server - Client Informationsaustausch, Möglichkeiten Netzwerkprogrammierung 3
H Socket Chat entwickeln mit Java Server Client Netzwerkprogrammierung 4
X Kann ich einen Client/Server verbindung hinkriegen die mir alle paar Sekunden die aktuellen Daten per Realtime zuschickt ? Netzwerkprogrammierung 9
T Client zu Client Kommunikation Netzwerkprogrammierung 2
D Slf4j - Logging - Client-Server Architektur Netzwerkprogrammierung 3
J client server mit nur einem PC Netzwerkprogrammierung 33
M Socket Nachricht von TCP-Client an Server schicken Netzwerkprogrammierung 12
M Socket Verbindung Matlab(Server) Java(Client) Netzwerkprogrammierung 1
R Socket FATAL EXCEPTION MAIN bei Socket based client/server app Netzwerkprogrammierung 2
G Server-Client IO Problem Netzwerkprogrammierung 6
ruutaiokwu ständig "sender address rejected: improper use of smtp" bei smtp-client Netzwerkprogrammierung 4
J HTTP [Java 9] Neuer HTTP Client - Tutorial Netzwerkprogrammierung 3
A Chatserver/-client - Code stoppt bei readUTF() Netzwerkprogrammierung 7
I Socket Das erste Server-Client Programm Netzwerkprogrammierung 16
L Zugriffprobleme Client - Webservice AspenTechnology Netzwerkprogrammierung 0
A Client Client Übertragung Netzwerkprogrammierung 12
M Socket Server antwortet dem Client nicht Netzwerkprogrammierung 6
K Socket Netty Client wirft Fehler! Netzwerkprogrammierung 3
I Client/Server Kommunikation bei einem Spiel Netzwerkprogrammierung 4
E Objekte versenden, Client-Server Netzwerkprogrammierung 25
C Mini Client-Server-Anwendung funktioniert nicht Netzwerkprogrammierung 8
U Client Soap Verbindung wieder schließen Netzwerkprogrammierung 0
U Socket Client mit hash authentifizieren Netzwerkprogrammierung 3
F HTTP HTTP Rest Client mit TLS1.2 und selbst signiertem Zertifikat Netzwerkprogrammierung 2
P Server als Client nutzen Netzwerkprogrammierung 8
D Socket Run Args Client/Server Socket Netzwerkprogrammierung 1
Cromewell Socket Multithreaded Server und Client Netzwerkprogrammierung 1
Y Client/Server/DB communication Netzwerkprogrammierung 3
JavaWolf165 Socket mit .writeUtf etwas vom Client zum Server schicken Netzwerkprogrammierung 13
J Client - Serversocket Netzwerkprogrammierung 1
P RMI Client Server Programm über Internet Netzwerkprogrammierung 2
brainless Client Server Kommunikation verschlüsseln Netzwerkprogrammierung 13
gamebreiti Socket Server / Client Anwendung Manipulation von Objekten durch Server Netzwerkprogrammierung 9
T Socket Server/Client Kommunikation Netzwerkprogrammierung 8
N Fragen zu Sockets Client Netzwerkprogrammierung 3
F Extasys TCp Client extends Funktion Netzwerkprogrammierung 0
F Server Client Anwendung mit UDP Netzwerkprogrammierung 2
O Client zwischen XML und JSON auswählen lassen Netzwerkprogrammierung 2
A RMI Wo treten Exceptions bei RMI Aufrufen auf? Auf Client oder auf Server? Netzwerkprogrammierung 3
A ByteBuffer - Client/Server Netzwerkprogrammierung 9
A Socket Wie ein einfacher Multithreads Service mit Telnet als Client mit Observable/Observer gelöst.... Netzwerkprogrammierung 0
K C# Server - Android Client Netzwerkprogrammierung 0
T Application Client NullPointerExc Netzwerkprogrammierung 7
V TCP Client funktioniert auf Emulator aber nicht auf Smartphone Netzwerkprogrammierung 5
H Machbarkeitsfrage: TCP/IP Client (z.B. Netty) für Java Web Applcation Netzwerkprogrammierung 1
P MIME-TYPE Erklaerung, Kommunikation zwischen Client und Server Netzwerkprogrammierung 3
H HTTP REST Jersey - PUT-Beispiel von Client senden Netzwerkprogrammierung 0
J Sichere Kommunikation bei Server Client Netzwerkprogrammierung 3
T Frage zu Client-Server Applikation Netzwerkprogrammierung 2
H Socket Client/Server Socket Programmieren Netzwerkprogrammierung 1
M Theoretische Frage zu Server - Client Netzwerkprogrammierung 2
P HTTP Server / Client Netzwerkprogrammierung 1
N FTP FTP Client invalid IPv6 address (Apache Commons Net API) Netzwerkprogrammierung 6
F TCP Client, verbindung aufrecht halten Netzwerkprogrammierung 0
X RMI: Woher kennt der Client das Schnittstellen-Interface? Netzwerkprogrammierung 2
E Thematik Client server Netzwerkprogrammierung 2
D UDP Client empfängt nichts Netzwerkprogrammierung 2
D Client/Server per Crossover Lan Kabel Netzwerkprogrammierung 1
S Client Server Connection Netzwerkprogrammierung 4
V erste Client - Server Anwendung, paar Fragen wie Socketverbindung checken usw. Netzwerkprogrammierung 4
S Client Anwendung mit zentraler SQL-Datenbank Netzwerkprogrammierung 3
N Client Identifikation eines Servers Netzwerkprogrammierung 1
S Sichere Server/Client Architektur Netzwerkprogrammierung 1
D Chat Server/mehre Client Netzwerkprogrammierung 9
I Server+Client Netzwerkprogrammierung 3
N Client am Server abmelden Netzwerkprogrammierung 0
F Server/Client Probleme Netzwerkprogrammierung 3
D SSH Client Netzwerkprogrammierung 7
U Socket Instant Messanger (Server Linux, Client Windows) Netzwerkprogrammierung 1
B TCP Client Android Netzwerkprogrammierung 3
Athena Grundsatzfragen zu Client-Server-Architektur / Matchmaking Netzwerkprogrammierung 1
A Problem beim Senden von Client zu Server Netzwerkprogrammierung 10
F Client Server DB Netzwerkprogrammierung 0
A Verständnisfrage Multi-Threaded Client/Server Netzwerkprogrammierung 5
F Tipps zum Thema Server/Client vie SOAP Netzwerkprogrammierung 0
OnDemand Ist Client noch angemeldet? Netzwerkprogrammierung 7
F Socket Java - Server/Client simple Netzwerkprogrammierung 1
D Socket UDP Client reagiert nicht auf spontane Meldungen Netzwerkprogrammierung 5
R Zeitliche Syncronisation Server - Client Netzwerkprogrammierung 0
S Server-Client: Image senden Netzwerkprogrammierung 2
C Multithreading Client / Server erklärt Netzwerkprogrammierung 11
M Client sendet nur, wenn das Socket geschlossen wird Netzwerkprogrammierung 53
P server - client verbindung (anfänger) Netzwerkprogrammierung 8
S Socket (client) verbindet nicht Netzwerkprogrammierung 6

Ähnliche Java Themen

Neue Themen


Oben