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
原因:
對系統所訪問外部資源,未執行關閉操作,導致外部資源大量浪費,最終可能導致系統無法正常運行;
對系統所訪問的外部資源關閉次數太多,外部系統無法正常處理;
所繫統訪問的外部資源出現異常情況。
解決方案:
訪問外部資源前,首先檢查該資源(如數據庫)是否可正常連接或操作。
訪問外部資源時,如果進行了連接,一定進行關閉操作,並僅進行一次關閉操作。
儘量在同一操作***享外部資源,以減少該操作對資源的消費,提高程序的執行效率。






發佈了43 篇原創文章 · 獲贊 1 · 訪問量 15萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章