Maven Problem mit Datenbanktreiber (H2 Embedded)

C

christian30251

Mitglied
Hallo zusammen!

Ich habe ein Problem, welches ich auch nach stundenlangem Recherchieren im WWW nicht lösen kann.
Kurz beschrieben geht es um folgendes:

Ich habe kürzlich ein Projekt fertiggestellt, welches Daten ein einer MySQL-DB speichert/ausliest...
Jedenfalls wollte ich im nachhinein auf eine H2 embedded DB umstellen. Dazu habe ich die Dependency für Maven aus dem MavenRepo installiert, die Java Klasse angepasst. Ich habe die JAR File gebuildet, das ganze mit Launch4j noch zu einer .exe gebaut und anfänglich hat alles funktioniert. Nur geht es jetzt nicht mehr.

Das spannende daran: Wenn ich das ganze in IntelliJ IDEA starte (javafx:run als Mavengoal) dann funktioniert es ohne Probleme! Aber sobald ich versuche die gebuildete .jar Datei auszuführen, bekomme ich den Fehler: "SQLException: No suitable driver found" obwohl ich nichts wirklich geändert habe im Vergleich zur funktionierenden Version. Genau der selbe Code funktioniert in der IDE problemlos.

Der Code sieht so aus (DB Connection Klasse):
DatabaseController:
public class DatabaseController {

    private static final String USERNAME = "guard";
    private static final String PASSWORD = "guard+22";

    /**
     * Establishes a connection and returns the connection object.
     *
     * @return Connection object
     * @throws SQLException If the connection fails, a SQLException is thrown.
     */
    public Connection connect() throws SQLException {
        return DriverManager.getConnection("jdbc:h2:~/guard", USERNAME, PASSWORD);
    }
}

Ich habe alles mögliche probiert:
- mvn clean install
- IDE Caches leeren und mehrere Restarts
- Downgrade der H2 Version in der pom.xml (diese befindet sich weiter unten)
- Treiber per "Class.forName()" versucht zu laden
- etc. etc.

NICHTS hilft....
Hoffe dass hier jemand einen guten Rat für mich hat.... vielen Dank schonmal!
Hier noch die Pom.xml ...

pom.xml:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xmlns="http://maven.apache.org/POM/4.0.0"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>at.christianreisenauer</groupId>
    <artifactId>DrugGuard</artifactId>
    <version>1.0</version>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <maven.compiler.source>16</maven.compiler.source>
        <maven.compiler.target>16</maven.compiler.target>
    </properties>

    <dependencies>
        <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.25</version>
        </dependency>
        <dependency>
            <groupId>org.openjfx</groupId>
            <artifactId>javafx-controls</artifactId>
            <version>17-ea+11</version>
        </dependency>
        <dependency>
            <groupId>org.openjfx</groupId>
            <artifactId>javafx-fxml</artifactId>
            <version>17-ea+11</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.apache.maven.plugins/maven-shade-plugin -->
        <dependency>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-shade-plugin</artifactId>
            <version>3.2.4</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/com.h2database/h2 -->
        <!-- https://mvnrepository.com/artifact/com.h2database/h2 -->
        <dependency>
            <groupId>com.h2database</groupId>
            <artifactId>h2</artifactId>
            <version>1.4.197</version>
        </dependency>

    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.8.0</version>
                <configuration>
                    <release>16</release>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.openjfx</groupId>
                <artifactId>javafx-maven-plugin</artifactId>
                <version>0.0.4</version>
                <configuration>
                    <mainClass>application.App</mainClass>
                </configuration>
            </plugin>
            <!-- build a runnable jar -->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-shade-plugin</artifactId>
                <version>3.2.4</version>
                <executions>
                    <execution>
                        <goals>
                            <goal>shade</goal>
                        </goals>
                        <configuration>
                            <shadedArtifactAttached>true</shadedArtifactAttached>
                            <transformers>
                                <transformer
                                        implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
                                    <mainClass>application.App</mainClass>
                                </transformer>
                            </transformers>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>
</project>

Nochmals herzlichen Dank im Vorhinein!!

Beste Grüße
Christian
 
C

christian30251

Mitglied
Danke für deine Antwort! Ich habe folgendes ausgeführt:

- mvn clean install

Dann die jar Datei (shader Plugin von Maven) ausgeführt - Fehler (siehe oben).
Die jar mit launch4j zu einer .exe zu machen hat dann auch nichts geändert....

Beste Grüße

Christian
 
kneitzel

kneitzel

Top Contributor
Die jar Datei ist unter dem Strich auch nur eine ZIP Datei. Du kannst es also umbenennen und dann mit dem Tool Deiner Wahl ansehen.
 
C

christian30251

Mitglied
Ahhh. Wieder was gelernt! Danke!

Also ich habe jetzt reingeschaut.
Der Treiber scheint da zu sein....

org/h2/Driver.class

Den Treiber meldet er jedenfalls als vermisst...?

EDIT:

Jaaaa! Endlich hat es geklappt. Eure Beiträge haben mich nochmal zum Denken angestoßen. Ich habe jetzt den Treiber über die Klasse DriverManager geladen (voher über "Class.forName()" usw. probiert), und es funktioniert alles. Herzlichen Dank nochmal an alle!!! :)
 
Zuletzt bearbeitet:
kneitzel

kneitzel

Top Contributor
Also die Treiber müssen sich selbst registrieren. Das läuft über Services.

Wenn Du in die jar vom Treiber rein schaust, dann dürfte da in META-INF/services eine java.sql.Driver Datei sein, die einfach nur den Klassennamen des Treibers enthält.

Ist diese Datei auch vorhanden in deinem jar?
 
C

christian30251

Mitglied
Also die Treiber müssen sich selbst registrieren. Das läuft über Services.

Wenn Du in die jar vom Treiber rein schaust, dann dürfte da in META-INF/services eine java.sql.Driver Datei sein, die einfach nur den Klassennamen des Treibers enthält.

Ist diese Datei auch vorhanden in deinem jar?

Falls es noch aktuell ist (vielleicht haben sich unsere Beiträge überschnitten) - ja, die Datei ist da!

Wie auch immer. Mich freut es einfach, dass es läuft! ;)
 
mihe7

mihe7

Top Contributor
Das sollte aber nicht sein, zumindest kapier ich gerade nicht, warum der Treiber sich nicht registriert, wenn in dem geshadeten Jar die META-INF/services/java.sql.Driver vorhanden ist. Was steht denn in der Datei drin?!?
 
kneitzel

kneitzel

Top Contributor
Schafft das Shading Plugin ein merge von mehreren Dateien? in der Pom sind ja zwei JDBC Treiber enthalten wenn ich das richtig gesehen habe:
Java:
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.25</version>
        </dependency>

        <dependency>
            <groupId>com.h2database</groupId>
            <artifactId>h2</artifactId>
            <version>1.4.197</version>
        </dependency>

Daher könnte eine Ursache sein, dass da nur die mysql Klasse enthalten ist: com.mysql.cj.jdbc.Driver
 
C

christian30251

Mitglied
Das sollte aber nicht sein, zumindest kapier ich gerade nicht, warum der Treiber sich nicht registriert, wenn in dem geshadeten Jar die META-INF/services/java.sql.Driver vorhanden ist. Was steht denn in der Datei drin?!?
Folgendes steht drinnen:
Driver.class:
//
// Source code recreated from a .class file by IntelliJ IDEA
// (powered by FernFlower decompiler)
//

package org.h2;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.DriverPropertyInfo;
import java.sql.SQLException;
import java.util.Properties;
import java.util.logging.Logger;
import org.h2.jdbc.JdbcConnection;
import org.h2.message.DbException;
import org.h2.upgrade.DbUpgrade;

public class Driver implements java.sql.Driver, JdbcDriverBackwardsCompat {
    private static final Driver INSTANCE = new Driver();
    private static final String DEFAULT_URL = "jdbc:default:connection";
    private static final ThreadLocal<Connection> DEFAULT_CONNECTION = new ThreadLocal();
    private static volatile boolean registered;

    public Driver() {
    }

    public Connection connect(String var1, Properties var2) throws SQLException {
        try {
            if (var2 == null) {
                var2 = new Properties();
            }

            if (!this.acceptsURL(var1)) {
                return null;
            } else if (var1.equals("jdbc:default:connection")) {
                return (Connection)DEFAULT_CONNECTION.get();
            } else {
                Connection var3 = DbUpgrade.connectOrUpgrade(var1, var2);
                return (Connection)(var3 != null ? var3 : new JdbcConnection(var1, var2));
            }
        } catch (Exception var4) {
            throw DbException.toSQLException(var4);
        }
    }

    public boolean acceptsURL(String var1) {
        if (var1 != null) {
            if (var1.startsWith("jdbc:h2:")) {
                return true;
            }

            if (var1.equals("jdbc:default:connection")) {
                return DEFAULT_CONNECTION.get() != null;
            }
        }

        return false;
    }

    public int getMajorVersion() {
        return 1;
    }

    public int getMinorVersion() {
        return 4;
    }

    public DriverPropertyInfo[] getPropertyInfo(String var1, Properties var2) {
        return new DriverPropertyInfo[0];
    }

    public boolean jdbcCompliant() {
        return true;
    }

    public Logger getParentLogger() {
        return null;
    }

    public static synchronized Driver load() {
        try {
            if (!registered) {
                registered = true;
                DriverManager.registerDriver(INSTANCE);
            }
        } catch (SQLException var1) {
            DbException.traceThrowable(var1);
        }

        return INSTANCE;
    }

    public static synchronized void unload() {
        try {
            if (registered) {
                registered = false;
                DriverManager.deregisterDriver(INSTANCE);
            }
        } catch (SQLException var1) {
            DbException.traceThrowable(var1);
        }

    }

    public static void setDefaultConnection(Connection var0) {
        if (var0 == null) {
            DEFAULT_CONNECTION.remove();
        } else {
            DEFAULT_CONNECTION.set(var0);
        }

    }

    public static void setThreadContextClassLoader(Thread var0) {
        try {
            var0.setContextClassLoader(Driver.class.getClassLoader());
        } catch (Throwable var2) {
        }

    }

    static {
        load();
    }
}

Schafft das Shading Plugin ein merge von mehreren Dateien? in der Pom sind ja zwei JDBC Treiber enthalten wenn ich das richtig gesehen habe:
Java:
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.25</version>
        </dependency>

        <dependency>
            <groupId>com.h2database</groupId>
            <artifactId>h2</artifactId>
            <version>1.4.197</version>
        </dependency>

Daher könnte eine Ursache sein, dass da nur die mysql Klasse enthalten ist: com.mysql.cj.jdbc.Driver
Vielleicht hast du recht und es ist das? Wäre irgendwie logisch, jetzt wo du es sagst. Und wenn man dem Treiber explizit sagt, was er laden soll, dann gehts ...
 
kneitzel

kneitzel

Top Contributor
Das ist aber doch nicht der Inhalt der Datei META-INF/services/java.sql.Driver in deinem jar. Das wäre komplett falsch.

Da müsste einfach nur etwas drin stehen wie:
org.h2.Driver
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
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
F Java Mail Problem: Authentifizierung wird nicht immer mitgeschickt Allgemeine Java-Themen 1
I Problem beim Aufrufen, von Objektmethoden/ -variablen Allgemeine Java-Themen 6
K Thread Problem Allgemeine Java-Themen 6
A Reflection Problem Allgemeine Java-Themen 15
RalleYTN Problem bei Schleife die durch einen 2D raum iterieren soll Allgemeine Java-Themen 1
S FileReader-Problem in Eclipse Allgemeine Java-Themen 8
H Collector Generics Problem (incl. Stream & Lambda) Allgemeine Java-Themen 4
1 Problem mit Selenium WebDriver findElement bei Instagram Bot Allgemeine Java-Themen 3
I JAXB Problem Allgemeine Java-Themen 9
Tausendsassa Input/Output Problem mit der gleichzeitigen Ausgabe zweier Threads Allgemeine Java-Themen 8
C Input/Output Problem bei Datei verschiebung mit File.move und Paths.get() Allgemeine Java-Themen 26
F Problem mit "package" Allgemeine Java-Themen 7
D Problem mit zu langen Verzeichnisnamen auf Laufwerken Allgemeine Java-Themen 8
M Problem mit BufferedImage und PrinterJob im Querformat Allgemeine Java-Themen 1
C JTextPane + HTMLEditorKit withe space problem Allgemeine Java-Themen 0
Q Game of Life "unendlichkeits" Problem Allgemeine Java-Themen 4
0 Erste Schritte Rekursions Problem bei Zahlenvergabe Allgemeine Java-Themen 3
VfL_Freak JDK installieren Problem mit Erstellungspfad nach Wechsel von Java7 auf Java8 Allgemeine Java-Themen 1
Seikuassi Input/Output Java transferTo ByteArrayOutputStream-Problem Allgemeine Java-Themen 4
M Arrays.sort Problem Allgemeine Java-Themen 2
Seikuassi Compiler-Fehler Xuggler-Problem-Video > Audio bzw. Video > Audio-API Allgemeine Java-Themen 2
T Xbox Emulator Problem Allgemeine Java-Themen 9
C Klassen Problem mit Funktion einer Generischen Klasse die ein Interface implementiert Allgemeine Java-Themen 0
K Problem: Java-Klasse mit mehreren Threads als eigenen Prozess starten Allgemeine Java-Themen 3
J Datentypen Kalender problem Allgemeine Java-Themen 11
G problem: array aus objekten Allgemeine Java-Themen 10

Ähnliche Java Themen


Oben