我正在Glassfish v3上开发JSF
2.0应用程序,并且试图处理ViewExpiredException。但是无论我做什么,我总会得到一个Glassfish错误报告,而不是我自己的错误页面。
为了模拟VEE的发生,我将以下函数插入到支持bean中,从而触发了VEE。我正在通过commandLink从我的JSF页面触发此功能。代码:
@Named
public class PersonHome {
(...)
public void throwVEE() {
throw new ViewExpiredException();
}
}
最初,我只是通过将一个错误页面添加到我的web.xml中来进行尝试:
<error-page>
<exception-type>javax.faces.application.ViewExpiredException</exception-type>
<location>/error.xhtml</location>
</error-page>
但这不起作用,我没有重定向到错误,但是显示了Glassfish错误页面,该页面显示了HTTP Status 500页面,内容如下:
description:The server encountered an internal error () that prevented it from fulfilling this request.
exception: javax.servlet.ServletException: javax.faces.application.ViewExpiredException
root cause: javax.faces.el.EvaluationException:javax.faces.application.ViewExpiredException
root cause:javax.faces.application.ViewExpiredException
我试图做的下一件事是编写ExceptionHandlerFactory和CustomExceptionHandler,如 JavaServerFaces
2.0-完整参考中所述
。所以我将以下标签插入faces-config.xml:
<factory>
<exception-handler-factory>
exceptions.ExceptionHandlerFactory
</exception-handler-factory>
</factory>
并添加了以下类:工厂:
package exceptions;
import javax.faces.context.ExceptionHandler;
public class ExceptionHandlerFactory extends javax.faces.context.ExceptionHandlerFactory {
private javax.faces.context.ExceptionHandlerFactory parent;
public ExceptionHandlerFactory(javax.faces.context.ExceptionHandlerFactory parent) {
this.parent = parent;
}
@Override
public ExceptionHandler getExceptionHandler() {
ExceptionHandler result = parent.getExceptionHandler();
result = new CustomExceptionHandler(result);
return result;
}
}
自定义异常处理程序:
package exceptions;
import java.util.Iterator;
import javax.faces.FacesException;
import javax.faces.application.NavigationHandler;
import javax.faces.application.ViewExpiredException;
import javax.faces.context.ExceptionHandler;
import javax.faces.context.ExceptionHandlerWrapper;
import javax.faces.context.FacesContext;
import javax.faces.event.ExceptionQueuedEvent;
import javax.faces.event.ExceptionQueuedEventContext;
class CustomExceptionHandler extends ExceptionHandlerWrapper {
private ExceptionHandler parent;
public CustomExceptionHandler(ExceptionHandler parent) {
this.parent = parent;
}
@Override
public ExceptionHandler getWrapped() {
return this.parent;
}
@Override
public void handle() throws FacesException {
for (Iterator<ExceptionQueuedEvent> i = getUnhandledExceptionQueuedEvents().iterator(); i.hasNext();) {
ExceptionQueuedEvent event = i.next();
System.out.println("Iterating over ExceptionQueuedEvents. Current:" + event.toString());
ExceptionQueuedEventContext context = (ExceptionQueuedEventContext) event.getSource();
Throwable t = context.getException();
if (t instanceof ViewExpiredException) {
ViewExpiredException vee = (ViewExpiredException) t;
FacesContext fc = FacesContext.getCurrentInstance();
NavigationHandler nav =
fc.getApplication().getNavigationHandler();
try {
// Push some useful stuff to the flash scope for
// use in the page
fc.getExternalContext().getFlash().put("expiredViewId", vee.getViewId());
nav.handleNavigation(fc, null, "/login?faces-redirect=true");
fc.renderResponse();
} finally {
i.remove();
}
}
}
// At this point, the queue will not contain any ViewExpiredEvents.
// Therefore, let the parent handle them.
getWrapped().handle();
}
}
但是仍然没有将我重定向到我的错误页面-我遇到了与上述相同的HTTP 500错误。我在做错什么,我的实现中可能缺少哪些异常处理不正确的内容? 任何
帮助,高度赞赏!
编辑
好吧,我很诚实。实际上,我的代码实际上是用Scala编写的,但这是一个很长的故事。我一直认为这是一个Java问题。在这种情况下,真正的错误是我自己的愚蠢。在我的(Scala)代码中,在CustomExceptionHandler中,我忘记添加带有“
i.remove();”的行。因此,ViewExpiredException在处理完之后留在UnhandledExceptionsQueue中,并且“冒泡了”。当它冒泡时,它变成了ServletException。
非常抱歉使你们俩混淆!
这个测试用例是假的。在ViewExpiredException
通常恢复视图(因为它缺少在会议)期间,未呈现响应,也没有实例化的bean时只被扔出。在您的情况下,在实例化bean期间抛出此异常,并且将此异常包装在ServletException
。
在 真正 ViewExpiredException
当您在HTTP会话过期发送一个HTTP
POST请求到服务器通常只抛出。因此,基本上有两种方法可以可靠地重现此内容:
h:form
在网络浏览器中以POST形式打开JSF页面(默认情况下已为POST),关闭服务器并清理其工作目录(这很重要,因为大多数服务器在关闭时会将打开的会话序列化为磁盘,并在启动时反序列化它们),然后重新启动服务器并提交已经打开的表单。A ViewExpiredException
将被抛出。
将<session-timeout>
in 设置web.xml
为1
分钟,并在使用POST表单打开JSF页面后的1分钟内提交表单。这也将引发ViewExpiredException
。
问题内容: 我正在尝试捕获“ android.database.sqlite.SQLiteException:错误代码5:数据库已锁定”异常,并带有: 由于某些原因,我仍然会收到错误消息,并且LogCat中没有显示“ caught”。我尝试捕获一般的“异常”,但这仍然行不通。怎么了? 更新, 我发现了这个问题,这确实很奇怪:由于某种原因,将goto10声明的db.insert()更改为db.ins
问题内容: 尽管我在日志中看到了异常,但似乎无法捕获到约束违例异常。 实体 我正试图抓住它 -它永远不会到达捕获块。 当我使用 捕获(异常e) 我捕获到“ javax.transaction.RollbackException:ARJUNA016053:无法提交事务。” 这是错误日志: 我究竟做错了什么 ? 更新>> 我当前的代码是: 日志是 环境:PostgreSQL 9.2 JBoss AS
我使用的是Spring Boot 2和Spring Boot starter数据jpa以及底层的MariaDB。 我有一个带有唯一键“用户名”的表。如果违反了此约束,我想捕获,但似乎Spring正在记录并且不会在记录后重新抛出(我最好的猜测)。被抛出。 我想在中捕获。 以下是几段代码片段: 堆栈跟踪:
问题内容: 我的IDE给我该行的错误 我试着抓住,但是并没有使错误消失。有什么想法吗? 问题答案: 扩展了,所以您的IDE本身就有了更深的麻烦-也许库导入被搞砸了?
我正在尝试捕获SocketTimeoutException,以便我的套接字保持活动状态,并且可以继续读取程序。不幸的是,无论我如何尝试捕获读取超时,我都无法捕获,因此应用程序关闭。
我有一个实体类Person,它通过JoinColumn连接到另一个实体Address,并且与Person有一个关系,Address实体在字段Country上有一个@NotNull注释。 简化代码如下: 我还有一个服务方法,即updateAddress,该方法最简单的形式如下: 我编写了一个小的单元测试,其中我试图使用updateAddress方法为一个没有预定义地址的人更新地址。 即 Transa