Wildfly 忽略 ApplicationPath

Posted

技术标签:

【中文标题】Wildfly 忽略 ApplicationPath【英文标题】:ApplicationPath being ignored by wildfly 【发布时间】:2019-09-06 20:25:44 【问题描述】:

我目前正在尝试设置我的第一个 Java-EE (JDK8) 应用程序,但无法覆盖 Context Root 以使用 @ApplicationPath 注释。 正在使用的应用程序服务器是 Wildfly 16.0.0.Final,我正在尝试使用 Resteasy 作为 JAX-RS 实现。

由于我使用 gradle 将我的应用程序部署为战争,这是我的依赖项:(这是一团糟,我正试图弄清楚我真正需要什么,什么不是,欢迎提供建议)

    dependencies 
    compileOnly 'org.jboss.logging:jboss-logging:3.3.0.Final'
    compileOnly 'org.apache.logging.log4j:log4j-api:2.8.2'
    compileOnly 'org.eclipse.persistence:javax.persistence:2.1.0'
    compileOnly 'javax.inject:javax.inject:1'
    compileOnly 'javax.transaction:javax.transaction-api:1.2'
    compileOnly 'javax.enterprise:cdi-api:2.0'
    compileOnly 'org.hibernate:hibernate-core:5.4.2.Final'
    compileOnly 'org.hibernate:hibernate-envers:5.4.2.Final'
    compileOnly 'com.fasterxml.jackson.core:jackson-core:2.9.8'
    compileOnly 'com.fasterxml.jackson.core:jackson-annotations:2.9.8'
    compileOnly 'com.fasterxml.jackson.core:jackson-databind:2.9.8'
    compileOnly 'javax.servlet:javax.servlet-api:3.1.0'
    compile group: 'org.jboss.resteasy', name: 'resteasy-jaxrs', version: '3.6.3.Final'
    compile group: 'org.jboss.resteasy', name: 'jaxrs-api', version: '3.0.12.Final'

我确认 wildfly 使用的是适当版本的 resteasy,并且它也在使用 3.6.3。

我的应用程序配置如下所示:

import javax.ws.rs.ApplicationPath;
import javax.ws.rs.core.Application;
import java.util.HashSet;
import java.util.Set;

@ApplicationPath("rest/*")
public class ApplicationConfig extends Application 
    // Intentionally empty. Just used to configure the application path for wildfly

    @Override
    public Set<Class<?>> getClasses() 
        final Set<Class<?>> s = new HashSet<>();
        s.add(HelloWorldController.class);
        return s;
    


现在我目前能够成功部署我的应用程序,但上下文根仍被设置为我的 war 文件的名称,如下所示:

18:39:47,586 INFO  [org.wildfly.extension.undertow] (ServerService Thread Pool -- 85) WFLYUT0021: Registered web context: '/Rest-Test-1.0' for server 'default-server'

当访问带有战争名称的 URL 时,我可以看到我的 WebFilter 的日志条目,但过滤器也无法正确执行链,以使用匹配的 @Path 注释将其寻址到正确的类。(这可能也是 CDI 的问题吗?)

更新 1: 将@ApplicationPath 更改为“/rest”或“rest”也不会更改上下文根注册。它仍然将战争名称作为上下文根。

TL;DR: 为什么我的 @ApplicationPath 注释被忽略,为什么我的 webfilter 无法链接请求?

解决方案:

    将依赖关系从 resteasy 更改为 compileOnly

这删除了警告WELD-000167: Class org.jboss.resteasy.core.AsynchronousDispatcher is annotated with @RequestScoped but it does not declare an appropriate constructor therefore is not registered as a bean!

    将 ApplicationPath 更改为正确的路径 ("/rest")

这使我的 URI 正确注册为 root 并启用 WebFilter 以执行正确的链,因为它现在可以与 URI 中的每个组件不同。

    将 jboss-web.xml 添加到 WEB-INF

像这样使用 jboss-web.xml:

<?xml version="1.0" encoding="UTF-8"?>
<jboss-web version="10.0"
           xmlns="http://www.jboss.com/xml/ns/javaee"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xsi:schemaLocation="http://www.jboss.com/xml/ns/javaee http://www.jboss.org/j2ee/schema/jboss-web_10_0.xsd">

    <context-root>/api</context-root>
    <security-domain>other</security-domain> <!-- Configure to the security domain used for your deployed application -->
    <server-instance>default-server</server-instance>
    <virtual-host>default-host</virtual-host>

</jboss-web>

我能够将上下文根覆盖为一个更漂亮的根。

如果您的 IDE 声明 server-instance 元素有错误,您可以忽略它,它仍然可以正常工作。

【问题讨论】:

查看我的配置时,@ApplicationPath 总是有一个 实际 路径,而不是模式。然后用@Path 注释的不同资源可以有模式。 所以把它改成只是休息应该是诀窍吗? 不确定,但也许值得一试? 这两个答案的结合实际上是它起作用的原因。老实说,我不确定该接受什么。 【参考方案1】:

在发布我的解决方案之前,我首先要感谢 ogulcan 和 Sebastian S,因为他们的帮助让我找到了正确的解决方案。

解决方案:

    将依赖关系从 resteasy 更改为 compileOnly

这消除了警告 WELD-000167: Class org.jboss.resteasy.core.AsynchronousDispatcher is annotated with @RequestScoped 但它没有声明适当的构造函数因此没有注册为 bean!

    将 ApplicationPath 更改为正确的路径 ("/rest")

这使我的 URI 正确注册为 root 并启用 WebFilter 以执行正确的链,因为它现在可以与 URI 中的每个组件不同。

    将 jboss-web.xml 添加到 WEB-INF

像这样使用 jboss-web.xml:

http://www.jboss.org/j2ee/schema/jboss-web_10_0.xsd">

<context-root>/api</context-root>
<security-domain>other</security-domain> <!-- Configure to the security domain used for your deployed application -->
<server-instance>default-server</server-instance>
<virtual-host>default-host</virtual-host>

我能够将上下文根覆盖为更漂亮的根。

如果您的 IDE 声明 server-instance 元素有错误,您可以忽略它,它仍然可以正常工作。

【讨论】:

【参考方案2】:

您可以使用 application xml 更改上下文根

【讨论】:

但据我所知,application.xml 仅用于 EAR 部署,还是我错了?目前我只使用 WAR 部署,因为 EAR 只会在一个带有一个模块的小型应用程序中被“压倒”。 对不起,我没有注意到。只有战争方法你可以使用jboss-web.xml 这两个答案的结合实际上是它起作用的原因。老实说,我不确定该接受什么。

以上是关于Wildfly 忽略 ApplicationPath的主要内容,如果未能解决你的问题,请参考以下文章

从 Wildfly 10 中排除所有模块

保护https密钥库时,Wildfly保险库(JCEKS)有什么意义?

为啥 OpenJDK Docker 容器会忽略 Kubernetes 中的内存限制?

从 Wildfly 11 升级到 Wildfly 15 时的日期序列化问题

使用 wildfly (wildfly:deploy) 在一个简单的 Maven 项目中构建失败

Docker 容器中的 Wildfly 未启动