Хотя решение, предлагаемое Bozho, может работать, я не хочу вводить прокси-объекты в приложение, которое в настоящее время не использует их.Мое решение не идеально, но оно выполняет свою работу.
Я оставил переходное поле на месте:
transient private ApplicationData _applicationData;
Я также оставил установщик на месте, чтобы JSF мог изначально установитьссылка при первом создании объекта SessionData
:
public void setApplicationData(ApplicationData applicationData) {
_applicationData = applicationData;
}
Изменение, которое я сделал, было в методе getter.Методы в объекте SessionData
теперь должны прекратить прямой доступ к полю _applicationData
и получить ссылку через геттер.Получатель сначала проверит нулевую ссылку.Если он нулевой, то управляемый компонент получается через FacesContext
.Ограничение здесь заключается в том, что FacesContext
доступен только в течение срока действия запроса.
/**
* Get a reference to the ApplicationData object
* @return ApplicationData
* @throws IllegalStateException May be thrown if this method is called
* outside of a request and the ApplicationData object needs to be
* obtained via the FacesContext
*/
private ApplicationData getApplicationData() {
if (_applicationData == null) {
_applicationData = JSFUtilities.getManagedBean(
"applicationData", // name of managed bean
ApplicationData.class);
if (_applicationData == null) {
throw new IllegalStateException(
"Cannot get reference to ApplicationData object");
}
}
return _applicationData;
}
Если кому-то интересно, вот код для моего getManagedBean()
метода:
/**
* <p>Retrieve a JSF managed bean instance by name. If the bean has
* never been accessed before then it will likely be instantiated by
* the JSF framework during the execution of this method.</p>
*
* @param managedBeanKey String containing the name of the managed bean
* @param clazz Class object that corresponds to the managed bean type
* @return T
* @throws IllegalArgumentException Thrown when the supplied key does
* not resolve to any managed bean or when a managed bean is found but
* the object is not of type T
*/
public static <T> T getManagedBean(String managedBeanKey, Class<T> clazz)
throws IllegalArgumentException {
Validate.notNull(managedBeanKey);
Validate.isTrue(!managedBeanKey.isEmpty());
Validate.notNull(clazz);
FacesContext facesContext = FacesContext.getCurrentInstance();
if (facesContext == null) {
return null;
}
Validate.notNull(facesContext.getApplication());
ELResolver resolver = facesContext.getApplication().getELResolver();
Validate.notNull(resolver);
ELContext elContext = facesContext.getELContext();
Validate.notNull(elContext);
Object managedBean = resolver.getValue(
elContext, null, managedBeanKey);
if (!elContext.isPropertyResolved()) {
throw new IllegalArgumentException(
"No managed bean found for key: " + managedBeanKey);
}
if (managedBean == null) {
return null;
} else {
if (clazz.isInstance(managedBean)) {
return clazz.cast(managedBean);
} else {
throw new IllegalArgumentException(
"Managed bean is not of type [" + clazz.getName() +
"] | Actual type is: [" + managedBean.getClass().getName()+
"]");
}
}
}
И не выбирайте мои проверочные звонки.Я заберу их после того, как закончу с разработкой!:)