【问题标题】:Jersey application not working on WebLogicJersey 应用程序无法在 WebLogic 上运行
【发布时间】:2018-05-02 06:14:12
【问题描述】:

我有一个应用程序,当我将它部署在 tomcat 服务器上时运行良好,但如果部署在 weblogic 上则无法运行。
Tomcat 版本为:7.0.47
Weblogic版本为:12.2.1.2.0

有一个返回 JSON 的简单休息端点:
http://localhost:8080/MyApplication/rest/configuration/test
在tomcat上工作正常,在weblogic上我只得到字符串“未找到”。

在日志文件中,我发现的唯一警告如下:

<Warning> <JAXRSIntegration> <MyApplication> <[ACTIVE] ExecuteThread: '12' for queue: 'weblogic.kernel.Default (self-tuning)'> <<WLS Kernel>> <> <24ad6e0e-7bbc-4781-b294-f546069677ec-00000007> <1511013418859> <[severity-value: 16] [rid: 0] [partition-id: 0] [partition-name: DOMAIN] > <BEA-2192510> <Cannot add Jersey servlet for application class org.glassfish.jersey.server.ResourceConfig because ApplicationPath annotation is not set on it.>
<Warning> <JAXRSIntegration> <MyApplication> <[ACTIVE] ExecuteThread: '12' for queue: 'weblogic.kernel.Default (self-tuning)'> <<WLS Kernel>> <> <24ad6e0e-7bbc-4781-b294-f546069677ec-00000007> <1511013418860> <[severity-value: 16] [rid: 0] [partition-id: 0] [partition-name: DOMAIN] > <BEA-2192510> <Cannot add Jersey servlet for application class org.glassfish.jersey.server.ResourceConfig$WrappingResourceConfig because ApplicationPath annotation is not set on it.>
<Warning> <JAXRSIntegration> <MyApplication> <[ACTIVE] ExecuteThread: '12' for queue: 'weblogic.kernel.Default (self-tuning)'> <<WLS Kernel>> <> <24ad6e0e-7bbc-4781-b294-f546069677ec-00000007> <1511013418861> <[severity-value: 16] [rid: 0] [partition-id: 0] [partition-name: DOMAIN] > <BEA-2192510> <Cannot add Jersey servlet for application class org.glassfish.jersey.server.ResourceConfig$RuntimeConfig because ApplicationPath annotation is not set on it.>

端点:

@Path("/configuration")
@NoCache
public class ConfigurationResource {
    @GET
    @Path("/test")
    @Produces(MediaType.APPLICATION_JSON)
    public Response getClientConfig() {
        Map<String, Object> map = new HashMap<>();
        map.put("test", "Test is running.");
        return Response.ok(map).build();
    }

    ...
}
public class MyApplication extends ResourceConfig {
    public MyApplication() {
        register(ConfigurationResource.class);
    }
}

来自 web.xml

<servlet>
    <servlet-name>jersey-servlet</servlet-name>
    <servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
    <init-param>
        <param-name>javax.ws.rs.Application</param-name>
        <param-value>com.sample.rest.MyApplication</param-value>
    </init-param>
    <init-param>
        <param-name>com.sun.jersey.api.json.POJOMappingFeature</param-name>
        <param-value>true</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
    <servlet-name>jersey-servlet</servlet-name>
    <url-pattern>/rest/*</url-pattern>
</servlet-mapping>

weblogic.xml:

<weblogic-web-app>
    <container-descriptor>
        <prefer-application-packages>
          <package-name>javax.ws.rs</package-name>
          <package-name>javax.persistence</package-name>
          <package-name>org.apache.commons</package-name>
          <package-name>org.slf4j</package-name>
          <package-name>org.apache.commons.logging</package-name>
          </prefer-application-packages>
    </container-descriptor>
</weblogic-web-app>

我已经尝试添加注释,但没有效果。
有人知道我可以做些什么来让它工作吗?

【问题讨论】:

  • 不确定您是否将@ApplicationPath("/MyApplication") 添加到MyApplication 类中
  • @Optional:是的,这就是我所尝试的(因为我认为这是 weblogic 所缺少的),但这对警告和功能没有影响。烦人的是没有其他警告/错误来了解问题所在。

标签: java jersey weblogic12c


【解决方案1】:

我找到了解决该问题的方法 从 weblogic.xml 中删除一些行后,它起作用了:

weblogic.xml:

<weblogic-web-app>enter code here
    <container-descriptor>
        <prefer-application-packages>

          <package-name>org.apache.commons</package-name>
          <package-name>org.slf4j</package-name>
          <package-name>org.apache.commons.logging</package-name>
          </prefer-application-packages>
    </container-descriptor>
</weblogic-web-app>

所以我要删除:

          <package-name>javax.ws.rs</package-name>
          <package-name>javax.persistence</package-name>

这是唯一的事情。 不幸的是,由于我在任何日志文件中都没有发现错误/警告条目,因此没有真正的提示实际问题是什么。

这些包似乎与 weblogic 提供的包不兼容。 我认为还应该检查 pom 文件中的相应依赖项是否在“提供”范围内。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-08-03
    • 2011-09-28
    • 2014-10-08
    相关资源
    最近更新 更多