Не могу найти класс драйвера postgresql - PullRequest
0 голосов
/ 27 марта 2019

Я пытаюсь использовать библиотеку HikariCP для пулов соединений PostgreSQL в Java. Я использую Maven, и я получаю эту ошибку: java.lang.ClassNotFoundException: org.postgresql.Driver.

Я пытался использовать разные версии драйвера PostgreSQL, но ни одна из них не сработала. (Я сделал больше, но я столкнулся с этой проблемой, которую я не принял к сведению)

org.postgresql.ds.PGSimpleDataSource, org.postgresql.Driver и com.impossibl.postgres.jdbc.PGDataSource по-прежнему выдают эту ошибку, хотя в руководстве HikariCP сказано, что использовать первое или третье. Второе, что я нашел из исследования.

Мой Maven:

(...)
    <build>
        <defaultGoal>clean package</defaultGoal>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.7.0</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-shade-plugin</artifactId>
                <version>3.1.0</version>
                <executions>
                    <execution>
                        <phase>package</phase>
                        <goals>
                            <goal>shade</goal>
                        </goals>
                        <configuration>
                            <minimizeJar>true</minimizeJar>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
        </plugins>
        <resources>
            <resource>
                <directory>src/main/resources</directory>
                <filtering>true</filtering>
            </resource>
        </resources>
    </build>

    <repositories>
        <repository>
            <id>spigotmc-repo</id>
            <url>https://hub.spigotmc.org/nexus/content/groups/public/</url>
        </repository>
    </repositories>

    <dependencies>
        <dependency>
            <groupId>org.spigotmc</groupId>
            <artifactId>spigot-api</artifactId>
            <version>1.12.2-R0.1-SNAPSHOT</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>com.zaxxer</groupId>
            <artifactId>HikariCP</artifactId>
            <version>3.3.1</version>
            <scope>compile</scope>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-simple</artifactId>
            <version>1.6.4</version>
            <scope>compile</scope>
        </dependency>
        <dependency>
            <groupId>org.postgresql</groupId>
            <artifactId>postgresql</artifactId>
            <version>42.2.5</version>
        </dependency>
    </dependencies>
</project>

Что я использую для создания этой ошибки:

        try {
            Class.forName("org.postgresql.Driver");
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
            System.out.println("Failed to load.");
        }

        HikariConfig config = new HikariConfig("database.properties");
        ds = new HikariDataSource(config);

(Конструктор HikariDataSource(config); также выдает эту ошибку)

Я полагаю, что причина этого заключается в том, что драйвер не попадает в путь к классам - однако все попытки, которые я пытался сделать, не могут этого сделать. Это проблема водителя, не входящего в финальную банку (по моему убеждению): org.postgresql is not found in final jar.

Фактическая ошибка:

[20:16:35 WARN]: java.lang.ClassNotFoundException: org.postgresql.Driver
[20:16:35 WARN]:        at java.net.URLClassLoader.findClass(Unknown Source)
[20:16:35 WARN]:        at org.bukkit.plugin.java.PluginClassLoader.findClass(PluginClassLoader.java:152)
[20:16:35 WARN]:        at org.bukkit.plugin.java.PluginClassLoader.findClass(PluginClassLoader.java:100)
[20:16:35 WARN]:        at java.lang.ClassLoader.loadClass(Unknown Source)
[20:16:35 WARN]:        at java.lang.ClassLoader.loadClass(Unknown Source)
[20:16:35 WARN]:        at java.lang.Class.forName0(Native Method)
[20:16:35 WARN]:        at java.lang.Class.forName(Unknown Source)
[20:16:35 WARN]:        at me.test.kitpvp.Kitpvp.onEnable(Kitpvp.java:43)
[20:16:35 WARN]:        at org.bukkit.plugin.java.JavaPlugin.setEnabled(JavaPlugin.java:264)
[20:16:35 WARN]:        at org.bukkit.plugin.java.JavaPluginLoader.enablePlugin(JavaPluginLoader.java:337)
(...)
[20:16:35 INFO]: Failed to load.
[20:16:35 WARN]: 74 [Server thread] INFO com.zaxxer.hikari.HikariDataSource - HikariPool-1 - Starting...

редактирует

  • Добавление <scope>compile</scope> дало те же результаты - не сработало.
...