小编典典

JSP Servlet中的最佳实践错误处理

jsp

我有一个非常简单的Web应用程序,它通过Oracle数据库使用jsp / servlet。尽管该应用程序正在增长,但目前只有少量页面。

截至目前,我还没有任何东西可以显示用户错误。例如,如果数据库连接失败,则该页面为空白。我很好奇错误处理的最佳实践是什么?我应该打印出堆栈跟踪吗?是否所有错误都应转到默认错误页面?

任何建议或参考材料将不胜感激。您可能会说,这对我来说是新的。

谢谢


阅读 225

收藏
2020-06-08

共1个答案

小编典典

对于被认为是不可恢复的错误(例如数据库连接问题),这些类型的错误通常在应用程序的最高层捕获,并在单个位置处理。许多框架会将这些转换为未经检查的样本,以避免中间层不得不处理它们。

对于这些不可恢复的异常,通常您会向用户显示一个用户友好且相当通用的错误页面,并将堆栈跟踪信息(包含更多详细信息)发送到日志文件,以供系统管理员和/或开发人员查询。

Servlet规范提供了一种通过web.xmlvia error-page标签处理错误的方法。

如果您使用的是Servlet 3.0或更高版本,则web.xml可以在其中添加:

<error-page>
    <location>/error.html</location>
</error-page>

这将捕获所有未处理的异常,并将它们发送到error.htmlwebapp根目录中的页面。

在servlet规范的早期版本中,您必须指定异常类型或错误代码(您仍然可以执行此操作以进行更细粒度的错误处理):

<error-page>
    <exception-type>java.lang.Exception</exception-type>
    <location>/error.html</location>
</error-page>

要么:

<error-page>
    <error-code>500</error-code>
    <location>/error.html</location>
</error-page>

和:

<error-page>
    <error-code>404</error-code>
    <location>/notFound.html</location>
</error-page>

另外,如果您需要在错误页面中进行动态处理,则可以转发到另一个JSP(或另一个servlet):

<error-page>
    <error-code>500</error-code>
    <location>/WEB-INF/jsp/error.jsp</location>
</error-page>

如果您需要从错误页面内部访问异常(也许您想显示异常所保存的某些特定数据,例如代码),则可以通过javax.servlet.error.exceptionrequest属性访问原始异常:

Throwable throwable = (Throwable) request.getAttribute("javax.servlet.error.exception");

如果您的应用程序正在增长,则最好迁移到MVC框架(例如Spring
MVC)
,这将使您的应用程序的构建更易于管理,此外,它还将提供一致且定义明确的错误处理机制。

2020-06-08