Сохранение имени пользователя, который последний раз изменял строку базы данных через EJB3.0 и JPA - PullRequest
0 голосов
/ 25 февраля 2009

Я хотел бы сохранить имя пользователя с последней измененной строкой таблицы в качестве поля в каждой таблице.

У меня есть следующие настройки: пользователь входит в систему, веб-слой вызывает некоторые компоненты EJB 3.0. Эти EJB-бины создают и модифицируют некоторые сущности JPA. Теперь я хотел бы, чтобы это имя пользователя (из веб-слоя) автоматически сохранялось для каждой сущности JPA (и строки базы данных), которая создается или изменяется во время вызова метода EJB.

У меня есть такая таблица (то есть: каждая таблица имеет модификатор поля):

CREATE TABLE my_table (
  some_data INTEGER,
  modifier VARCHAR(20)
);

Под автоматически я имею в виду, что мне не нужно было бы вручную устанавливать имя пользователя для каждой сущности в методах EJB.

Этого можно достичь, сохранив имя пользователя в переменной ThreadLocal и выбрав имя пользователя из ThreadLocal в EntityListener сущности JPA. Однако это работает только при использовании локального вызова EJB, оно не будет работать с вызовами EJB, которые пересекают границы JVM. Я хотел бы сделать это через удаленные вызовы EJB-методов.

Это вообще возможно?

Я использую Weblogic Server 10.3, EJB3.0 и EclipseLink JPA. Мне также интересно услышать, работает ли это с другими реализациями JPA.

1 Ответ

3 голосов
/ 11 марта 2009

Вы можете использовать перехватчик EJB (@Around) в классе EJB, чтобы получить текущего пользователя (используя стандартные API EJB) и сохранить имя в переменной threadlocal. Это будет работать прозрачно для удаленных и локальных вызовов.

...