java 什么容器提供者支持org.apache.cxf.jaxrs.JAXRSServerFactoryBean?

pdkcd3nj  于 2023-02-18  发布在  Java
关注(0)|答案(2)|浏览(144)

使用下面提供的信息,您可以回答以下问题:
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>

再次感谢您的帮助!

91zkwejq

91zkwejq1#

我想出了问题的答案。
我试图将应用程序部署到的系统已经在系统的各个目录中安装了jar文件。
我更新了我的应用程序以包含那些jar文件,这是通过更新用于将应用程序部署到系统的描述符来完成的。
然后,我将pom.xml中某些依赖项的scope设置为<scope>provided</scope>,这样当应用程序被maven打包时,这些依赖项就不会包含在最终的jar中。
下面是一个例子:

<dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>javax.ws.rs</groupId>
            <artifactId>javax.ws.rs-api</artifactId>
            <version>2.0.1</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-annotations</artifactId>
            <version>2.9.8</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>org.glassfish.jersey.test-framework.providers</groupId>
            <artifactId>jersey-test-framework-provider-jdk-http</artifactId>
            <version>2.28-RC4</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>org.glassfish.jersey.containers</groupId>
            <artifactId>jersey-container-servlet-core</artifactId>
            <version>2.28-RC4</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>org.glassfish.jersey.inject</groupId>
            <artifactId>jersey-hk2</artifactId>
            <version>2.28-RC4</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>org.glassfish.jersey.media</groupId>
            <artifactId>jersey-media-json-jackson</artifactId>
            <version>2.28-RC4</version>
            <scope>provided</scope>
        </dependency>
    </dependencies>
tjvv9vkg

tjvv9vkg2#

在我这边,通过排除拥有自己的META-INF/services/javax.ws.rs.ext.RuntimeDelegatejersey-server(请参见RuntimeDelegate.JAXRS_RUNTIME_DELEGATE_PROPERTY),从而防止正确加载org.apache.cxf.jaxrs.impl.RuntimeDelegateImpl,修复了这个问题。在我的例子中,jersey-server是由hadoop-mapreduce-client-core传递的:

<dependency>
        <groupId>XXX</groupId>
        <artifactId>YYY</artifactId>
        <exclusions>
            <exclusion>
                <groupId>org.apache.hadoop</groupId>
                <artifactId>hadoop-mapreduce-client-core</artifactId>
            </exclusion>
        </exclusions>
    </dependency>

相关问题