从JBoss AS 7降级到JBoss AS 5时,Weld Servlet无法正常工作

时间:2013-06-04 19:47:15

标签: jboss jax-rs cdi weld

我有一个在jboss7上运行良好的应用程序,它使用jee6 apis:jax-rs和CDI。由于生产限制,我被要求调整它以在Jboss 5.1.0上运行。为了方便起见,我创建了一个最小的应用程序,只有一个服务和一个注入。它在jb7上工作正常,我不得不添加没有为jboss5版本提供的库。

jax-rs运行正常,我添加了RestEasy并在web.xml上声明了RestEasy servlet。

对于CDI,我包括Weld,用于处理servlet模式,因为应用程序没有servlet。在文档之后,我将监听器包含在web.xml中,然后在jboss论坛上发现需要另一个监听器来将BeanContext注册到jboss jndi。

所以我拥有的是:

<?xml version="1.0" encoding="UTF-8"?>

<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
 http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">


    <listener>
        <listener-class>org.jboss.weld.environment.servlet.Listener</listener-class>
    </listener> 

    <listener>
        <listener-class>org.jboss.weld.environment.servlet.BeanManagerResourceBindingListener</listener-class>
    </listener> 

    <servlet>
        <servlet-name>resteasy-servlet</servlet-name>
        <servlet-class>org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher</servlet-class>
        <init-param>
            <param-name>javax.ws.rs.Application</param-name>
            <param-value>br.com.bvmf.services.ApplicationConfig</param-value>
        </init-param>
    </servlet>

    <servlet-mapping>
        <servlet-name>resteasy-servlet</servlet-name>
        <url-pattern>/*</url-pattern>
    </servlet-mapping>    

    <session-config>
        <session-timeout>
            30
        </session-timeout>
    </session-config>  
</web-app>

对于构建我使用Gadle,但只是为了更好地理解而不是我现在手动插入大多数jar:

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'war'

webAppDirName = 'WebContent'

repositories {
    mavenCentral()
    flatDir name:'EasyRestJars',dirs:'libs'
}


dependencies {
    compile(

        [name : 'weld-servlet', version : '2.0.0.SP1-jboss5'],

        [name : 'jaxrs-api', version : '2.3.6.Final'],
        [name : 'jackson-core-asl', version : '1.9.9'],
        [name : 'jackson-jaxrs', version : '1.9.9'],
        [name : 'jackson-mapper-asl', version : '1.9.9'],
        [name : 'resteasy-jackson-provider', version : '2.3.6.Final'],
        [name : 'resteasy-jaxb-provider', version : '2.3.6.Final'],
        [name : 'resteasy-jaxrs', version : '2.3.6.Final'],
        [name : 'scannotation', version : '1.0.3']
    )

    providedCompile(
        [group: 'org.slf4j', name: 'slf4j-api', version: '1.5.6'],
        [group: 'javaee',    name: 'javaee-api', version: '5' ]
    )

    testCompile group: 'junit', name: 'junit', version: '4.+'

}


test {
    systemProperties 'property': 'value'
}

war{
    exclude 'WEB-INF/lib/*'
}

现在有三个班级:

Tha application config只返回服务:

@ApplicationPath("min")
public class ApplicationConfig extends Application {

     @Override
        public Set<Class<?>> getClasses() {
         Set<Class<?>> resources = new java.util.HashSet<Class<?>>();
            resources.add(br.com.bvmf.services.HelloWorldResource.class);
            return resources;
        }

}

应该注入的bean:

public class HelloProvider {    
    public String getString() {     
        return "Injected Hello";
    }
}

服务本身:

@Path("/helloworld")
public class HelloWorldResource {

    @Inject
    private HelloProvider provider;

    @GET
    public String getMessage() {
        //This is where I get a null pointer
        return provider.getString();

    }
}

所以没有注入bean,就是这样。在部署期间,日志显示为:

2013-06-04 15:24:31,371 INFO  [org.jboss.webbeans.bootstrap.WebBeansBootstrap] (HDScanner) Web Beans 1.0.0.PREVIEW1
2013-06-04 15:24:32,898 INFO  [org.jboss.web.tomcat.service.deployers.TomcatDeployment] (HDScanner) deploy, ctxPath=/min-cil-1.0-SNAPSHOT
2013-06-04 15:24:33,417 INFO  [org.jboss.weld.Version] (HDScanner) WELD-000900 2.0.0 (SP1)
2013-06-04 15:24:33,774 INFO  [org.jboss.weld.Bootstrap] (HDScanner) WELD-000101 Transactional services not available. Injection of @Inject UserTransaction not available. Transactional observers will be invoked synchronously.
2013-06-04 15:24:34,485 WARN  [org.jboss.weld.Bootstrap] (HDScanner) Legacy deployment metadata provided by the integrator. Certain functionality will not be available.
2013-06-04 15:24:34,809 INFO  [org.jboss.weld.environment.tomcat.Tomcat6Container] (HDScanner) Tomcat 6 detected, CDI injection will be available in Servlets and Filters. Injection into Listeners is not supported
2013-06-04 15:24:35,750 INFO  [org.jboss.weld.environment.servlet.BeanManagerResourceBindingListener] (HDScanner) BeanManager reference bound to java:comp/env/BeanManager
2013-06-04 15:26:13,648 INFO  [org.jboss.resteasy.spi.ResteasyDeployment] (http-127.0.0.1-8080-2) Deploying javax.ws.rs.core.Application: class br.com.bvmf.services.ApplicationConfig

weld docs中有一条说法:“另外,Weld Servlet支持JBoss EAP 5.1,使用Weld Servlet的jboss5变种。”所以我找到了这个版本,但没有区别(除了slf4j的更多问题)。

2 个答案:

答案 0 :(得分:0)

我认为Weld Servlet中没有与JAX-RS集成 - 这只在Java EE 6中可用。你可以看看它在JBoss AS 6中的运行方式并尝试向后移植它吗?或者查看CDI和RESTEasy文档以了解如何添加它(基本上,您需要使用RESTEasy注册某种后构造侦听器,然后使用CDI API注入实例)。

答案 1 :(得分:0)

似乎在JBoss 5.1上不支持Weld。最后,我通过注释和autowire将依赖注入更改为Spring。 Spring在RESTEasy上发挥得很好,所以现在一切都很好。