使用下面提供的信息,您可以回答以下问题:
1.哪个容器提供程序支持org.apache.cxf.jaxrs.JAXRSServerFactoryBean,以便在创建端点时可以使用org.glassfish.jersey.server.ContainerFactory添加应用程序?
1.下面的应用程序有什么问题导致(JAXRSServerFactoryBean)RuntimeDelegate.getInstance().createEndpoint(app, JAXRSServerFactoryBean.class);
抛出非法参数异常?
我正在尝试将使用注解(no web.xml)的JAX-RS应用程序部署到使用 Java Application Manager(这是一个专有系统,已经移植了一些应用程序管理器库,但由于支持文档很少,我不确定这些库是什么)的系统。
在较高的层次上,我有一个Java应用程序,它使用JAX-RS注解(如ApplicationPath、Path、Produces/Consumes和JsonProperty)尝试在“应用程序服务器”上创建端点。我之所以说“应用程序服务器”,是因为我没有关于此系统的文档,所以我就这样称呼它。当尝试启动应用程序时,我遇到以下异常:
java.lang.IllegalArgumentException: No container provider supports the type class org.apache.cxf.jaxrs.JAXRSServerFactoryBean
at org.glassfish.jersey.server.ContainerFactory.createContainer(ContainerFactory.java:64)
at org.glassfish.jersey.server.internal.RuntimeDelegateImpl.createEndpoint(RuntimeDelegateImpl.java:47)
at com.app.Server.startServer(Server.java:182)
我研究过org.glassfish.jersey.server.internal.RuntimeDelegateImpl.createEndpoint
函数抛出的java.lang.IllegalArgumentException
。我不确定它为什么会这样做,因为在封面上看起来应用程序类注解正确,extends Application
。
我能够查看服务器的类代码,下面是正在执行的操作:
服务器代码
这里是com.app.Server.startServer(Server.java:182)
代码的一个片段部分,我不能改变这个代码:
inside of startServer...
Application app = (Application) Class.forName("com.app.MyApplication").newInstance();
JAXRSServerFactoryBean jaxrsServerFactory = (JAXRSServerFactoryBean)RuntimeDelegate.getInstance().createEndpoint(app, JAXRSServerFactoryBean.class);
现在我的代码:
应用程序代码
我的应用程序
package com.app;
import java.util.HashSet;
import java.util.Set;
import javax.ws.rs.ApplicationPath;
import javax.ws.rs.core.Application;
import com.app.services.ServiceOne;
@ApplicationPath("base/path")
public class MyApplication extends Application {
public MyApplication() {
System.out.println(Long.toString(System.nanoTime()) + " " + this.getClass().getName() + " constructor called...");
}
/* (non-Javadoc)
* @see javax.ws.rs.core.Application#getClasses()
*/
@Override
public Set<Class<?>> getClasses() {
System.out.println(Long.toString(System.nanoTime()) + " " + this.getClass().getName() + " getClasses() method called...");
Set<Class<?>> classes = new HashSet<>();
classes.add(ServiceOne.class);
return classes;
}
}
我的应用程序的服务
package com.app.services.ServiceOne;
import java.util.ArrayList;
import javax.ws.rs.Consumes;
import javax.ws.rs.NotFoundException;
import javax.ws.rs.PUT;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
// pretend the model imports are here...
@Path("serviceOne")
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
public class ServiceOne {
@PUT
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
public ResponseObject performService(InputObject body) throws NotFoundException {
// do whatever to get result and send...
}
}
Pom.xml插件和依赖项
<build>
<plugins>
<plugin>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.5.1</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
<plugin>
<artifactId>maven-assembly-plugin</artifactId>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>single</goal>
</goals>
</execution>
</executions>
<configuration>
<descriptorRefs>
<descriptorRef>jar-with-dependencies</descriptorRef>
</descriptorRefs>
</configuration>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
<dependency>
<groupId>javax.ws.rs</groupId>
<artifactId>javax.ws.rs-api</artifactId>
<version>2.0.1</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-annotations</artifactId>
<version>2.9.8</version>
</dependency>
<dependency>
<groupId>org.glassfish.jersey.test-framework.providers</groupId>
<artifactId>jersey-test-framework-provider-jdk-http</artifactId>
<version>2.28-RC4</version>
</dependency>
<dependency>
<groupId>org.glassfish.jersey.containers</groupId>
<artifactId>jersey-container-servlet-core</artifactId>
<version>2.28-RC4</version>
</dependency>
<dependency>
<groupId>org.glassfish.jersey.inject</groupId>
<artifactId>jersey-hk2</artifactId>
<version>2.28-RC4</version>
</dependency>
<dependency>
<groupId>org.glassfish.jersey.media</groupId>
<artifactId>jersey-media-json-jackson</artifactId>
<version>2.28-RC4</version>
</dependency>
</dependencies>
再次感谢您的帮助!
2条答案
按热度按时间91zkwejq1#
我想出了问题的答案。
我试图将应用程序部署到的系统已经在系统的各个目录中安装了
jar
文件。我更新了我的应用程序以包含那些
jar
文件,这是通过更新用于将应用程序部署到系统的描述符来完成的。然后,我将
pom.xml
中某些依赖项的scope
设置为<scope>provided</scope>
,这样当应用程序被maven打包时,这些依赖项就不会包含在最终的jar中。下面是一个例子:
tjvv9vkg2#
在我这边,通过排除拥有自己的
META-INF/services/javax.ws.rs.ext.RuntimeDelegate
的jersey-server
(请参见RuntimeDelegate.JAXRS_RUNTIME_DELEGATE_PROPERTY),从而防止正确加载org.apache.cxf.jaxrs.impl.RuntimeDelegateImpl
,修复了这个问题。在我的例子中,jersey-server是由hadoop-mapreduce-client-core
传递的: