From 5794c8f1f5e48dea6afe808e374265ca69f7419a Mon Sep 17 00:00:00 2001 From: ulrich Date: Fri, 01 Jan 2021 11:39:12 +0000 Subject: [PATCH] Logging-Einstellungen ausgeschaltet und die MEthode zur Bestimmung des Daten-Ordners angepasst. --- src/java/de/uhilger/filecms/web/Initialiser.java | 118 ++++++++++++++------------------------- src/java/logging.properties | 26 ++++---- 2 files changed, 56 insertions(+), 88 deletions(-) diff --git a/src/java/de/uhilger/filecms/web/Initialiser.java b/src/java/de/uhilger/filecms/web/Initialiser.java index 758c374..82e0192 100644 --- a/src/java/de/uhilger/filecms/web/Initialiser.java +++ b/src/java/de/uhilger/filecms/web/Initialiser.java @@ -33,7 +33,9 @@ */ /* - der folgende Eintrag kann z.B. in $CATALINA_BASE/conf/context.xml + der folgende Eintrag kann z.B. in $CATALINA_BASE/conf/context.xml + eingetragen werden + <Environment name="wbxFileBase" type="java.lang.String" @@ -49,54 +51,7 @@ public static final String FILE_BASE = "filebase"; public static final String DATENABLAGE = "datenAblage"; public static final String WBX_FILE_BASE = "wbxFileBase"; - - /** - * 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) { - logger.fine("Catalina Base: " + System.getProperty("catalina.base")); - File catalinaBase = new File(System.getProperty("catalina.base")); - File wbxDir = catalinaBase.getParentFile().getParentFile(); - return wbxDir; - /* - 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; - */ - //} - + /** * Die Dateiablage wird entweder auf einen absoluten Pfad gesetzt, * der im Deployment Descriptor hinterlegt werden kann oder, wenn @@ -108,6 +63,9 @@ */ protected void ablageErmitteln(ServletContext ctx) { //Object o = ctx.getInitParameter(DATENABLAGE); + + //File wbxDaten = getDataDir(ctx, 2, "data/"); + WbxUtils wu = new WbxUtils(); Object o = wu.getJNDIParameter(WBX_FILE_BASE, WbxUtils.EMPTY_STRING); try { @@ -115,17 +73,49 @@ String pfad = o.toString(); if(pfad.trim().length() > 0) { ctx.setAttribute(FILE_BASE, pfad); - logger.fine("Basis: " + pfad); + logger.log(Level.INFO, "Daten-Ordner aus wbxFileBase: {0}", pfad); } else { - ctx.setAttribute(FILE_BASE, wu.getWbxDataDir().getAbsolutePath()); + ctx.setAttribute(FILE_BASE, getDataDir(ctx, 2, "data/").getAbsolutePath()); } } else { - ctx.setAttribute(FILE_BASE, wu.getWbxDataDir().getAbsolutePath()); + ctx.setAttribute(FILE_BASE, getDataDir(ctx, 2, "data/").getAbsolutePath()); } } catch(Exception ex) { - ctx.setAttribute(FILE_BASE, wu.getWbxDataDir().getAbsolutePath()); + ctx.setAttribute(FILE_BASE, getDataDir(ctx, 2, "data/").getAbsolutePath()); } } + + /** + * Daten-Ordner relativ zum Ablageort des file-cms finden. + * + * Die Standard-Struktur einer WebBox sieht folgende Ordner vor + * + * wbx/apps + * wbx/data + * + * Liegt das file-cms z.B. im Ordner /home/ulrich/dev/srv/wbx-3/apps/file-cms + * kann von dort aus der Daten-Ordner mit + * getDataDir(ctx, 2, "data/") + * gefunden werden. + * + * @param ctx der ServletContext, in dem das file-cms laeuft + * @param tiefe Anzahl Ordner, die der Ablageort des file-cms vom + * Eltern-Ordner entfernt ist + * @param pfad der Pfad zum Daten-Ordner ausgehend vom Eltern-Ordner + * @return Daten-Ordner + */ + private File getDataDir(ServletContext ctx, int tiefe, String pfad) { + File appsOrdner = new File(ctx.getRealPath("/")); + logger.log(Level.INFO, "Apps-Ordner: {0}", appsOrdner.getAbsolutePath()); + File wbx = new File(appsOrdner, ""); + for(int i = 0; i < tiefe; i++) { + wbx = wbx.getParentFile(); + } + logger.log(Level.INFO, "Wbx-Ordner: {0}", wbx.getAbsolutePath()); + File daten = new File(wbx, pfad); + logger.log(Level.INFO, "Daten-Ordner: {0}", daten.getAbsolutePath()); + return daten; + } protected void ablageInitialisieren(ServletContext ctx) { Object o = ctx.getAttribute(FILE_BASE); @@ -143,28 +133,6 @@ FileUtils.copyDirectoryToDirectory(srcDir, dataDir); srcDir = new File(srcPath, "/META-INF/daten/dav"); FileUtils.copyDirectoryToDirectory(srcDir, dataDir); - - /* - - an dieser Stelle koennten noch die Kontexte fuer www und home - angelegt werden. Sie muessten aber dynamisch erzeugt werden, - mit der jeweiligen Einstellung laut FILE_BASE, nicht, wie - unten durch Kopieren einer statischen Datei - - // hier noch den context anlegen - String path = ctx.getRealPath("/"); - //File appDir = new File(path); - logger.fine("Catalina Base: " + System.getProperty("catalina.base")); - //File catalinaBase = appDir.getParentFile().getParentFile(); - File catalinaBase = new File(System.getProperty("catalina.base")); - File confLocalhost = new File(catalinaBase, "conf/Catalina/localhost"); - File dataContext = new File(confLocalhost, "data.xml"); - srcDir = new File(path, "/META-INF/conf"); - File dataCtxSrc = new File(srcDir, "data.xml"); - logger.fine("dataCtxSrc: " + dataCtxSrc.getAbsolutePath()); - logger.fine("dataContext: " + dataContext.getAbsolutePath()); - FileUtils.copyFile(dataCtxSrc, dataContext); - */ } catch (IOException ex) { logger.log(Level.SEVERE, null, ex); } diff --git a/src/java/logging.properties b/src/java/logging.properties index 465c5ec..92e67f4 100644 --- a/src/java/logging.properties +++ b/src/java/logging.properties @@ -18,7 +18,7 @@ # handlers= java.util.logging.ConsoleHandler # To also add the FileHandler, use the following line instead. -handlers= java.util.logging.FileHandler, java.util.logging.ConsoleHandler +# handlers= java.util.logging.FileHandler, java.util.logging.ConsoleHandler # Default global logging level. # This specifies which kinds of events are logged across @@ -27,7 +27,7 @@ # Note that the ConsoleHandler also has a separate level # setting to limit messages printed to the console. # .level= FINE -.level = NONE +# .level = NONE ############################################################ # Handler specific properties. @@ -37,18 +37,18 @@ # default file output is in user's home directory. # java.util.logging.FileHandler.pattern = %h/java%u.log # java.util.logging.FileHandler.pattern = /media/extmirror/tomcat747/logs/tv_%u.log -java.util.logging.FileHandler.pattern = ${catalina.base}/logs/file-cms_%u.log -java.util.logging.FileHandler.limit = 50000 +# java.util.logging.FileHandler.pattern = ${catalina.base}/logs/file-cms_%u.log +# java.util.logging.FileHandler.limit = 50000 # java.util.logging.FileHandler.count = 1 -java.util.logging.FileHandler.count = 2 +# java.util.logging.FileHandler.count = 2 # java.util.logging.FileHandler.formatter = java.util.logging.XMLFormatter -java.util.logging.FileHandler.formatter = java.util.logging.SimpleFormatter -java.util.logging.FileHandler.level = FINER +# java.util.logging.FileHandler.formatter = java.util.logging.SimpleFormatter +# java.util.logging.FileHandler.level = FINER # Limit the message that are printed on the console to INFO and above. # java.util.logging.ConsoleHandler.level = INFO -java.util.logging.ConsoleHandler.level = FINER -java.util.logging.ConsoleHandler.formatter = java.util.logging.SimpleFormatter +# java.util.logging.ConsoleHandler.level = FINER +# java.util.logging.ConsoleHandler.formatter = java.util.logging.SimpleFormatter # Example to customize the SimpleFormatter output format # to print one-line log message like this: @@ -64,7 +64,7 @@ # For example, set the com.xyz.foo logger to only log SEVERE # messages: # com.xyz.foo.level = SEVERE -de.uhilger.filecms.handlers = java.util.logging.FileHandler, java.util.logging.ConsoleHandler -de.uhilger.filecms.level = FINEST -de.uhilger.wbx.handlers = java.util.logging.ConsoleHandler -de.uhilger.wbx.level = FINEST \ No newline at end of file +# de.uhilger.filecms.handlers = java.util.logging.FileHandler, java.util.logging.ConsoleHandler +# de.uhilger.filecms.level = FINEST +# de.uhilger.wbx.handlers = java.util.logging.ConsoleHandler +# de.uhilger.wbx.level = FINEST \ No newline at end of file -- Gitblit v1.9.3