首先,您发布的代码在重定向之前不会看到FacesMessage,您将在重定向之后看到它。但是,为了实现这一点,您需要添加一个过滤器,因为重定向时邮件会丢失。这是你需要(不要忘了声明它在web.xml)过滤器的代码:
public class MultiPageMessagesSupport implements PhaseListener {
private static final long serialVersionUID = 1250469273857785274L;
private static final String sessionToken = "MULTI_PAGE_MESSAGES_SUPPORT";
@Override
public PhaseId getPhaseId() {
return PhaseId.ANY_PHASE;
}
/*
* Check to see if we are "naturally" in the RENDER_RESPONSE phase. If we
* have arrived here and the response is already complete, then the page is
* not going to show up: don't display messages yet.
*/
@Override
public void beforePhase(final PhaseEvent event) {
FacesContext facesContext = event.getFacesContext();
int msg = this.saveMessages(facesContext);
if (PhaseId.RENDER_RESPONSE.equals(event.getPhaseId())) {
if (!facesContext.getResponseComplete()) {
this.restoreMessages(facesContext);
}
}
}
/*
* Save messages into the session after every phase.
*/
@Override
public void afterPhase(final PhaseEvent event) {
if (event.getPhaseId() == PhaseId.APPLY_REQUEST_VALUES ||
event.getPhaseId() == PhaseId.PROCESS_VALIDATIONS ||
event.getPhaseId() == PhaseId.INVOKE_APPLICATION) {
FacesContext facesContext = event.getFacesContext();
int msg = this.saveMessages(facesContext);
}
}
@SuppressWarnings("unchecked")
private int saveMessages(final FacesContext facesContext) {
List<FacesMessage> messages = new ArrayList<FacesMessage>();
for (Iterator<FacesMessage> iter = facesContext.getMessages(null); iter.hasNext();) {
messages.add(iter.next());
iter.remove();
}
if (messages.isEmpty()) {
return 0;
}
Map<String, Object> sessionMap = facesContext.getExternalContext().getSessionMap();
List<FacesMessage> existingMessages = (List<FacesMessage>) sessionMap.get(sessionToken);
if (existingMessages != null) {
existingMessages.addAll(messages);
} else {
sessionMap.put(sessionToken, messages);
}
return messages.size();
}
@SuppressWarnings("unchecked")
private int restoreMessages(final FacesContext facesContext) {
Map<String, Object> sessionMap = facesContext.getExternalContext().getSessionMap();
List<FacesMessage> messages = (List<FacesMessage>) sessionMap.remove(sessionToken);
if (messages == null) {
return 0;
}
int restoredCount = messages.size();
for (Object element : messages) {
facesContext.addMessage(null, (FacesMessage) element);
}
return restoredCount;
}
}
如果你不工作,你需要之前显示的信息,然后你必须如下所示:使方法返回void,通过ajax调用它,并在添加成功消息后调用一些javascript方法,该方法将等待几秒钟,然后进行重定向(也许通过以编程方式单击隐藏的按钮重定向到下一页)。 在我看来这是不值得的麻烦,你只会推迟登录过程。反正用户就会知道塔tlogin成功是因为他会重定向到主页(或你送他到任何网页)
编辑: 的消息显示在页面时的方法完成,在管理,以便等待bean方法不起作用。加入的FacesMessage后,使用
RequestContext.getCurrentInstance().execute("waitAndRedirect()");
而在你的XHTML,你需要有一个类似的JavaScript函数:
function waitAndRedirect() {
setTimeout(function() {
hiddenButtonId.click();
}, 2000);
}
其中hiddenButtonId是AP的ID:该按钮来重定向主页和隐藏(显示:无)
但是,再次,这是一个讨厌的方法,在我看来没有必要这样做,你只会延迟登录过程。
你好@Damian, 我与阿贾克斯的工作,我都试过Thread.currentThread()睡眠(5000);它让页面等待5秒,但消息在重定向后显示,我只是想在显示消息之前用该方法重定向,谢谢! – Holysh 2013-04-04 12:35:41
请注意,这是一个JSF 1。x目标解决方案。在JSF 2.x中,使用Flash范围有更好的方法。 – BalusC 2013-04-04 12:54:10
@Holysh我编辑了答案,解释如何在重定向之前显示消息。 – Damian 2013-04-04 19:22:05