我正在创建一个RESTful应用程序,但我无法为新连接进行转换。 我的应用程序服务器是Wildfly 10.0。
standalone-full.xml中的DataSource和驱动程序:
<datasource jndi-name="java:jboss/datasources/PostgreDS" pool-name="PostgreDS" enabled="true" use-java-context="true">
<connection-url>jdbc:postgresql://192.168.0.112:5432/bdns</connection-url>
<driver>postgresql</driver>
<transaction-isolation>TRANSACTION_READ_COMMITTED</transaction-isolation>
<pool>
<min-pool-size>10</min-pool-size>
<max-pool-size>40</max-pool-size>
<prefill>true</prefill>
</pool>
<security>
<user-name>sa</user-name>
<password>000000</password>
</security>
<statement>
<prepared-statement-cache-size>32</prepared-statement-cache-size>
<share-prepared-statements>true</share-prepared-statements>
</statement>
</datasource>
<drivers>
<driver name="postgresql" module="org.postgresql">
<xa-datasource-class>org.postgresql.xa.PGXADataSource</xa-datasource-class>
</driver>
</drivers>
Java代码ConnectionMng.java:
package dao;
import java.sql.Connection;
import java.sql.SQLException;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.sql.DataSource;
import org.jboss.jca.adapters.jdbc.jdk7.WrappedConnectionJDK7;
import org.postgresql.jdbc.PgConnection;
public class ConnectionMng {
private DataSource ds;
private ConnectionMng() throws NamingException {
this.ds = (DataSource)new InitialContext().lookup("java:jboss/datasources/PostgreDS");
}
public PgConnection getPgConnection() throws SQLException {
WrappedConnectionJDK7 wrappedConn = (WrappedConnectionJDK7)ds.getConnection();
Connection underlyingConn = wrappedConn.getUnderlyingConnection();
return (PgConnection)underlyingConn;
}
}
发生异常:
ClassCastException: org.jboss.jca.adapters.jdbc.jdk7.WrappedConnectionJDK7 cannot be cast to org.jboss.jca.adapters.jdbc.jdk7.WrappedConnectionJDK7
的pom.xml:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
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>Core</groupId>
<artifactId>Core</artifactId>
<version>1.0.0-SNAPSHOT</version>
<packaging>war</packaging>
<name>Core</name>
<description>Core</description>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<java.version>1.8</java.version>
<javac.target>1.8</javac.target>
<postgresql.enforce.jdk.version>[1.7,1.8)</postgresql.enforce.jdk.version>
</properties>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.3.3.RELEASE</version>
</parent>
<dependencies>
<dependency>
<groupId>org.wildfly</groupId>
<artifactId>wildfly-connector</artifactId>
<version>10.0.0.Final</version>
</dependency>
<dependency>
<groupId>org.postgresql</groupId>
<artifactId>postgresql</artifactId>
</dependency>
<dependency>
<groupId>javax</groupId>
<artifactId>javaee-api</artifactId>
<version>7.0</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-dbcp2</artifactId>
</dependency>
<dependency>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-mapper-asl</artifactId>
<version>1.9.13</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>3.12</version>
</dependency>
<dependency>
<groupId>commons-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>1.3.1</version>
</dependency>
<dependency>
<groupId>com.thoughtworks.xstream</groupId>
<artifactId>xstream</artifactId>
<version>1.4.8</version>
</dependency>
<dependency>
<groupId>com.github.junrar</groupId>
<artifactId>junrar</artifactId>
<version>0.7</version>
</dependency>
<dependency>
<groupId>org.zeroturnaround</groupId>
<artifactId>zt-zip</artifactId>
<version>1.9</version>
<type>jar</type>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
</exclusion>
<exclusion>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
</exclusion>
</exclusions>
</dependency>
</dependencies>
<build>
<sourceDirectory>src</sourceDirectory>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
<plugin>
<artifactId>maven-war-plugin</artifactId>
<configuration>
<warSourceDirectory>WebContent</warSourceDirectory>
<failOnMissingWebXml>false</failOnMissingWebXml>
</configuration>
</plugin>
</plugins>
</build>
答案 0 :(得分:1)
显然,正如已经说明的那样,由于依赖性冲突,您会遇到类加载器问题。
要解决此问题,您应将 wildfly-connector 依赖关系标记为提供。
<dependency>
<groupId>org.wildfly</groupId>
<artifactId>wildfly-connector</artifactId>
<version>10.0.0.Final</version>
<scope>provided</scope>
</dependency>
WildFly已经包含JAR。如果您转到以下文件夹,您可以找到它:
<wildfly-10.0.0.Final-dir>\modules\system\layers\base\org\jboss\as\connector\main
您无需随身携带应用程序。
然而,如WildFly 10's Implicit module dependencies for deployments所述,需要明确触发JCA子系统。为此,可以使用 jboss-deployment-structure.xml 以及以下内容:
<?xml version="1.0" encoding="UTF-8"?>
<jboss-deployment-structure>
<deployment>
<dependencies>
<module name="org.jboss.ironjacamar.jdbcadapters" slot="main"/>
</dependencies>
</deployment>
</jboss-deployment-structure>
然后,将 jboss-deployment-structure.xml 添加到WAR的 WEB-INF 文件夹中。
答案 1 :(得分:1)
aribeiro的回答是正确答案:由构建工具(Maven)打包的jar位于战争的lib目录中,并与wildfly-Classloader冲突。
此外,以下是针对以下问题的通用解决方案:
当你离开Java EE-Spec并使用JBoss / Wildfly特定模块,ironjacamar,jsf-impl等时,大多数情况都会发生。 Maven将所需的jar放在lib目录中。但是Jars已经在AS的module-directory中了。根据我的经验,ClassCastException
就是出于这个原因。
然后必须通过声明所提供的依赖关系,从maven中的lib目录中删除jar。
告诉JBoss / Wildfly-Classloader,在哪里找到这个类。这可以通过以下方式完成:
将依赖项添加到项目的MANIFEST.MF
。 Eclipse-JBoss-Tools从Server-Enviroment加载类,因此您可以从pom中删除依赖项。在你的情况下:
Dependencies: org.jboss.ironjacamar.jdbcadapters
或者您使用jboss-deployment-structure.xml
,然后您可以使用Maven加载该类,但是按照提供的方式声明它
<dependencies>
<module name="org.jboss.ironjacamar.jdbcadapters" />
</dependencies>
另见https://docs.jboss.org/author/display/WFLY8/Class+Loading+in+WildFly