jsp错误-剪切

type Exception report

message

deion The server encountered an internal error () that prevented it from fulfilling this request.

exception
root cause

java.sql.SQLException: [Microsoft][ODBC ???????] ???????
sun.jdbc.odbc.JdbcOdbc.createSQLException(JdbcOdbc.java:6958)
sun.jdbc.odbc.JdbcOdbc.standardError(JdbcOdbc.java:7115)
sun.jdbc.odbc.JdbcOdbc.SQLGetDataString(JdbcOdbc.java:3908)
sun.jdbc.odbc.JdbcOdbcResultSet.getDataString(JdbcOdbcResultSet.java:5702)
sun.jdbc.odbc.JdbcOdbcResultSet.getString(JdbcOdbcResultSet.java:356)
sun.jdbc.odbc.JdbcOdbcResultSet.getString(JdbcOdbcResultSet.java:413)
org.apache.jsp.courseplaceaction_jsp._jspService(courseplaceaction_jsp.java:68)
org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:94)
javax.servlet.http.HttpServlet.service(HttpServlet.java:810)
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:298)
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:292)
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:236)
javax.servlet.http.HttpServlet.service(HttpServlet.java:810)
解决办法: while(rs.next()){
……
}
也就是错误原因是没有将rs游标定位到第一条记录。
2.Result set type is TYPE_FORWARD_ONLY
java.sql.SQLException: Result set type is TYPE_FORWARD_ONLY
sun.jdbc.odbc.JdbcOdbcResultSet.last(JdbcOdbcResultSet.java:2293)
org.apache.jsp.queryresult_jsp._jspService(queryresult_jsp.java:133)
org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:94)
javax.servlet.http.HttpServlet.service(HttpServlet.java:810)
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:298)
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:292)
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:236)
javax.servlet.http.HttpServlet.service(HttpServlet.java:810)
解决办法:
Statement stmt=conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY);
通过这样设置,rs游标可以自由的移动,不一定就是只向前移动

3.package javax.servlet does not exist

问题在于没有将

Tomcat中的servelet.jar(在tomcat3.3.1libcommonservlet.jar 下 ),或者servlet-api.jar(在tomcat-5.0.24commonlib、servlet-api.jar )添加到了classpath中去。最好添加到用户环境变量里去。
5.解决中文显示中的乱码问题

需要在首行加入如下代码,有时要重新启动Tomcat

<%@ page contentType="text/html;chartset=gb2312" %>

6.result.next()注意的问题

假如你的表结构中各字段的顺序为:title,name,mail,content, add_time

那么你取数据的顺序也应该是:title,name,mail,content, add_time,任何颠倒就会出问题。下面语句执行会正确。

while(result.next())
{

String title=result.getString("title");
String name=result.getString("name");
String mail=result.getString("mail");
String content=result.getString("content");
Timestamp time=result.getTimestamp("add_time");
Date date_time=new Date(time.getTime());
Time time_time=new Time(time.getTime());

%>

异常或错误名称 项目1 项目3 项目3 均值
Exception 35581 2361 28429 --
java.sql.SQLException 17806 100 663 18.87
Java.lang.NullPointerException 15957 545 7364 31.28
Java.lang.NumberFormatException 232 107 34 1.77
Java.lang.StringIndexOutOfBoundsException 113 0 0 0.11
Java.lang.Exception 172 0 1316 1.70
Java.lang.NoClassDefFoundError 4 174 0 2.46
Java.lang.Error 830 129 1830 4.74
Others 467 1306 17222 39.07
有三成以上的错误是java.lang.NullpointerException对象空指针错误

约有近二成java.lang.SQLException错误

近一成的错误是由于Java.lang.NoClassDefFoundError,Java.lang.Error 引起的
另一些错误是由于 java.lang.NumberFormatException, Java.lang.StringIndexOutOfBoundsException引起
通常,为了达到开发出健壮的JAVA应用系统的目的,就必须考虑到"输入的数据无效或操作错误等"意外情况可能发生,因而得要遵循更多的规则,从而减少系统异常或错误出现的频率,实现更高系统健壮性。本文所建议使用的开发方式及示范主要是针对Java Web 应用开发者;同时也适用于您所进行的常规JAVA项目。

下面,我开始对得到的统计结果中的这些异常及错误进行一些分析:

空指针错误 java.lang.NullPointerException
上面的统计结果显示,我们的项目结果有近三成或更多的异常是空指针异常,这说明空指针异常可能很常见。实际上,我相信100%的JAVA程序员都会对空指针异常十分熟悉。

使用基本的JAVA数据类型,变量的值要么已经是默认值,如果没有对其正常赋值,程序便不能通过编译,因此使用基本的JAVA数据类型(double,float,boolean,char,int,long)一般不会引起空指针异常。由此可见,空指针异常主要跟与对象的操作相关。

下面先列出了可能发生空指针异常的几种情况及相应解决方案:

不管对象是否为空就直接开始使用。
(JSP)代码段1:
out.println(request.getParameter("username"));

描述:
代码段1的功能十分简单,就是输出用户输入的表单域"username"的值。

说明:
看上去,上面的语句找不出什么语法错误,而且在大多数情况下也遇不到什么问题。但是,如果某个用户在输入数据时并没有提供表单域"username"的值,或通过某种途径绕过表单直接输入时,此时request.getParameter("username")的值为空(不是空字符串,是空对象null。),out对象的println方法是无法直接对空对象操作,因此代码段1所在的JSP页面将会抛出"java.lang.NullPointerException"异常。

即使对象可能为空时,也调用java.lang.Object或Object对象本身的一些方法如toString(), equals(Object obj)等操作。
(JSP)代码段2:

  String userName = request.getParameter("username");
  If (userName.equals("root"))
  {
// 实际操作….
}
描述:
代码段2的功能是检测用户提供的用户名,如果是用户名称为"root"的用户时,就执行一些特别的操作。

说明:
在代码段2中,如果有用户没有提供表单域"username"的值时,字符串对象userName为null值,不能够将一个null的对象与另一个对象直接比较,同样,代码段2所在的JSP页面就会抛出(java.lang.NullPointerException)空指针错误。
(JSP)代码段3:
String userName = session.getAttribute("session.username").toString();

描述:
代码段3的功能是将session中session.username的值取出,并将该值赋给字符串对象 userName。
说明:
在一般情况下,如果在用户已经进行某个会话,则不会出现什么问题;但是,如果此时应用服务器重新启动,而用户还没有重新登录,(也可能是用户关闭浏览器,但是仍打开原来的页面。)那么,此时该session的值就会失效,同时导致session中的session.username的值为空。对一个为null的对象的直接执行toString()操作,就会导致系统抛出(java.lang.NullPointerException)空指针异常。
解决方案:
为了确保进行操作或引用的对象非空,假若我们要对某对象进行操作或引用,我们首先去检查该对象是否已经实例化且不为空;并且在系统中加入针对对象为空时情况的处理。

如:采用String对象保存用户提交的结果;在如果涉及对象的操作时,先检测其是否为空后,检查到对象为空后,可再选择进行以下任一种处理方式:

处理方式 1) 检查到对象为空时,设置对象值为空字符串或一个默认值;
处理方式 2) 检测到对象为空时,根本不执行某操作,直接跳转到其他处理中。
处理方式 3) 检查到对象为空时,提示用户操作有错误。
将代码段2按以上方式进行改写,得到:
方式1:

String userName = request.getParameter("username");
  // 该变量值为空时,转化为默认空字符串
If (userName == null)
    userName = "";
  If (userName.equals("root"))
  {
// 实际操作….}
方式2:
String userName = request.getParameter("username");
  // 该变量值为空时,转化为默认空字符串,不执行有关操作。
  If (usreName != null)
   { If (userName.equals("root")){}}
方式3:
String userName = request.getParameter("username");
  // 该变量值为空时,转化为默认空字符串,不执行有关操作。
  If (usreName == null)
{ // 提示用户输入信息为空}
实际中,上面提供到三种处理方式也同样适用于其他异常的处理:

异常处理方式 1) 检查到异常出现,设置对象值为空字符串或一个默认值;
异常处理方式 2) 检测到异常出现,根本不执行某操作,直接跳转到其他处理中。
异常处理方式 3) 检查到异常出现,提示用户操作有错误
格式化数字错误 java.lang.NumberFormatException
(JSP)代码段3:
String s_memberid = request.getParameter("memberid");
int i_memberid = Integer.parseInt(s_memberid);
//….其他操作
描述:
以上代码段的作用是将用户提交的表单域memberid的值转化为整数。
说明:
如果用户输入正确的数字如:1082,不会有什么问题。然而,如果用户输入T1082时,由于T1082不是合法的数字格式,JAVA无法将其转化为合适的数字,导致抛出java.lang.NumberFormatException数字格式化异常。
解决方案:
在任何用到字符串转化为数字时,捕捉异常,对异常情况进行处理按异常处理方式

1:检查到异常发生,即赋给某变量一个默认值;(可能在某些情况下导致一其他程序错误[比方说其他模块中并未处理您所赋予的默认值情况,可能导致一些异常或错误出现。])按异常处理方式

3:检查到异常发生,提示用户使用正确的数字格式输入。(实现稍微麻烦一点,但是将错误阻挡在您的模块前[即您提供给其他模块的值均是安全的]。)按这种方法对程序进行改写,在编程时稍微麻烦一点,但这的确会您的模块更加健壮。将代码段3按以上要求进行改写,得到:

String s_memberid = request.getParameter("memberid");
int i_memberid;
try
{i_memberid = Integer.parseInt(s_memberid);
//….其他操作}
catch(NumberFormatException nfe)
{ //方式1:(简单,直接给该编号为一个默认值0;)
i_memberid = 0;
//方式2:(很简陋的做法,建议使用更友好的提示方式)
  out.println("<script>alert('您提供的用户编号有误,请重新输入。';history.go(-1);</script>");}
字符串越界错误 java.lang.StringIndexOutOfBoundsException等字符串类相关错误
代码段4:
  String s_all_power = "1010011";
  String s_access_power = s_all_power.substring(3,4);
描述:
以上代码段功能的功能是获取字符串s_all_power中的第4个字符。
说明:
一般情况下,程序不会有问题,如果由于某种原因,s_all_power长度变短,程序就会抛出字符串错误。
解决方案:对字符串进行截取(substring, charAt)、转换为字节数组(getBytes),字符数组转换为字符串(valueOf)操作时,先对操作字符串对象的存在性(是否为空)及长度进行检查后,再进行操作
改写得到:

  String s_all_power = "1010011";
  if (s_all_power.length>4)
  String s_access_power = s_all_power.substring(3,4);
当然,最好的方法是将这些操作封装到Javabeans 中,使用起来就更方便了。
类定义未找到错误 java.lang.NoClassDefFoundError
原因:
由于该程序调用到的JAVA类文件没有正确上传;
解决方案:将JAVA类文件重新上传。

JAVA类文件已经上传,但应用服务器并未检测到,建议将JSP页面重新更新。
解决方案:将JSP页面更新并上传;或将应用程序服务器进行重新启动。

JAVA错误 java.lang.Error
原因:
对系统所访问外部资源,未执行关闭操作,导致外部资源大量浪费,最终可能导致系统无法正常运行;
对系统所访问的外部资源关闭次数太多,外部系统无法正常处理;
所系统访问的外部资源出现异常情况。
解决方案:
访问外部资源前,首先检查该资源(如数据库)是否可正常连接或操作。
访问外部资源时,如果进行了连接,一定进行关闭操作,并仅进行一次关闭操作。
尽量在同一操作***享外部资源,以减少该操作对资源的消费,提高程序的执行效率。






评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值