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 | 52 ++++++++++++++++++++++++++++++++++++---------------- 1 files changed, 36 insertions(+), 16 deletions(-) diff --git a/src/de/uhilger/httpserver/adoc/AdocHandler.java b/src/de/uhilger/httpserver/adoc/AdocHandler.java index 6edfb7a..b913ba3 100644 --- a/src/de/uhilger/httpserver/adoc/AdocHandler.java +++ b/src/de/uhilger/httpserver/adoc/AdocHandler.java @@ -18,41 +18,61 @@ 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()); - public AdocHandler(String absoluteDirectoryPathAndName) { - super(absoluteDirectoryPathAndName); + /** + * Benoetigt das Attribut + * FileHandler.ATTR_FILE_BASE + */ + public AdocHandler() { + //super(absoluteDirectoryPathAndName); } @Override 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, fileBase, 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()); @@ -62,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