JSP学习之异常处理实例分析

本文实例讲述了JSP异常处理的方法。分享给大家供大家参考。具体如下:

要对JSP程序可能产生的异常进行处理,可以从多个角度完成:可以针对特定的代码,可以针对特定的文件,也可以针对错误的类型。

如果针对特定的代码,可以使用标准标签库中的核心标签库中的<c:catch>标签。

如果针对特定的文件,可以使用JSP的page指令中的isErrorPage属性和errorPage属性完成。

如果针对特定类型的错误,可以使用web.xml配置文件。

1 使用<c:catch>进行异常处理

<c:catch>标签可以针对特定的一行或者多行代码。<c:catch>标签的基本格式如下:

代码如下:

<c:catch [var="存储异常信息的变量"]>
其他的JSP代码,包括各种标签
</c:catch>

用法与Java代码中的try语句非常类似,把可能产生异常的代码放在<c:catch>开始标志和结束标志之间。这样,当这些代码产生异常的时候,JSP容器会对异常进行处理。

下面是一个对界面异常进行处理的例子:

<c:catch>
  <c:out value="${user.address}"/>
</c:catch>

如果希望产生异常之后,把异常信息保存起来供其它的代码使用,可以使用var属性指定一个变量。

下面的代码会在异常产生的时候把异常信息存储在exceptionInfo变量中:

<c:catch var="exceptionInfo">
  <c:out value="${user.address}"/>
</c:catch>

如果需要可以在后面输出异常的信息:

<c:if test="${exceptionInfo != null}">
  运行时候产生异常,异常信息为:${exceptionInfo.message}
</c:if>

2 为页面指定异常处理文件

如果不想针对每一段代码都进行异常处理,可以以页面作为单位进行异常处理,可以指定当前页面运行过程中产生错误的时候,由特定的页面对异常进行处理。

采用这种异常处理方式,需要编写一个专门的异常处理文件,然后在每个需要进行异常处理的文件中进行设置。

编写异常处理文件

异常处理文件中需要使用page指令的isErrorPage属性,格式如下:

代码如下:

<%@ page isErrorPage="true"%>

如果在页面上进行了这样的设置,页面就具有了一项特殊的功能,能够访问异常对象exception。exception是JSP的内部对象,当页面在运行过程中产生异常的时候,会抛出异常对象exception,该对象包含了异常信息。

下面是一个异常处理文件:

文件名:errorPage.jsp

<%@ page contentType="text/html;charset=gb2312"%>
<%@ page isErrorPage="true"%>

页面产生异常,异常信息如下:

代码如下:

${exception.message}

为页面指定异常处理文件

要想让页面产生异常的时候,由专门的异常处理文件对异常进行处理,需要在该页面中使用page指令的errorPage指定专门的异常处理界面,格式如下:

代码如下:

<%@ page errorPage="异常处理文件"%>

假设要设置前面编写的errorPage.jsp页面为当前页面的异常处理文件,可以使用下面的代码:

代码如下:

<%@ page errorPage="errorPage.jsp"%>

3 通过web.xml进行配置

如果不想为每个页面设置异常处理文件,可以为同一种类型的异常指定统一的异常处理文件。还有一些异常的处理是没有办法通过页面设置来完成的,例如用户输入了网站中的一个不存在文件,这时候应该告诉用户文件不存在,但是这种异常是没有办法通过在页面设置来解决的。

要想为每种类型的异常指定一个异常处理文件,可以通过web.xml进行配置。在web.xml中进行配置可以根据错误类型配置,例如NullPointException、IOException等,也可以根据错误编码配置。

常见的异常编码如下:

403错误:文件被禁止访问;
404错误:文件没有找到;
500错误:文件在运行过程中发生未知错误。
根据异常类型进行配置,可以使用下面的代码:

<error-page>
  < exception-type >java.lang.NullPointerException</exception-type>
  <location>/nullpointer.jsp</location>
</error-page>

根据异常编码进行配置,可以使用下面的代码:

<error-page>
  <error-code>401</error-code>
  <location>/401.jsp</location>
</error-page>

希望本文所述对大家的JSP程序设计有所帮助。

(0)

相关推荐

  • javascript中异常处理案例(推荐)

    如下所示: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <script type="text/javascript"> // cache 缓存 // try-catch-finall

  • javascript 异常处理使用总结

    JavaScript中的异常可以用try..catch..finally语句来处理,也可以手动的来抛出异常. 1.使用try..catch..finally语句来处理异常 js代码在执行过程中如果出现异常,会手动创建一个异常类对象,该异常类对象将被提交给浏览器,这个过程称为"抛出异常".当浏览器接收到一场对象时,会寻找能处理这一异常的代码并把当前异常对象提交给其处理,这一过程被称为"捕获异常".try..catch..finally语句的基本语法格式为: 复制代码

  • 浅谈JavaScript异常处理语句

    程序运行过程中难免会出错,出错后的运行结果往往是不正确的,因此运行时出错的程序通常被强制中止.运行时的错误统称为异常,为了能在错误发生时得到一个处理的机会,JavaScript提供了异常处理语句.包含try-catch.try-catch-finally和throw. try-catch语句 try{ tryStatements } catch(exception){ catchStatements } 参数说明: tryStatements:必选项.可能发生错误的语句序列. exception

  • JS异常处理try..catch语句的作用和实例

    首先一个常识就是,在浏览器执行JS脚本过程中,当出现脚本错误,并且你没有手动进行异常捕捉时,他会在浏览器下面出现黄色的叹号,这是正常的,这也不是最重要的,最重要的是,出错行以下的所有JS代码将中停执行,这是我们不希望看到的,所以说,对于自己写的,拿不准的脚本还是加上异常捕捉比较好. 1 清除黄色叹号: 复制代码 代码如下: window.onerror={return true;}  //这只是表面清除了错误,但JS代码将被中停 2 为容易出错的,容易产生兼容问题的代码段加上try..catch

  • JS中的异常处理方法分享

    js容错语句,就是js出错也不提示错误(防止浏览器右下角有个黄色的三角符号,要不用户体验不好) 复制代码 代码如下: window.onerror=function(){return true;} 下面是为了获取js异常信息,方便开发者找回问题 1,try...catch... 复制代码 代码如下: <script type="text/javascript">var txt=""function message(){try   {   adddlert

  • javascript编程异常处理实例小结

    本文实例总结了javascript编程异常处理的方法.分享给大家供大家参考,具体如下: 前言:在前一篇<asp.net开发中常见公共捕获异常方式总结>,我们整理总结了asp.net服务端的异常处理.这一篇接着前文,简单总结并讨论一下javascript在客户端的异常处理.这样asp.net的服务端和客户端异常处理我们就都有了初步的认识. 1.烦人的脚本错误 楼猪经常装13,但是普遍都没有深度.偶然艰难地看懂了一段英文,终于可以深沉地再装一回: When browsing Web pages o

  • 详解JavaScript中的异常处理方法

    有三种类型的编程错误:(1)语法错误和(2)运行时错误(3)逻辑错误: 语法错误: 语法错误,也被称为解析错误,在编译时进行传统的编程语言,并出现在JavaScript解释时. 例如,下面一行将导致一个语法错误,因为它缺少一个右括号: <script type="text/javascript"> <!-- window.print(; //--> </script> 当一个语法错误在JavaScript中出现,只有在同一个线程中包含的语法错误的影响

  • js中的异常处理try...catch使用介绍

    在JavaScript可以使用try...catch来进行异常处理.例如: 复制代码 代码如下: try { foo.bar();} catch (e) { alert(e.name + ": " + e.message);} 目前我们可能得到的系统异常主要包含以下6种: EvalError: raised when an error occurs executing code in eval() RangeError: raised when a numeric variable o

  • JS异常处理的一个想法(sofish)

    可能由于网络.浏览器问题.缓存等原因,可能导致线上执行 js 的时候与开发环境并不一样,会抛出异常.js 异常基本上是前端开发工程师的家常便饭.如何记录,并使用它,却很少人关注.最近在考虑一个想法,基本上涉及到两步:收集和使用. 一.收集 对于 error 收集这一块,还是比较方便的,因为在各浏览器中都有一个接口:window.onerror,代码如下: 复制代码 代码如下: window.onerror = function(errorMessage, scriptURL, lineNumbe

  • JavaScript 异常处理 详解

    前端工程师都知道 JavaScript 有基本的异常处理能力.我们可以 throw new Error(),浏览器也会在我们调用 API 出错时抛出异常.但估计绝大多数前端工程师都没考虑过收集这些异常信息 反正只要 JavaScript 出错后刷新不复现,那用户就可以通过刷新解决问题,浏览器不会崩溃,当没有发生过好了.这种假设在 Single Page App 流行之前还是成立的.现在的 Single Page App 运行一段时间后状态复杂无比,用户可能进行了若干输入操作才来到这里的,说刷新就

随机推荐