JBoss EAP 7, разрешено только исключение сварки @Dependent

При попытке перенести приложение с JBoss EAP 5 на JBoss EAP, а также добавить некоторые дополнительные функции, такие как JAX-RS, я получаю следующую ошибку:

WELD-000082: Интерфейс области javax.enterprise.context.RequestScoped не разрешен для сеансовых компонентов без сохранения состояния для класса net.MyCompany.My.service.MyIPAuthJaxRsService. Допускается только @Dependent.

Полная трассировка стека:

    1:02:29,721 ERROR [org.jboss.msc.service.fail] (MSC service thread 1-3) MSC000001: Failed to start service jboss.deployment.unit."C1Authentication.ear".WeldStartService: org.jboss.msc.service.StartException in service jboss.deployment.unit."C1Authentication.ear".WeldStartService: Failed to start service
        at org.jboss.msc.service.ServiceControllerImpl$StartTask.run(ServiceControllerImpl.java:1904)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
        at java.lang.Thread.run(Thread.java:745)
    Caused by: org.jboss.weld.exceptions.DefinitionException: WELD-000082: Scope interface javax.enterprise.context.RequestScoped is not allowed on stateless session beans for class net.MyCompany.My.service.MyIPAuthJaxRsService. Only @Dependent is allowed.
        at org.jboss.weld.bean.SessionBean.checkScopeAllowed(SessionBean.java:122)
        at org.jboss.weld.bean.SessionBean.internalInitialize(SessionBean.java:101)
        at org.jboss.weld.bean.RIBean.initialize(RIBean.java:69)
        at org.jboss.weld.bootstrap.ConcurrentBeanDeployer$5.doWork(ConcurrentBeanDeployer.java:121)
        at org.jboss.weld.bootstrap.ConcurrentBeanDeployer$5.doWork(ConcurrentBeanDeployer.java:118)
        at org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:63)
        at org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:56)
        at java.util.concurrent.FutureTask.run(FutureTask.java:266)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
        at java.lang.Thread.run(Thread.java:745)
        at org.jboss.threads.JBossThread.run(JBossThread.java:320)

В Eclipse аспекты проектов относятся к EJB 3.2 и Java 1.7.

Мой файл EJB-Jar.xml содержит:

    <?xml version="1.0" encoding="UTF-8"?>
    <ejb-jar xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/ejb-jar
    package net.mycompany.my.service;

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

    @ApplicationPath(value="/C1AuthService")
    public class MyIPAuthJaxRsServiceApplication extends Application {

        private Set singletons = new HashSet();

        public MyIPAuthJaxRsServiceApplication() {
            singletons.add(new MyIPAuthJaxRsService());
        }

        @Override
        public Set getSingletons() {
            return singletons;
        }

        @Override
        public Set> getClasses() {
            // TODO Auto-generated method stub
            return null;
        }
    }
2.xsd" version="3.2"> <display-name>C1AuthService</display-name> <enterprise-beans> <session> <ejb-name>MyWSService</ejb-name> <ejb-class>net.MyCompany.My.service.MyWSService</ejb-class> <session-type>Stateless</session-type> <transaction-type>Container</transaction-type> </session> <session> <ejb-name>MyIPAuthJaxRsService</ejb-name> <ejb-class>net.MyCompany.My.service.MyIPAuthJaxRsService</ejb-class> <session-type>Stateless</session-type> <transaction-type>Container</transaction-type> </session> <session> <ejb-name>MyIPAuthJaxRsServiceApplication</ejb-name> <ejb-class>net.MyCompany.My.service.MyIPAuthJaxRsServiceApplication</ejb-class> <session-type>Stateless</session-type> <transaction-type>Container</transaction-type> </session> </enterprise-beans> </ejb-jar>

Два класса JAX-RS:

    package net.mycompany.my.service;

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

    @ApplicationPath(value="/C1AuthService")
    public class MyIPAuthJaxRsServiceApplication extends Application {

        private Set singletons = new HashSet();

        public MyIPAuthJaxRsServiceApplication() {
            singletons.add(new MyIPAuthJaxRsService());
        }

        @Override
        public Set getSingletons() {
            return singletons;
        }

        @Override
        public Set> getClasses() {
            // TODO Auto-generated method stub
            return null;
        }
    }
    package net.mycompany.my.service;

    import javax.ws.rs.GET;
    import javax.ws.rs.Path;

    @Path("/C1AuthService")
    public class MyIPAuthJaxRsService {
        public MyIPAuthJaxRsService() {
        }

        @GET
        @Path("/test")
        public String test() {
            return "Hello RESTFul 2";
        }

    }

person JGlass    schedule 24.05.2017    source источник


Ответы (1)


Оказывается, после небольшого поиска в Интернете я нашел следующую статью, которая дала ключ к разгадке: https://dzone.com/articles/valid-cdi-scopes-session-ejb

Я также наткнулся на это: http://docs.jboss.org/resteasy/docs/2.0.0.GA/userguide/html/CDI.html

Что, по-видимому, происходит, так это то, что в EJB-Jar.xml я объявлял EJB как сеансовые компоненты без сохранения состояния, и, не аннотируя их в самих классах java, CDI/Weld по умолчанию устанавливал их как @Dependent, например из статьи JBoss A CDI bean that does not explicitly define a scope is @Dependent scoped by default.

Просто добавьте следующие импорты и аннотации к обоим классам:

    package net.mycompany.my.service;

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

    @Stateless
    @ApplicationPath(value="/C1AuthService")
    public class MyIPAuthJaxRsServiceApplication extends Application {

        private Set singletons = new HashSet();

        public MyIPAuthJaxRsServiceApplication() {
            singletons.add(new MyIPAuthJaxRsService());
        }

    }
    package net.mycompany.my.service;

    import javax.ejb.Stateless;
    import javax.ws.rs.GET;
    import javax.ws.rs.Path;

    @Stateless
    @Path("/C1AuthService")
    public class MyIPAuthJaxRsService {
        public MyIPAuthJaxRsService() {
        }

        @GET
        @Path("/test")
        public String test() {
            return "Hello RESTFul 2";
        }

    }

В основном проверьте, что вы аннотировали свои EJB с помощью @Stateless, а также добавили правильный импорт import javax.ejb.Stateless;

Редактировать - как указал @SteveC, я удалил переопределения, но когда я попытался удалить @Stateless из MyIPAuthJaxRsServiceApplication, как он предложил, я снова получил исключение для MyIPAuthJaxRsServiceApplication. Также следует отметить, что этот пример даже не работает, и поэтому иметь EJB в EJB-Jar.xml и аннотировать, возможно, даже не нужно, я пытался использовать проект EJB и jar в EAR, аннотируя EJB с помощью JAX-RS, но, по-видимому, он не поддерживается, так как я работаю над этим с ребятами из JBoss здесь https://developer.jboss.org/message/972433#972433

Похоже, у вас должен быть контейнер сервлетов для JAX-RS, и тот факт, что EJB могут иметь аннотации веб-сервисов, не означает, что они используют контейнер сервлетов - о, хорошо, я пытался!. Кроме того, эти вопросы и ответы были больше для исправления A CDI bean that does not explicitly define a scope is @Dependent scoped by default., с которым я немного боролся, и подумал, что помогу другим, если они столкнутся с тем же.

person JGlass    schedule 24.05.2017
comment
Вашему классу MyIPAuthJaxRsServiceApplication не нужен @Stateless и, скорее всего, не нужно переопределять какие-либо методы. - person Steve C; 25.05.2017
comment
Спасибо @SteveC за вклад! У меня будет еще одна попытка без @Stateless. Я определенно получал ошибку @Dependent is allowed для одного класса, но просто предположил, что мне это нужно для обоих, как только я подумал добавить ее к одному! обновление, теперь я получаю исключение и для этого класса, поэтому кажется, что оно требуется И спасибо, что указали на это в переопределениях - удалено. Редактируя пост, не стесняйтесь проверить редактирование, так как есть примечание! - person JGlass; 25.05.2017