Probleme mit dem URLClassLoader

Status
Nicht offen für weitere Antworten.

Julian84

Neues Mitglied
Hi,
ich hab zur Zeit an folgendem Problem zu knabbern:

Nachdem wir zu unserem Projekt ein paar weitere JAR-Files hinzugefügt hatten, fing Windows plötzlich an zu meckern, der Classpath sei zu lang. Auf der Suche nach möglichen Lösungen haben wir dann im Sun-Forum eine Runner.class gefunden. Das ganze soll dann wie folgt ausssehen:

Code:
/**
 * Runner.java
 *
 * Executes a JAVA class with a class path consisting of elements written in a given text file.
 * The text file name is classpath.txt . It must be accessible by the starting class path.
 * It may consist of one or more lines.
 * Each line is written in the same way as normally done when setting the class path.
 *
 * Usage: java Runner SomeClassName [SomeParam ...]
 * This will execute SomeClassName (with the optional SomeParam(s)).
 *
 */

package com.firma.projekt;

import java.io.*;
import java.util.*;
import java.net.*;
import java.lang.reflect.*;

public class Runner
{
    static final String CLASSPATH_FILE = "classpath.txt";
    private String className;
    private String[] args;
    private String classPath;
    private URL[] classUrls;
    private URLClassLoader loader;

    public static void main(String[] args) throws Exception
    {
      (new Runner()).exec(args);
    }

    private void exec(String[] args) throws Exception
    {
        getParameters(args);
        getClasspathFromFileResource();
        convertClasspathToUrls();
        executeClassWithNewLoader();
    }

    private void getParameters(String[] args) throws Exception
    {
        if (args.length == 0)
            throw new Exception("MUST SPECIFY A CLASS NAME");
        className = args[0];
        this.args = new String[args.length - 1];
        for (int i = 0; i < this.args.length; i++)
            this.args[i] = args[i + 1];
    }

    private void getClasspathFromFileResource() throws Exception
    {
        InputStream is = null;
        try
        {
            is = getClass().getResourceAsStream(CLASSPATH_FILE);
            if (is == null)
                return;

            BufferedReader br = new BufferedReader(new InputStreamReader(is));
            StringBuffer strBuf = new StringBuffer();
            String line;

            while ((line = br.readLine()) != null)
            {
              strBuf.append(line).append(File.pathSeparator);
            }
            classPath = strBuf.toString();
        }
        finally
        {
            if (is != null)
                try { is.close(); }
                catch (IOException e) {System.out.println("err1");}
        }
    }

    private void convertClasspathToUrls() throws Exception
    {
        StringTokenizer strTok = new StringTokenizer(classPath, File.pathSeparator);
        ArrayList urlList = new ArrayList();

        while (strTok.hasMoreTokens())
        {
            File file = new File(strTok.nextToken());
            urlList.add(file.toURL());
        }
        classUrls = new URL[urlList.size()];
        urlList.toArray(classUrls);
    }

    private void executeClassWithNewLoader() throws Exception
    {
        loader = new URLClassLoader(classUrls, this.getClass().getClassLoader());
        Class cls = Class.forName(className, true, loader);
        Method method = cls.getDeclaredMethod("main", new Class[]
        {
          String[].class
        });
        method.invoke(null, new Object[] { args });
    }

}

Die entsprechende classpath.txt liegt im richtigen Verzeichnis. Ich hab mir auch schonmal ausgeben lassen, welche URLs in der "classUrls" gespeichert werden, die sind alle korrekt.

Wenn ich dann die Runner wie folgt aufrufe: "java com.firma.projekt.Runner com.firma.projekt.Control" wird auch die Control gestartet. Die erzeugt dann eine neue Instanz von der Klasse com.firma.projekt.Client, und dort werden zum ersten mal Imports aus der classpath.txt gebraucht. Und an der Stelle knallts dann:

Code:
Exception in thread "main" java.lang.reflect.InvocationTargetException
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
        at java.lang.reflect.Method.invoke(Method.java:324)
        at com.firma.projekt.Runner.executeClassWithNewLoader(Runner.java:106)
        at com.firma.projekt.Runner.exec(Runner.java:42)
        at com.firma.projekt.Runner.main(Runner.java:34)
Caused by: java.lang.NoClassDefFoundError: com/progress/open4gl/javaproxy/ProObject
        at com.firma.projekt.Control.main(Control.java:23)
        ... 7 more

Ich hab auch schon versucht in der Klasse Control mal ein paar verschiedene Klassen aus der classpath.txt zu verwenden, dann knallts halt entsprechend dort schon.

Interessant find ich auch folgendes: Wenn ich nach " Class cls = Class.forName(className, true, loader);" mir mal Ausgaben anzeigen lasse
Code:
System.out.println(loader.getURLs().length);
System.out.println(((URLClassLoader) cls.getClassLoader()).getURLs().length);
bekomme ich bei der ersten Ausgabe 83 (82 aus der classpath.txt und eine aus dem CLASSPATH mit dem die Runner gestartet wird), bei der zweiten allerdings nur 1! Ich denke, dass an der Stelle bereits "alles vorbei" ist.

Allerdings konnte ich trotz intensivem googlen und nachlesen keine funktionierende Lösung finden. Ihr seid also quasi meine letzte Hoffnung. :)

Danke schonmal für eure Mühe,
Julian
 

Wildcard

Top Contributor
Wow! Wusste gar nicht das der Classpath zu lang werden kann :shock:
Läuft die Anwendung zufällig über Webstart?
 

Julian84

Neues Mitglied
Naja Du siehst ja, 83 Jar-Files bzw. Verzeichnisse im Classpath, da sind die 1024 Zeichen, mit den Windows vor dem XP Zeit alter wohl maximal zurecht kam, schnell erreicht. Natürlich könnten wir die JAR-Files alle in ein Verzeichnis packen und dann 1.jar 2.jar und so weiter nennen, aber das wäre eine sehr wartungsunfreundliche Lösung.

Zu deiner Frage: Die Anwendung läuft nicht über Webstart.

Ach ja, und als ergänzende Info: Wir benutzen das JDK 1.4.2.

Nochmals danke an alle, die sich durch meinen Text und den Sourcecode quälen. :)

Julian
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
R Probleme mit dem URLClassLoader Allgemeine Java-Themen 16
M Probleme mit URLClassLoader in Verbindung mit rmi Allgemeine Java-Themen 6
C Probleme beim Erstellen eines runnable-jar files Allgemeine Java-Themen 1
S Umstellung von File auf Path - Probleme mit Stream Allgemeine Java-Themen 5
C Probleme mit javax.mail.Session Allgemeine Java-Themen 8
M tomcat probleme Allgemeine Java-Themen 1
N Division macht Probleme Allgemeine Java-Themen 14
B Java Reflection Probleme beim wehcselseitigen Referenzieren zweier Klassen/Objekte Allgemeine Java-Themen 14
MarvinsDepression Probleme mit relativem Dateipfad Allgemeine Java-Themen 1
G Geotools Probleme nach PC-Wechsel Allgemeine Java-Themen 6
nibe1501 GUI Probleme Allgemeine Java-Themen 16
C Probleme mit dem WindowBuilder Allgemeine Java-Themen 3
P Selenium . Probleme ein Iron Icon Element anzusprechen Allgemeine Java-Themen 2
B Compiler-Fehler Probleme beim Kompilieren mit Jsoup Allgemeine Java-Themen 8
K VisualVM Profiling Remote Probleme Allgemeine Java-Themen 1
O Leerzeichen und Umlaute im Pfad einer Java Applikation machen Probleme Allgemeine Java-Themen 13
M Probleme bei Eclipse wenn ich entpacke Allgemeine Java-Themen 15
D Regex Probleme Allgemeine Java-Themen 2
M Probleme jar datei. Allgemeine Java-Themen 2
L Vererbung Verständnis Probleme Vererbung Allgemeine Java-Themen 2
Dann07 Probleme mit OpenAL Allgemeine Java-Themen 0
V Threads Probleme beim Aufrufen von Methoden einer anderen Klasse (Threads) Allgemeine Java-Themen 14
V Compiler-Fehler Online Compiler Probleme Allgemeine Java-Themen 4
M Probleme mit Negamax-Algorithmus Allgemeine Java-Themen 29
M Probleme mit BigDecimal Allgemeine Java-Themen 1
T Probleme mit NumberFormat Allgemeine Java-Themen 5
J Probleme exe-Start mit Task Scheduler Allgemeine Java-Themen 1
B Input/Output Probleme beim Ausführen von Shell-Befehlen mit Java Allgemeine Java-Themen 28
J Probleme beim einbinden von Zip4j library Allgemeine Java-Themen 6
F Variablen Palindromzahl (Probleme mit Methode) Allgemeine Java-Themen 9
K Data Konverter - Probleme mit Byte[] Kodierung Allgemeine Java-Themen 3
T Probleme mit dem Pfad zum Propertie file Allgemeine Java-Themen 7
H Swing HashMap zu Tabelle macht mir Probleme Allgemeine Java-Themen 4
Neoline Interpreter-Fehler Probleme mit Arrays.toString Allgemeine Java-Themen 7
F SQLite mit Java / Probleme beim INSERT Befehl Allgemeine Java-Themen 4
J Erste Schritte Probleme mit der Hauptklasse Allgemeine Java-Themen 14
J Tetris Probleme bei Klassen Allgemeine Java-Themen 14
J MinMax VierGewinnt Probleme Allgemeine Java-Themen 22
J Probleme mit CodeCoverage und Lombok Equals Allgemeine Java-Themen 1
S Eclipse Probleme beim Implementieren / Ausführen von jUnit 5-Test Suites Allgemeine Java-Themen 14
R Snake Probleme Allgemeine Java-Themen 2
A Probleme beim Verstehen einer Aufgabenstellung Allgemeine Java-Themen 11
RalleYTN 3D Objekt Translation basierend auf Rotation (Probleme mit Z Rotation) Allgemeine Java-Themen 0
Bluedaishi Druck Probleme mit PDF dateien Allgemeine Java-Themen 4
G Ant Probleme bei einer Installation die Apache ant+ivy verwendet Allgemeine Java-Themen 14
E TableView Probleme Allgemeine Java-Themen 7
perlenfischer1984 Probleme beim Mocken Allgemeine Java-Themen 6
S Kaffemaschine Programmierung Probleme Allgemeine Java-Themen 2
K Threads Runtime und Process Probleme Allgemeine Java-Themen 3
S Probleme mit unterschiedlichen Java-Versionen (Mac OS X 10.11) Allgemeine Java-Themen 0
S Event Handling keyPressed()-Probleme Allgemeine Java-Themen 2
VfL_Freak Große und seltsame Probleme nach Java-Update auf V1.8.0_91 Allgemeine Java-Themen 3
P Probleme mit Grafik (Java) Allgemeine Java-Themen 6
R probleme beim starten von jar unter linux Allgemeine Java-Themen 2
H Probleme mit DAY_OF_WEEK Allgemeine Java-Themen 4
Arif Probleme mit NullPointerException Allgemeine Java-Themen 2
E Probleme mit nextInt() und Exception Allgemeine Java-Themen 35
Streeber Probleme mit AWT-EventQueue: ArrayList Elemente hinzufügen Allgemeine Java-Themen 1
D Performance-Probleme mit Joda-Time Allgemeine Java-Themen 3
M Probleme beim rechnen, bei Zahlen mit führenden Nullen. Allgemeine Java-Themen 7
RalleYTN Probleme mit Encrypting Allgemeine Java-Themen 10
M Probleme mit Schriftarten PDFBox Allgemeine Java-Themen 3
J Probleme mit der Java-Runtime Allgemeine Java-Themen 10
G Probleme mit BufferedWriter und URL Allgemeine Java-Themen 4
S Probleme mit meinem MacBook Pro DRINGEND HILFE erbeten! Allgemeine Java-Themen 17
Androbin Interpreter-Fehler Probleme mit Rekursion - StackOverflowError Allgemeine Java-Themen 8
E JCuda-0.6.5 Probleme beim ausführen der Datei Allgemeine Java-Themen 0
M Runtime.exec() verursacht auf manchen Systemen Probleme - Ursache unklar Allgemeine Java-Themen 2
W JNDI - LDAP - Probleme beim editieren von Usern Allgemeine Java-Themen 0
R DBUnit Performance Probleme Allgemeine Java-Themen 0
S Probleme mit Collection Allgemeine Java-Themen 7
L Probleme mit Jar Allgemeine Java-Themen 6
N Zahlensysteme umrechnen; Probleme beim Umwandeln Allgemeine Java-Themen 4
K OOP OOP Gui Spiel + Vererbungen Probleme durch Nichtwissen!! Allgemeine Java-Themen 1
F Java Native/Shared Library (.so) laden macht Probleme Allgemeine Java-Themen 3
J Synchronized Probleme Allgemeine Java-Themen 7
J Java Progressbar & Download Probleme Allgemeine Java-Themen 10
S Probleme mit dem filechooser Allgemeine Java-Themen 1
J Comperator Probleme Allgemeine Java-Themen 4
A Probleme beim auslesen von Quelltext (HTML) Allgemeine Java-Themen 5
S Probleme mit Webappplikation Allgemeine Java-Themen 5
L Plötzlich Probleme mit der JVM :( Allgemeine Java-Themen 6
S starke performance probleme des forums Allgemeine Java-Themen 10
K Probleme bei Berechnung der Komplexität Allgemeine Java-Themen 7
R JRE Ablaufdatum seit 7u10 - Probleme bei selbst ausgelieferter JRE bekannt? Allgemeine Java-Themen 3
H Reg Exp Probleme Allgemeine Java-Themen 5
M Classpath Probleme bei JAR Generierung Allgemeine Java-Themen 2
S Probleme mit JAVA-Installation Allgemeine Java-Themen 3
D Probleme bei for-Schleife Allgemeine Java-Themen 4
R Probleme mit Javadoc Allgemeine Java-Themen 2
G Gson Probleme Allgemeine Java-Themen 2
P KI für TicTacToe programmieren > Probleme Allgemeine Java-Themen 2
M Google App Engine macht Probleme Allgemeine Java-Themen 4
H Probleme mit finally-Block und close() Allgemeine Java-Themen 4
F 2d array probleme Allgemeine Java-Themen 2
M 3D-Grafik Probleme beim drehen von Objekten Allgemeine Java-Themen 9
T Interface Probleme Allgemeine Java-Themen 8
C Eclipse Probleme bei selbst erstelltem Algorithmus Allgemeine Java-Themen 2
M Probleme mit String in Label übergeben. Allgemeine Java-Themen 6
H MediaManager Fragen/Probleme Allgemeine Java-Themen 6

Ähnliche Java Themen

Neue Themen


Oben