From d14d78390fda6a8604966d596ee178966262a9bc Mon Sep 17 00:00:00 2001 From: ulrich <not disclosed> Date: Sat, 23 Dec 2017 10:05:56 +0000 Subject: [PATCH] Sortierung nach Name hinzugefuegt --- src/java/de/uhilger/filecms/web/Initialiser.java | 66 ++++++++++++++++++++++++-------- 1 files changed, 49 insertions(+), 17 deletions(-) diff --git a/src/java/de/uhilger/filecms/web/Initialiser.java b/src/java/de/uhilger/filecms/web/Initialiser.java index ac25f00..eece13c 100644 --- a/src/java/de/uhilger/filecms/web/Initialiser.java +++ b/src/java/de/uhilger/filecms/web/Initialiser.java @@ -18,7 +18,6 @@ package de.uhilger.filecms.web; -import de.uhilger.wbx.WbxUtils; import java.io.File; import java.util.logging.Logger; import javax.servlet.ServletContext; @@ -32,17 +31,45 @@ private static final Logger logger = Logger.getLogger(Initialiser.class.getName()); - public static final String FILE_BASE = "filebase"; public static final String DATENABLAGE = "datenAblage"; - - /* ----- ServletContextListener Implementation ----- */ - - @Override - public void contextInitialized(ServletContextEvent sce) { - // hier kann etwas initialisiert werden - ServletContext ctx = sce.getServletContext(); - ablageErmitteln(ctx); + + /** + * Bei der WebBox ist das Datenverzeichnis relativ zum Verzeichnis + * $CATALINA_BASE/webapps untergebracht. + * Die Abfrage ServletContext.getRealPath + * liefert das Verzeichnis des Context dieser Webanwendung, also + * $CATALINA_BASE/webapps/file-cms + * oder + * $WBX/sys/base/webapps/file-cms + * + * Unter Windows z.B. + * C:\Users\fred\Documents\srv\wbx\sys\base\webapps\file-cms + * Unter Linux oder Mac OS z.B. + * /home/fred/srv/wbx/sys/base/webapps/file-cms + * + * Das Datenverzeichis liegt dann auf + * $WBX/daten + * + * Mit dem Verzeichnis des Context dieser Webanwendung ist das + * Datenverzeichnis der WebBox hart kodierbar mit dieser Methode + * + * @return Verzeichnis 'daten' der WebBox + */ + protected File getWbxDataDir(ServletContext ctx) { + File file = getWbxDir(ctx); + file = new File(file, "daten/"); + logger.fine("WebBox Datenbasis: " + file.getAbsolutePath()); + return file; + } + + protected File getWbxDir(ServletContext ctx) { + String path = ctx.getRealPath("/"); + logger.fine("getRealPath: " + path); // file-cms in webapps + File file = new File(path); + file = file.getParentFile().getParentFile().getParentFile().getParentFile(); + logger.fine("WebBox: " + file.getAbsolutePath()); + return file; } /** @@ -54,7 +81,7 @@ * @param ctx der ServletContext, in den die Angabe eingetragen wird. Dort * ist anschliessend die Angabe unter Initialiser.FILE_BASE abrufbar */ - private void ablageErmitteln(ServletContext ctx) { + protected void ablageErmitteln(ServletContext ctx) { Object o = ctx.getInitParameter(DATENABLAGE); try { if(o instanceof String) { @@ -63,21 +90,26 @@ ctx.setAttribute(FILE_BASE, pfad); logger.fine("Basis: " + pfad); } else { - ctx.setAttribute(FILE_BASE, WbxUtils.getWbxDataDir(ctx).getAbsolutePath()); + ctx.setAttribute(FILE_BASE, getWbxDataDir(ctx).getAbsolutePath()); } } else { - ctx.setAttribute(FILE_BASE, WbxUtils.getWbxDataDir(ctx).getAbsolutePath()); + ctx.setAttribute(FILE_BASE, getWbxDataDir(ctx).getAbsolutePath()); } } catch(Exception ex) { - ctx.setAttribute(FILE_BASE, WbxUtils.getWbxDataDir(ctx).getAbsolutePath()); + ctx.setAttribute(FILE_BASE, getWbxDataDir(ctx).getAbsolutePath()); } + } + + @Override + public void contextInitialized(ServletContextEvent sce) { + ServletContext ctx = sce.getServletContext(); + ablageErmitteln(ctx); } - + @Override public void contextDestroyed(ServletContextEvent sce) { - // hier wird alles wieder aufgeraeumt ServletContext ctx = sce.getServletContext(); ctx.removeAttribute(FILE_BASE); } - + } -- Gitblit v1.9.3