From d686d32afb10bf4d56928abd30f56d58bd2968e9 Mon Sep 17 00:00:00 2001 From: ulrich Date: Wed, 30 Jun 2021 13:01:45 +0000 Subject: [PATCH] Auf PatternDelegator umgestellt --- src/de/uhilger/httpserver/adoc/AdocHandler.java | 44 ++++++++++++++++++++++++++++++-------------- 1 files changed, 30 insertions(+), 14 deletions(-) diff --git a/src/de/uhilger/httpserver/adoc/AdocHandler.java b/src/de/uhilger/httpserver/adoc/AdocHandler.java index 40beef7..b913ba3 100644 --- a/src/de/uhilger/httpserver/adoc/AdocHandler.java +++ b/src/de/uhilger/httpserver/adoc/AdocHandler.java @@ -18,23 +18,33 @@ package de.uhilger.httpserver.adoc; import com.sun.net.httpserver.HttpExchange; +import com.sun.net.httpserver.HttpHandler; import de.uhilger.httpserver.base.handler.FileHandler; import java.io.IOException; import java.net.URI; import java.util.logging.Logger; /** - * Der AdocHandler verwendet den FileHandler zur Auslieferung statischer - * Inhalte und einen AdocFilter, um vorab zu pruefen, ob fuer eine - * Asciidoctor-Quelldatei bereits eine HTML-Version vorliegt. Wenn nicht, - * verwendet der AdocFilter den AdocActor, um eine HTML-Version zu erzeugen, - * die dann vom AdocHandler mit Hilfe der Methoden des FileHandler - * ausgeliefert werden kann. + * Der AdocHandler liefert die HTML-Version einer Asciidoc-Quelldatei aus. + * + * Dazu muss ein AdocHandler mit dem PatternDelegator an einen Pfad + * geknuepft werden, der Dateien mit der Endung adoc bezeichnet. + * + * Ein dafuer geeigneter regulaerer Ausdruck ist z.B. <br /> + * <pre> + * .+\\.adoc + * </pre> + * + * Zum Ausliefern der HTML-Version delegiert der AdocHandler an eine + * Instanz des AdocActors. + * + * Zum Erzeugen der HTML-Version muss ein AdocFilter mit dem HttpContext + * verbunden sein, an den der AdocHandler gebunden ist. * * @author Ulrich Hilger * @version 1, 16.06.2021 */ -public class AdocHandler extends FileHandler { +public class AdocHandler implements HttpHandler { private static final Logger logger = Logger.getLogger(AdocHandler.class.getName()); @@ -50,13 +60,19 @@ public void handle(HttpExchange e) throws IOException { URI uri = e.getRequestURI(); logger.fine(uri.toString()); - String query = uri.getQuery(); + //String query = uri.getQuery(); //String[] params = query.split("?&"); // hier noch Regex ermitteln - String requestPathStr = uri.getPath(); + //String requestPathStr = uri.getPath(); //logger.fine("filter: " + requestUriStr); - if(requestPathStr.toLowerCase().endsWith(AdocFilter.ADOC)) { + + String ctxPath = e.getHttpContext().getPath(); + String uriPath = e.getRequestURI().getPath(); + String fName = uriPath.substring(ctxPath.length()); + + + //if(requestPathStr.toLowerCase().endsWith(AdocFilter.ADOC)) { AdocActor actor = new AdocActor(); - actor.handle(e, e.getHttpContext().getAttributes().get(FileHandler.ATTR_FILE_BASE).toString(), getFileName(e)); + actor.handle(e, e.getHttpContext().getAttributes().get(FileHandler.ATTR_FILE_BASE).toString(), fName); /* File adocfile = new File(fileBase, getFileName(e)); logger.fine("adocfile: " + adocfile.getAbsolutePath()); @@ -66,9 +82,9 @@ HttpResponder fs = new HttpResponder(); fs.serveFile(e, outfile); */ - } else { - super.handle(e); // andere Inhalte zu FileHandler delegieren - } + //} else { + // super.handle(e); // andere Inhalte zu FileHandler delegieren + //} } -- Gitblit v1.9.3