gpt4 book ai didi

java - 捆绑服务组合 : org. sqlite.JDBC 未找到

转载 作者:行者123 更新时间:2023-11-29 04:20:43 26 4
gpt4 key购买 nike

我有一个使用 SQLite 数据库的应用程序。我把它打包成一个包,我可以看到服务组合上的服务。当我向 Post 或 Get 服务发送请求时,我收到此错误:

java.lang.ClassNotFoundException: 未找到 org.sqlite.JDBC

我在 servicemix 上安装了 SQLite JDBC 驱动程序,但仍然出错。

这是我的 POM:

<modelVersion>4.0.0</modelVersion>

<groupId>asd</groupId>
<artifactId>name</artifactId>
<version>0.0.1-SNAPSHOT</version>

<packaging>bundle</packaging>
<name>Name</name>
<description>Bundle Desc</description>

<dependencies>
<dependency>
<groupId>org.xerial</groupId>
<artifactId>sqlite-jdbc</artifactId>
<version>3.15.1</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-core</artifactId>
<version>3.1.5</version>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-transports-http</artifactId>
<version>3.1.5</version>
</dependency>
</dependencies>

<build>
<plugins>
<plugin>
<groupId>org.apache.felix</groupId>
<artifactId>maven-bundle-plugin</artifactId>
<version>3.3.0</version>
<extensions>true</extensions>
<configuration>
<instructions>
<Bundle-SymbolicName>${project.artifactId}</Bundle-SymbolicName>
<Bundle-Description>${project.description}</Bundle-Description>
<Import-Package>
javax.jws,
javax.wsdl,
javax.xml.namespace,
org.apache.cxf.helpers,
org.osgi.service.blueprint,
org.xerial.sqlite-jdbc,
*
</Import-Package>
<Export-Package>
my.services.package,
org.xerial.sqlite-jdbc
</Export-Package>
</instructions>
</configuration>
</plugin>
</plugins>
</build>

我曾尝试将此 org.xerial.sqlite-jdbc 仅作为导出包和导入包但没有成功。

这是 SQLite 连接的 java 代码:

private void getConnection() throws ClassNotFoundException, SQLException {
Class.forName("org.sqlite.JDBC");
con = DriverManager.getConnection("jdbc:sqlite:SQLiteTest1.db");
initialise();
}

该应用程序可以在本地运行,但不能在 servicemix 上运行。

最佳答案

您的 java 代码不适合 OSGi。默认情况下,在 OSGi 中,每个类都由它所在的包的类加载器加载。

所以你自己的类是由你的包的类加载器加载的。由于您有 org.sqlite 的 Import-Package 语句,因此您的代码可以访问 sqlite 驱动程序类。

问题是 DriverManager 自己加载类。 DriverManager 由系统包(felix framework bundle)提供。这个包当然没有 sqllite 的导入包。所以它不能加载这个类。

虽然有一个简单的解决方法。 DriverManager 允许您设置线程上下文类加载器。您可以将此类加载器设置为您自己的包的类加载器。这样 DriverManager 就可以看到 sqllite 类。不过,这只是一种解决方法。

在 OSGi 中,避免问题的最好方法就是不直接加载任何类。在 jdbc 的情况下,这可以通过使用 DataSource 类而不是 DriverManager 来完成。参见 this post .

另一种选择是使用 pax-jdbc。它允许从配置创建数据源服务。通过这种方式,您可以使您的包独立于实际的数据库驱动程序,并且仍然可以避免手动加载类。 See this example .

关于java - 捆绑服务组合 : org. sqlite.JDBC 未找到,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49357764/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com