Сведения о вопросе

GANGST1ER

06:22, 17th August, 2020

Теги

Как я могу переопределить метод EJB 3 session bean с общим аргументом - если это вообще возможно?

Просмотров: 448   Ответов: 2

Предположим, у вас есть следующие EJB 3 interfaces/classes:

public interface Repository<E>
{
   public void delete(E entity);
}

public abstract class AbstractRepository<E>  implements Repository<E>
{
   public void delete(E entity){
      //...
   }
}

public interface FooRepository<Foo>
{
   //other methods
}

@Local(FooRepository.class)
@Stateless
public class FooRepositoryImpl extends
    AbstractRepository<Foo> implements FooRepository
{
   @Override
   public void delete(Foo entity){
      //do something before deleting the entity
      super.delete(entity);
   }
   //other methods
}

А затем еще один боб, который обращается к Бобу FooRepository :

//...
@EJB
private FooRepository fooRepository;

public void someMethod(Foo foo)
{
    fooRepository.delete(foo);
}
//...

Однако метод переопределения никогда не выполняется при вызове метода delete компонента FooRepository . Вместо этого выполняется только реализация метода delete, определенного в AbstractRepository .

Что я делаю неправильно или это просто ограничение Java/EJB 3, что дженерики и наследование еще не играют хорошо вместе ?



  Сведения об ответе

SEEYOU

10:02, 15th August, 2020

Я попробовал его с помощью pojo, и он, кажется, работает. Мне пришлось немного изменить ваш код. Я думаю, что ваши интерфейсы были немного не в порядке, но я не уверен.

Я предположил, что "Foo"-это конкретный тип, но если нет, я могу сделать еще несколько тестов для вас.

Я только что написал основной метод, чтобы проверить это. Надеюсь, это поможет!

public static void main(String[] args){
        FooRepository fooRepository = new FooRepositoryImpl();
        fooRepository.delete(new Foo("Bar"));
}

public class Foo
{
    private String value;

    public Foo(String inValue){
        super();
        value = inValue;
    }
    public String toString(){
        return value;
    }
}

public interface Repository<E>
{
    public void delete(E entity);
}

public interface FooRepository extends Repository<Foo>
{
    //other methods
}

public class AbstractRespository<E> implements Repository<E>
{
    public void delete(E entity){
        System.out.println("Delete-" + entity.toString());
    }
}

public class FooRepositoryImpl extends AbstractRespository<Foo> implements FooRepository
{
     @Override
       public void delete(Foo entity){
          //do something before deleting the entity
            System.out.println("something before");
          super.delete(entity);
       }
}


  Сведения об ответе

lesha

20:42, 17th August, 2020

Вы можете написать модульный тест против вашего класса FooRepository, просто используя его как POJO. Если это работает так, как ожидалось, то я не знаю ни одной причины, по которой он будет функционировать по-другому внутри контейнера.

Я подозреваю, что есть что-то еще, и это, вероятно, будет легче отладить, если вы протестируете его как POJO.


Ответить на вопрос

Чтобы ответить на вопрос вам нужно войти в систему или зарегистрироваться