Почему мы получаем java.lang.ClassCastException: $ Proxy, в jndi-поиске бина сеанса без состояния в Glassfish 3.1.1 - PullRequest
0 голосов
/ 28 октября 2011

У нас возникают проблемы при поиске экземпляра сессионного компонента Local Stateles в служебном классе. Мы всегда получаем ClassCastException: $ ProxyXYZ (XYZ - любое число)

Мы используем Glassfish 3.1.1, JPA 2, EJB 3, JSF2

Все упаковано в ушной архив.

Мы также используем Валидацию Бина в нашем проекте, поэтому в одном из нашего класса валидатора мы пытаемся получить экземпляр сеансового бина без статов. Валидатор определяется следующим образом:

public class ValidadorParametroGlobal implements ConstraintValidator<ValidacionParametroGlobal, ParametroGlobal> {

    @Override
    public void initialize(final ValidacionParametroGlobal constraintAnnotation) {
        try {

            //Lookup works, jndi name is correct, but cast fails
            ParametroGlobalBOImpl pgbo =
                    (ParametroGlobalBOImpl) new InitialContext().lookup(
                    "java:global/esipren-ear/esipren-ejb/ParametroGlobalBOImpl!" +
                    "ec.gob.mf.esipren2.bo.entidad.ParametroGlobalBOLocal");
            LOG.info(pgbo);
        } catch (NamingException ex) {
            LOG.error("No se pudo recuperar el bo de parametro global en el validador");
            throw new IllegalStateException("No se puede ejecutar la validación", ex);
        }
        LOG.debug("Inicializando validador");
    }
    ... MORE CODE
}

Боб сеанса:

@Stateless
@Local(ParametroGlobalBOLocal.class)
@Remote(ParametroGlobalBORemote.class)
public class ParametroGlobalBOImpl extends ParametroGlobalGenericBridgeImpl implements     ParametroGlobalBOLocal,
        ParametroGlobalBORemote {
    MORE code...
}

Процесс поиска работает хорошо, потому что мы получаем Instancce класса Proxy, но невозможно привести его к Session Bean, и когда этот валидатор выполняется, мы получаем это исключение:

java.lang.ClassCastException: $Proxy1519
    at     ec.gob.mf.esipren2.validacion.ValidadorParametroGlobal.initialize(ValidadorParametroGlobal.java:64)
    at ec.gob.mf.esipren2.validacion.ValidadorParametroGlobal.initialize(ValidadorParametroGlobal.java:41)
    at org.hibernate.validator.engine.ConstraintTree.initializeConstraint(ConstraintTree.java:302)
    at org.hibernate.validator.engine.ConstraintTree.createAndInitializeValidator(ConstraintTree.java:212)
at org.hibernate.validator.engine.ConstraintTree.getInitializedValidator(ConstraintTree.java:189)
    at org.hibernate.validator.engine.ConstraintTree.validateConstraints(ConstraintTree|#]

            [#|2011-10-28T11:46:10.814-0500|INFO|glassfish3.1.1|javax.enterprise.system.std.com.sun.enterprise.server.logging|_ThreadID=19;_ThreadName=Thread-4;|.java:135)
    at org.hibernate.validator.metadata.MetaConstraint.validateConstraint(MetaConstraint.java:121)
    at org.hibernate.validator.engine.ValidatorImpl.validateConstraint(ValidatorImpl.java:327)
    at org.hibernate.validator.engine.ValidatorImpl.validateConstraintsForRedefinedDefaultGroup(ValidatorImpl.java:273)
    at org.hibernate.validator.engine.ValidatorImpl.validateConstraintsForCurrentGroup(ValidatorImpl.java:256)
    at org.hibernate.validator.engine.ValidatorImpl.validateInContext(ValidatorImpl.java:210)
    at org.hibernate.validator.engine.ValidatorImpl.validate(ValidatorImpl.java:119)
    at ec.gob.mf.esipren2.validacion.BeanValidationEventListener.validate(BeanValidationEventListener.java:56)
at ec.gob.mf.esipren2.persistencia.dao.jpa.JpaGenericDAOImpl.crear(JpaGenericDAOImpl.java:113)
    ... 95 more
    |#]

Мы также определили класс валидатора следующим образом:

public class ValidadorParametroGlobal implements ConstraintValidator<ValidacionParametroGlobal, ParametroGlobal> {

    @Override
    public void initialize(final ValidacionParametroGlobal constraintAnnotation) {
        try {
            ParametroGlobalBOLocal pgbo =
                    (ParametroGlobalBOLocal) new InitialContext().lookup(
                    "java:global/esipren-ear/esipren-ejb/ParametroGlobalBOImpl!" +
                    "ec.gob.mf.esipren2.bo.entidad.ParametroGlobalBOLocal");
            LOG.info(pgbo);
        } catch (NamingException ex) {
            LOG.error("No se pudo recuperar el bo de parametro global en el validador");
            throw new IllegalStateException("No se puede ejecutar la validación", ex);
        }
        LOG.debug("Inicializando validador");
    }
    ... MORE CODE
}

Но мы получаем ту же ошибку.

Есть идеи?

Ответы [ 2 ]

0 голосов
/ 22 декабря 2011

В качестве резюме для первого ответа. Проблема возникает из-за того, что вы преобразуетесь в сам EJB, и вам необходимо привести в бизнес-интерфейс EJB. Я столкнулся с той же проблемой после изучения FAQ здесь http://glassfish.java.net/javaee5/ejb/EJB_FAQ.html#POJOLocalEJB. К счастью, коллеги на java.net помогли мне. Спасибо им большое.

0 голосов
/ 21 декабря 2011

Один из способов получить локальную или удаленную ссылку на ejb в glassfish 3.1.1 - через локатор (см. http://www.adam -bien.com / roller / abien / entry / ejb_3_1_beanlocator_when )

Мой Beanlocator (см. Метод getBean, он ожидает два аргумента: локальный или удаленный класс Ejb и имя переносимого ejb):

package ec.gob.mf.esipren2.util;

import java.io.Serializable;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.rmi.PortableRemoteObject;
import org.apache.log4j.Logger;

/**
 *  Utilitario para recuperacion de instancias de Session Beans.
 * @author juan
 */
public final class BeanLocator implements Serializable {

    /**
     * Version de la clase.
     */
    private static final long serialVersionUID = 1L;

    /**
     * Logger de la clase.
     */
    private static final Logger LOG = Logger.getLogger(BeanLocator.class);

    /**
     * Constructor por defecto.
     */
    private BeanLocator() {
    }

    /**
     * Metodo para recuperacion de Session Beans Locales usando un archivo de
     * propiedades.
     * @param <T> Interfaz del Tipo de Session Bean que se quiere recuperar
     * @param clazz La clase que representa la interfaz del Session Bean
     * @param nombreServicio
     *      Nombre del servicio que se desea recuperar
         * @return Una Instancia del Session Bean cuya interfaz es igual a la
     * interfaz pasada como parametro
     * @throws NamingException En caso de encontrarse un error al intentar
     * recuperar la instancia del Session Bean
     */
    public static <T> T getBean(final Class<T> clazz, final String nombreServicio)
            throws NamingException {
        LOG.trace("Recuperando servicio Local" + nombreServicio);
        Context c = new InitialContext();
        Object o = c.lookup(nombreServicio);
        LOG.trace("Se recuperó un proxy: " + o.getClass().getName());
        return clazz.cast(PortableRemoteObject.narrow(o, clazz));
    }
}

Итак, чтобы получить локальную ссылку на ejb:

    public String despachar() {
    String result;
    try {

        ParametroGlobalBOLocal prboLocal = BeanLocator.getBean(ParametroGlobalBOLocal.class,
                "java:global/esipren-ear/esipren-ejb/ParametroGlobalBOImpl!" +
                "ec.gob.mf.esipren2.bo.entidad.ParametroGlobalBOLocal");
        prboLocal.buscarTodos();
        result = "Something";
    } catch (NamingException ex) {
        ex.printStackTrace();
        result = "error";
    }
    return result;
}

Тот же подход можно использовать для получения удаленной ссылки на ejb

public String despachar1() {
    String result;
    try {

        ParametroGlobalBORemote prboRemote = BeanLocator.getBean(ParametroGlobalBORemote.class,
                "java:global/esipren-ear/esipren-ejb/ParametroGlobalBOImpl!" +
                "ec.gob.mf.esipren2.bo.entidad.ParametroGlobalBORemote");
        prboRemote.buscarTodos();
        result = "Something";
    } catch (NamingException ex) {
        ex.printStackTrace();
        result = "error";
    }
    return result;    }

Наконец, это может вас заинтересовать

http://glassfish.java.net/javaee5/ejb/EJB_FAQ.html#StandaloneRemoteEJB
http://www.java.net/node/703676#comment-797861
http://www.jguru.com/faq/view.jsp?EID=734137

С уважением, Хуан

...