@WebServlet
、、@WebFilter
などのサーブレットベースのアーティファクトでは@WebListener
、次の方法で「プレーンバニラ」JSFを取得できます@ManagedBean @RequestScoped
。
Bean bean = (Bean) request.getAttribute("beanName");
と@ManagedBean @SessionScoped
によって:
Bean bean = (Bean) request.getSession().getAttribute("beanName");
と@ManagedBean @ApplicationScoped
によって:
Bean bean = (Bean) getServletContext().getAttribute("beanName");
これには、BeanがJSFによって事前に自動作成されている必要があることに注意してください。それ以外の場合、これらは戻りnull
ます。次に、手動でBeanを作成し、を使用する必要がありますsetAttribute("beanName", bean)
。
@Named
JSF 2.3が非推奨になったため、代わりにCDIを使用できる場合は@ManagedBean
、特にBeanを手動で作成する必要がなくなるため、さらに簡単になります。
@Inject
private Bean bean;
@Named @ViewScoped
BeanはJSFビューステートによってのみ識別でき、FacesServlet
が呼び出された場合にのみ使用できるため、これは使用中は機能しないことに注意してください。@Inject
したがって、その前に実行されるフィルターでは、 edにアクセスする@ViewScoped
と常にがスローされContextNotActiveException
ます。
あなたが中@ManagedBean
にいるときだけ、あなたは使うことができます@ManagedProperty
:
@ManagedProperty("#{bean}")
private Bean bean;
@Named
これは、または@WebServlet
またはその他のアーティファクトの内部では機能しないことに注意してください。それは本当に内部@ManagedBean
でのみ機能します。
の中にいない@ManagedBean
が、FacesContext
すぐに利用できる(つまり、FacesContext#getCurrentInstance()
戻らないnull
)場合は、次を使用することもできますApplication#evaluateExpressionGet()
。
FacesContext context = FacesContext.getCurrentInstance();
Bean bean = context.getApplication().evaluateExpressionGet(context, "#{beanName}", Bean.class);
これは次のように便利です。
@SuppressWarnings("unchecked")
public static <T> T findBean(String beanName) {
FacesContext context = FacesContext.getCurrentInstance();
return (T) context.getApplication().evaluateExpressionGet(context, "#{" + beanName + "}", Object.class);
}
次のように使用できます。
Bean bean = findBean("bean");
参照: