CP Problem: Webstart + Logging properties file + eigener Handler

Status
Nicht offen für weitere Antworten.
T

tuxedo

Gast
Hallo zusammen,

hab hier mal wieder n kleines Problem:

Ich hab eine Webstartanwendung welche java.util.logging benutzt. Um das zu konfigurieren hab ich eine "logging.properties" die in einem Package liegt.

"Konfigurieren" tu ich den LogManager so:

[HIGHLIGHT="Java"]InputStream is = MyApp.class.getResourceAsStream("/mypackage/resources/logging.properties");
LogManager.getLogManager().readConfiguration(is);[/HIGHLIGHT]

Das klappt auch prima.

In der logging.properties hab ich dann aber auch sowas stehen:

Code:
# To also add the FileHandler, use the following line instead.
# handlers= java.util.logging.FileHandler, java.util.logging.ConsoleHandler
handlers=mypackage.utils.CentralLogHandler

Ich hab also meinen eigenen Handler den ich gerne benutzen möchte.

Starte ich nun die Webstart-Anwendung sehe ich in der extra dafür aktivierten "Java Console" folgende Meldung:

Can't load log handler "mypackage.utils.CentralLogHandler"
java.lang.ClassNotFoundException: mypackage.utils.CentralLogHandler

In der JAR ist die class-File im richtigen Verzeichnis/Package aber vorhanden.
Google hat mir nicht sehr weiter geholfen. Da wurden nur Probleme diskutiert wie man die logging.properties überhaupt lädt. Aber das hab ich ja schon gelöst.
Problem ist dass er meint die CentralLogHandler Klasse die in der logging.properties referenziert wird nicht finden zu können.

Any ideas?

Gruß
Alex
 
Zuletzt bearbeitet von einem Moderator:
T

tuxedo

Gast
Hmm, in der JavaDOC für "LogManager" hab ich folgendes gefunden:

http://java.sun.com/javase/6/docs/api/java/util/logging/LogManager.html hat gesagt.:
Note that all classes loaded during LogManager configuration are first searched on the system class path before any user class path. That includes the LogManager class, any config classes, and any handler classes.

Denke das könnte mein Problem sein. Hab aber noch keinen Plan wie ich das "umgehe". In NetBeans klappts mit dem Laden prima. Mit Webstart halt nicht.

- Alex
 
T

tuxedo

Gast
Hmm, so wie es scheint sucht der Classloader, der die Klassen die in logging.properties spezifiziert sind lädt, ausschließlich im system class path.

Links die diese Aussage untermauern:

java.net Forums : How do I turn on file logging in Java ... (vorletzter Post)
Bug ID: 6207335 Handler loading fails for LogManager under Java Web Start (Classloader problem) (mir ist nicht ganz klar ob das schon gefixt wurde)
Kirill Grouchnikov's Blog: Using Java compiler in your Web Start application

Wenn das tatsächlich so ist: Wie soll man dann mit Webstart einen eigenen Handler oder Formatter benutzen?
Gibts eine einfache Art und Weise wie man dem Classloader vermittelt dass er auch die .JAR der Webstart-Anwendung in den System-Classpath übernimmt?
Oder fällt sonst noch jemandem eine Lösung ein?

Mein erster Workaround wäre das konfigurireren der Logger ausschließlich im Sourcecode statt über die Properties file. Aber da ich viele Logger habe, müsste ich so viele Logger "von Hand" konfigurieren statt die "Defaultsettings" aus der logging.properties zu ziehen.

Log4J und Konsorten sind leider keine Lösung.

- Alex

[update]
Okay, sieht denke ich schlecht aus für mich wenn sich seit java 1.4 da nichts getan hat:

http://lopica.sourceforge.net/faq.html hat gesagt.:
Does anyone know how I can configure LogManager to use my own handler?

A: The oracle speaks: Instead of passing on all properties to the Java runtime (that is, java.exe) with say -Dproperty=value Web Start sets all properties in the JNLPClassLoader after the Java runtime is up and running (but before your app gets loaded). The rationale is that allowing setting of arbitrary Java runtime properties is unsecure. Web Start only supports a hand-picked selection of properties considered "safe" for pass-through to the Java runtime command line (e.g. sun.java2d.noddraw). The logging properties are not yet part of this elite circle. Lobby Sun for membership.

Your second attempt fails because of a LogManager restriction: "Note that all classes loaded during LogManager configuration must be on the system class path. That includes the LogManager class, any config classes, and any handler classes." As a work around package your logging classes in a separate jar and roll a Web Start extension installer to install your logging jar in the Java runtime's lib/ext directory.

Aber Java 1.4 ist alt... Ich hoffe da hat sich jetzt doch was geändert ...
 
Zuletzt bearbeitet von einem Moderator:
T

tuxedo

Gast
Ach wie nett dass Sun auch nicht perfekt ist.

In der JavaDOC zu J2SE 6 zur Klasse LogManager steht, wie oben schon geschrieben:

http://java.sun.com/javase/6/docs/api/java/util/logging/LogManager.html hat gesagt.:
Note that all classes loaded during LogManager configuration are first searched on the system class path before any user class path. That includes the LogManager class, any config classes, and any handler classes.

Hab eben die Klasse LogManager durchforstet. Wenn da ein Classloader genutzt wird, dann so:

[HIGHLIGHT="Java"]Class clz = ClassLoader.getSystemClassLoader().loadClass(word);[/HIGHLIGHT]

Ander wird da keine Klasse geladen. Ergo: Es wird ausschließlich der System-Classloader benutzt. Und der hat dank Webstart nur den System-Classpath im Kopf, und nicht den, indem sich meine Webstart-Anwendung befindet.In meinem eigenen Sourcecode kann ich meinen eigenen LogHandler jedenfalls prima instanziieren.

Super Sache. Also darf ich mir jetzt ein krankes WorkAround überlegen.

- Alex
 
T

tuxedo

Gast
Hat hierzu keiner ne Idee? Loggt denn keiner mit eine Custom Loghandler in Verbinung mit Webstart?

-Alex
 
T

tuxedo

Gast
Ach menno, stelle ich denn schon wieder eine Randgruppe dar?

- Alex
 
T

tuxedo

Gast
Log4J dürfte nicht besser sein in dem Fall wenn in der properties-Datei eine Klasse referenziert wird.

Mir ist aber ne "tolle" Idee gekommen:

Verwende SLF4J. Baue da einfach mein "eigenes" Logging drunter und gut ist. Dann kann ich mir die Properties komplett sparen.

- Alex
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
schlingel Webstart/Applet Problem - Classloader-Bug Allgemeine Java-Themen 7
M WebStart problem Allgemeine Java-Themen 2
krgewb Problem mit Umlauten und Eszett bei InputStream Allgemeine Java-Themen 3
Max246Sch Backtracking Problem Box Filler Allgemeine Java-Themen 6
NightVision402 VisualVM Startskript Problem Allgemeine Java-Themen 3
javaBoon86 Email Server Connection Problem Allgemeine Java-Themen 1
F Problem mit PDFBOX Library Allgemeine Java-Themen 1
A Java modul Problem Allgemeine Java-Themen 4
D Read JSON File Problem Allgemeine Java-Themen 9
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
J Problem mit JasperReports Allgemeine Java-Themen 8
M log4j Problem mit jlink Allgemeine Java-Themen 19
8u3631984 Problem beim Mocken von Record Klassen Allgemeine Java-Themen 4
torresbig Website login Problem - Jsoup, wie bisher, klappt nicht! Allgemeine Java-Themen 31
P Selenium . getText Problem Allgemeine Java-Themen 9
A Jar zu Exe Problem Allgemeine Java-Themen 13
sserio Variablen Liste erstellt und ein Problem mit dem Index Allgemeine Java-Themen 6
S Folgendes Problem bei einem Programm Allgemeine Java-Themen 1
stormyark Problem beim Klassen erstellen Allgemeine Java-Themen 1
A Thread.sleep Problem Allgemeine Java-Themen 2
A Problem bei der Nachbarschafttest Allgemeine Java-Themen 11
Splayfer Problem: no main manifest attribute Allgemeine Java-Themen 3
G javamail Problem beim Empfangen von Nachrichten Allgemeine Java-Themen 3
Splayfer JDA Problem mit MessageCounter Allgemeine Java-Themen 0
Splayfer Problem mit BufferedWriter Allgemeine Java-Themen 3
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
N Maven Problem mit Datenbanktreiber (H2 Embedded) Allgemeine Java-Themen 12
T Problem beim Umwandeln in eine Jar-Datei Allgemeine Java-Themen 3
B Einfach Elemente zweier Arraylisten kreuz und quer vergleichen, min und max Problem? Allgemeine Java-Themen 16
C ArrayList Problem Allgemeine Java-Themen 3
kev34 nim-Spiel problem Allgemeine Java-Themen 1
D Firebase retrieve data Problem, Child Element wird nicht angesprochen Allgemeine Java-Themen 0
G Welches Problem besteht bei den Typparametern? Allgemeine Java-Themen 5
temi Problem mit Aufrufreihenfolge bei Vererbung Allgemeine Java-Themen 3
Sumo_ow "ArrayIndexOutofBoundsException: 2" Array Problem Allgemeine Java-Themen 6
T PIM basierend auf netbeans via AnyDesk Problem Allgemeine Java-Themen 3
xGh0st2014 Problem mit Java Array Allgemeine Java-Themen 1
Kirby.exe Verständnis Problem bei Rucksack Problem Allgemeine Java-Themen 6
B Eclipse-Lombok-Problem Allgemeine Java-Themen 19
I Input/Output ObjectOutputStream - Problem Allgemeine Java-Themen 7
1 Multiple Choice Knapsack- Problem Allgemeine Java-Themen 2
kodela Problem mit strukturiertem Array Allgemeine Java-Themen 18
E Problem mit Gridlayout und Button Allgemeine Java-Themen 2
A Array Problem Allgemeine Java-Themen 8
bueseb84 Problem Allgemeine Java-Themen 0
S Problem mit Arrays Allgemeine Java-Themen 1
D Nullpointer Exception Problem Allgemeine Java-Themen 5
B Problem mit meinen Klassen Allgemeine Java-Themen 6
A HashMap Methode "get()"-Problem Allgemeine Java-Themen 28
J Problem beim Umstellen auf Java jdk 13 Allgemeine Java-Themen 3
J Problem bei Install java 13 Allgemeine Java-Themen 3
X Profitable Reise Problem Allgemeine Java-Themen 32
A Problem beim öffnen von Java-Installern Allgemeine Java-Themen 1
Dann07 Problem mit JavaMail API Allgemeine Java-Themen 26
J Problem beim Generischen Klassen und Interfaces Allgemeine Java-Themen 2
L Klassen Algorithmus für das folgende Problem entwickeln? Allgemeine Java-Themen 30
J Clear-Problem Allgemeine Java-Themen 10
B Problem zu einem Java Projekt Allgemeine Java-Themen 6
S JFileChooser Problem Allgemeine Java-Themen 4
M Traveling Salesman - MST Heuristik Problem Allgemeine Java-Themen 4
J Traveling Salesman Problem Allgemeine Java-Themen 14
E Java Editor Problem mit 2er Exceptions Allgemeine Java-Themen 12
C code oder Bibliotheken für 2-Center Problem Allgemeine Java-Themen 4
M Salesman Problem - Bruteforce Algorithmus Allgemeine Java-Themen 23
S Methoden Problem mit NullPointerException Allgemeine Java-Themen 9
Javafan02 Problem mit if-clause Allgemeine Java-Themen 17
J Lombok Problem mit Konstruktoren bei Verberbung Allgemeine Java-Themen 1
kodela Event Handling Problem mit der Alt-Taste Allgemeine Java-Themen 16
W Threads Problem Allgemeine Java-Themen 15
D (Verständnis-)Problem mit Unterklasse Allgemeine Java-Themen 4
S Problem mit Generic bei unmodifiableCollection Allgemeine Java-Themen 4
S jserialcomm Problem Allgemeine Java-Themen 1
Flynn Thread-Problem... Allgemeine Java-Themen 2
J Generische Interface - Problem Allgemeine Java-Themen 3
G Problem beim GUI Allgemeine Java-Themen 9
L Applet Problem "security: Trusted libraries list file not found" ? Allgemeine Java-Themen 7
A OOP Problem beim Berechnen der größten Fläche eines Ringes Allgemeine Java-Themen 19
T Problem mit externen Datenbankzugriff über SSH Tunnel Allgemeine Java-Themen 4
F Problem beim Einlesen einer Textdatei Allgemeine Java-Themen 12
S Java OpenOffice Problem mit Windows-Benutzerwechsel Allgemeine Java-Themen 19
K Threads RAM Problem Allgemeine Java-Themen 20
P Operatoren Problem mit Zähler in recursiver Schleife Allgemeine Java-Themen 2
C Int Problem Allgemeine Java-Themen 8
C J2V8 NodeJs Java Bride Problem und Frage!?!? Allgemeine Java-Themen 1
J Problem bei Hashmap Key-Abfrage Allgemeine Java-Themen 4
C Webseiten Programm problem Allgemeine Java-Themen 5
M LocalDate Problem Allgemeine Java-Themen 4
J "Problem Objektorientierung" Allgemeine Java-Themen 20
geekex Problem Meldung! Was tun?! Allgemeine Java-Themen 19
T Klassen Override Problem Allgemeine Java-Themen 7
L Unbekanntes Problem Allgemeine Java-Themen 1
FrittenFritze Problem mit einer JComboBox, Event temporär deaktivieren Allgemeine Java-Themen 11
Blender3D Java Swing Programm Windows 10 Autostart Problem Allgemeine Java-Themen 2
F HTTPS Zertifikat Problem Allgemeine Java-Themen 3
M OpenCV KNearest Problem Allgemeine Java-Themen 0
Tommy Nightmare Project Euler: Problem 22 Allgemeine Java-Themen 2
C Abstrakte Klasse, lokale Variable-Problem Allgemeine Java-Themen 1
N Vererbung Design-Problem mit vorhandenen, von der Klasse unabhängigen Methoden Allgemeine Java-Themen 12
P Eclipse Projekt anlegen macht Problem Allgemeine Java-Themen 1
RalleYTN META-INF/services Problem Allgemeine Java-Themen 3

Ähnliche Java Themen

Neue Themen


Oben