Java Exception:
十多年的崗巴網(wǎng)站建設(shè)經(jīng)驗(yàn),針對設(shè)計(jì)、前端、開發(fā)、售后、文案、推廣等六對一服務(wù),響應(yīng)快,48小時及時工作處理。網(wǎng)絡(luò)營銷推廣的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動調(diào)整崗巴建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計(jì),從而大程度地提升瀏覽體驗(yàn)。創(chuàng)新互聯(lián)從事“崗巴網(wǎng)站設(shè)計(jì)”,“崗巴網(wǎng)站推廣”以來,每個客戶項(xiàng)目都認(rèn)真落實(shí)執(zhí)行。
1、Error
2、Runtime Exception 運(yùn)行時異常
3、Exception
4、throw 用戶自定義異常
異常類分兩大類型:Error類代表了編譯和系統(tǒng)的錯誤,不允許捕獲;Exception類代表了標(biāo)準(zhǔn)Java庫方法所激發(fā)的異常。Exception類還包含運(yùn)行異常類Runtime_Exception和非運(yùn)行異常類Non_RuntimeException這兩個直接的子類。
運(yùn)行異常類對應(yīng)于編譯錯誤,它是指Java程序在運(yùn)行時產(chǎn)生的由解釋器引發(fā)的各種異常。運(yùn)行異常可能出現(xiàn)在任何地方,且出現(xiàn)頻率很高,因此為了避免巨大的系統(tǒng)資源開銷,編譯器不對異常進(jìn)行檢查。所以Java語言中的運(yùn)行異常不一定被捕獲。出現(xiàn)運(yùn)行錯誤往往表示代碼有錯誤,如:算數(shù)異常(如被0除)、下標(biāo)異常(如數(shù)組越界)等。
非運(yùn)行異常時Non_RuntimeException類及其子類的實(shí)例,又稱為可檢測異常。Java編譯器利用分析方法或構(gòu)造方法中可能產(chǎn)生的結(jié)果來檢測Java程序中是否含有檢測異常的處理程序,對于每個可能的可檢測異常,方法或構(gòu)造方法的throws子句必須列出該異常對應(yīng)的類。在Java的標(biāo)準(zhǔn)包java.lang java.util 和 java.net 中定義的異常都是非運(yùn)行異常。
算術(shù)異常類:ArithmeticExecption
空指針異常類:NullPointerException
類型強(qiáng)制轉(zhuǎn)換異常:ClassCastException
數(shù)組負(fù)下標(biāo)異常:NegativeArrayException
數(shù)組下標(biāo)越界異常:ArrayIndexOutOfBoundsException
違背安全原則異常:SecturityException
文件已結(jié)束異常:EOFException
文件未找到異常:FileNotFoundException
字符串轉(zhuǎn)換為數(shù)字異常:NumberFormatException
操作數(shù)據(jù)庫異常:SQLException
輸入輸出異常:IOException
方法未找到異常:NoSuchMethodException
java.lang.AbstractMethodError
抽象方法錯誤。當(dāng)應(yīng)用試圖調(diào)用抽象方法時拋出。
java.lang.AssertionError
斷言錯。用來指示一個斷言失敗的情況。
java.lang.ClassCircularityError
類循環(huán)依賴錯誤。在初始化一個類時,若檢測到類之間循環(huán)依賴則拋出該異常。
java.lang.ClassFormatError
類格式錯誤。當(dāng)Java虛擬機(jī)試圖從一個文件中讀取Java類,而檢測到該文件的內(nèi)容不符合類的有效格式時拋出。
java.lang.Error
錯誤。是所有錯誤的基類,用于標(biāo)識嚴(yán)重的程序運(yùn)行問題。這些問題通常描述一些不應(yīng)被應(yīng)用程序捕獲的反常情況。
java.lang.ExceptionInInitializerError
初始化程序錯誤。當(dāng)執(zhí)行一個類的靜態(tài)初始化程序的過程中,發(fā)生了異常時拋出。靜態(tài)初始化程序是指直接包含于類中的static語句段。
java.lang.IllegalAccessError
違法訪問錯誤。當(dāng)一個應(yīng)用試圖訪問、修改某個類的域(Field)或者調(diào)用其方法,但是又違反域或方法的可見性聲明,則拋出該異常。
java.lang.IncompatibleClassChangeError
不兼容的類變化錯誤。當(dāng)正在執(zhí)行的方法所依賴的類定義發(fā)生了不兼容的改變時,拋出該異常。一般在修改了應(yīng)用中的某些類的聲明定義而沒有對整個應(yīng)用重新編譯而直接運(yùn)行的情況下,容易引發(fā)該錯誤。
java.lang.InstantiationError
實(shí)例化錯誤。當(dāng)一個應(yīng)用試圖通過Java的new操作符構(gòu)造一個抽象類或者接口時拋出該異常.
java.lang.InternalError
內(nèi)部錯誤。用于指示Java虛擬機(jī)發(fā)生了內(nèi)部錯誤。
java.lang.LinkageError
鏈接錯誤。該錯誤及其所有子類指示某個類依賴于另外一些類,在該類編譯之后,被依賴的類改變了其類定義而沒有重新編譯所有的類,進(jìn)而引發(fā)錯誤的情況。
java.lang.NoClassDefFoundError
未找到類定義錯誤。當(dāng)Java虛擬機(jī)或者類裝載器試圖實(shí)例化某個類,而找不到該類的定義時拋出該錯誤。
java.lang.NoSuchFieldError
域不存在錯誤。當(dāng)應(yīng)用試圖訪問或者修改某類的某個域,而該類的定義中沒有該域的定義時拋出該錯誤。
java.lang.NoSuchMethodError
方法不存在錯誤。當(dāng)應(yīng)用試圖調(diào)用某類的某個方法,而該類的定義中沒有該方法的定義時拋出該錯誤。
java.lang.OutOfMemoryError
內(nèi)存不足錯誤。當(dāng)可用內(nèi)存不足以讓Java虛擬機(jī)分配給一個對象時拋出該錯誤。
java.lang.StackOverflowError
堆棧溢出錯誤。當(dāng)一個應(yīng)用遞歸調(diào)用的層次太深而導(dǎo)致堆棧溢出時拋出該錯誤。
java.lang.ThreadDeath
線程結(jié)束。當(dāng)調(diào)用Thread類的stop方法時拋出該錯誤,用于指示線程結(jié)束。
java.lang.UnknownError
未知錯誤。用于指示Java虛擬機(jī)發(fā)生了未知嚴(yán)重錯誤的情況。
java.lang.UnsatisfiedLinkError
未滿足的鏈接錯誤。當(dāng)Java虛擬機(jī)未找到某個類的聲明為native方法的本機(jī)語言定義時拋出。
java.lang.UnsupportedClassVersionError
不支持的類版本錯誤。當(dāng)Java虛擬機(jī)試圖從讀取某個類文件,但是發(fā)現(xiàn)該文件的主、次版本號不被當(dāng)前Java虛擬機(jī)支持的時候,拋出該錯誤。
java.lang.VerifyError
驗(yàn)證錯誤。當(dāng)驗(yàn)證器檢測到某個類文件中存在內(nèi)部不兼容或者安全問題時拋出該錯誤。
java.lang.VirtualMachineError
虛擬機(jī)錯誤。用于指示虛擬機(jī)被破壞或者繼續(xù)執(zhí)行操作所需的資源不足的情況。
java.lang.ArithmeticException
算術(shù)條件異常。譬如:整數(shù)除零等。
java.lang.ArrayIndexOutOfBoundsException
數(shù)組索引越界異常。當(dāng)對數(shù)組的索引值為負(fù)數(shù)或大于等于數(shù)組大小時拋出。
java.lang.ArrayStoreException
數(shù)組存儲異常。當(dāng)向數(shù)組中存放非數(shù)組聲明類型對象時拋出。
java.lang.ClassCastException
類造型異常。假設(shè)有類A和B(A不是B的父類或子類),O是A的實(shí)例,那么當(dāng)強(qiáng)制將O構(gòu)造為類B的實(shí)例時拋出該異常。該異常經(jīng)常被稱為強(qiáng)制類型轉(zhuǎn)換異常。
java.lang.ClassNotFoundException
找不到類異常。當(dāng)應(yīng)用試圖根據(jù)字符串形式的類名構(gòu)造類,而在遍歷CLASSPAH之后找不到對應(yīng)名稱的class文件時,拋出該異常。
java.lang.CloneNotSupportedException
不支持克隆異常。當(dāng)沒有實(shí)現(xiàn)Cloneable接口或者不支持克隆方法時,調(diào)用其clone()方法則拋出該異常。
java.lang.EnumConstantNotPresentException
枚舉常量不存在異常。當(dāng)應(yīng)用試圖通過名稱和枚舉類型訪問一個枚舉對象,但該枚舉對象并不包含常量時,拋出該異常。
java.lang.Exception
根異常。用以描述應(yīng)用程序希望捕獲的情況。
java.lang.IllegalAccessException
違法的訪問異常。當(dāng)應(yīng)用試圖通過反射方式創(chuàng)建某個類的實(shí)例、訪問該類屬性、調(diào)用該類方法,而當(dāng)時又無法訪問類的、屬性的、方法的或構(gòu)造方法的定義時拋出該異常。
java.lang.IllegalMonitorStateException
違法的監(jiān)控狀態(tài)異常。當(dāng)某個線程試圖等待一個自己并不擁有的對象(O)的監(jiān)控器或者通知其他線程等待該對象(O)的監(jiān)控器時,拋出該異常。
java.lang.IllegalStateException
違法的狀態(tài)異常。當(dāng)在Java環(huán)境和應(yīng)用尚未處于某個方法的合法調(diào)用狀態(tài),而調(diào)用了該方法時,拋出該異常。
java.lang.IllegalThreadStateException
違法的線程狀態(tài)異常。當(dāng)縣城尚未處于某個方法的合法調(diào)用狀態(tài),而調(diào)用了該方法時,拋出異常。
java.lang.IndexOutOfBoundsException
索引越界異常。當(dāng)訪問某個序列的索引值小于0或大于等于序列大小時,拋出該異常。
java.lang.InstantiationException
實(shí)例化異常。當(dāng)試圖通過newInstance()方法創(chuàng)建某個類的實(shí)例,而該類是一個抽象類或接口時,拋出該異常。
java.lang.InterruptedException
被中止異常。當(dāng)某個線程處于長時間的等待、休眠或其他暫停狀態(tài),而此時其他的線程通過Thread的interrupt方法終止該線程時拋出該異常。
java.lang.NegativeArraySizeException
數(shù)組大小為負(fù)值異常。當(dāng)使用負(fù)數(shù)大小值創(chuàng)建數(shù)組時拋出該異常。
java.lang.NoSuchFieldException
屬性不存在異常。當(dāng)訪問某個類的不存在的屬性時拋出該異常。
java.lang.NoSuchMethodException
方法不存在異常。當(dāng)訪問某個類的不存在的方法時拋出該異常。
java.lang.NullPointerException
空指針異常。當(dāng)應(yīng)用試圖在要求使用對象的地方使用了null時,拋出該異常。譬如:調(diào)用null對象的實(shí)例方法、訪問null對象的屬性、計(jì)算null對象的長度、使用throw語句拋出null等等。
java.lang.NumberFormatException
數(shù)字格式異常。當(dāng)試圖將一個String轉(zhuǎn)換為指定的數(shù)字類型,而該字符串確不滿足數(shù)字類型要求的格式時,拋出該異常。
java.lang.RuntimeException
運(yùn)行時異常。是所有Java虛擬機(jī)正常操作期間可以被拋出的異常的父類。
java.lang.SecurityException
安全異常。由安全管理器拋出,用于指示違反安全情況的異常。
java.lang.StringIndexOutOfBoundsException
字符串索引越界異常。當(dāng)使用索引值訪問某個字符串中的字符,而該索引值小于0或大于等于序列大小時,拋出該異常。
java.lang.TypeNotPresentException
類型不存在異常。當(dāng)應(yīng)用試圖以某個類型名稱的字符串表達(dá)方式訪問該類型,但是根據(jù)給定的名稱又找不到該類型是拋出該異常。該異常與ClassNotFoundException的區(qū)別在于該異常是unchecked(不被檢查)異常,而ClassNotFoundException是checked(被檢查)異常。
java.lang.UnsupportedOperationException
不支持的方法異常。指明請求的方法不被支持情況的異常。
異常
javax.servlet.jsp.JspException: Cannot retrieve mapping for action /Login (/Login是你的action名字)
可能原因
action沒有再struts-config.xml 中定義,或沒有找到匹配的action,例如在JSP文件中使用 html:form action="Login.do".將表單提交給Login.do處理,如果出現(xiàn)上述異常,請查看struts-config.xml中的定義部分,有時可能是打錯了字符或者是某些不符合規(guī)則,可以使用strutsconsole工具來檢查。
-----------------------------------------------------------------------------------------------------------------
異常
org.apache.jasper.JasperException: Cannot retrieve definition for form bean null
可能原因
這個異常是因?yàn)镾truts根據(jù)struts-config.xml中的mapping沒有找到action期望的form bean。大部分的情況可能是因?yàn)樵趂orm-bean中設(shè)置的name屬性和action中設(shè)置的name屬性不匹配所致。換句話說,action和form都應(yīng)該各自有一個name屬性,并且要精確匹配,包括大小寫。這個錯誤當(dāng)沒有name屬性和action關(guān)聯(lián)時也會發(fā)生,如果沒有在action中指定name屬性,那么就沒有name屬性和action相關(guān)聯(lián)。當(dāng)然當(dāng)action制作某些控制時,譬如根據(jù)參數(shù)值跳轉(zhuǎn)到相應(yīng)的jsp頁面,而不是處理表單數(shù)據(jù),這是就不用name屬性,這也是action的使用方法之一。
-----------------------------------------------------------------------------------------------------------------
異常
No action instance for path /xxxx could be created
可能原因
特別提示:因?yàn)橛泻芏嘀星闆r會導(dǎo)致這個錯誤的發(fā)生,所以推薦大家調(diào)高你的web服務(wù)器的日志/調(diào)試級別,這樣可以從更多的信息中看到潛在的、在試圖創(chuàng)建action類時發(fā)生的錯誤,這個action類你已經(jīng)在struts-config.xml中設(shè)置了關(guān)聯(lián)(即添加了action標(biāo)簽)。
在struts-config.xml中通過action標(biāo)簽的class屬性指定的action類不能被找到有很多種原因,例如:定位編譯后的.class文件失敗。Failure to place compiled .class file for the action in the classpath (在web開發(fā)中,class的的位置在r WEB-INF/classes,所以你的action class必須要在這個目錄下。例如你的action類位于WEB-INF/classes/action/Login.class,那么在struts-config.xml中設(shè)置action的屬性type時就是action.Login).
拼寫錯誤,這個也時有發(fā)生,并且不易找到,特別注意第一個字母的大小寫和包的名稱。
-----------------------------------------------------------------------------------------------------------------
異常
javax.servlet.jsp.JspException: No getter method for property username of bean org.apache.struts.taglib.html.BEAN
可能原因
沒有位form bean中的某個變量定義getter 方法
這個錯誤主要發(fā)生在表單提交的FormBean中,用struts標(biāo)記html:text property=”username”時,在FormBean中必須有一個getUsername()方法。注意字母“U”。
-----------------------------------------------------------------------------------------------------------------
異常
java.lang.NoClassDefFoundError: org/apache/struts/action/ActionForm
可能原因
這個錯誤主要發(fā)生在在classpath中找不到相應(yīng)的Java .class文件。如果這個錯誤發(fā)生在web應(yīng)用程序的運(yùn)行時,主要是因?yàn)橹付ǖ腸lass文件不在web server的classpath中(/WEB-INF/classes 和 /WEB-INF/lib)。在上面的錯誤中,原因是找不到ActionForm類。
-----------------------------------------------------------------------------------------------------------------
異常
javax.servlet.jsp.JspException: Exception creating bean of class org.apache.struts.action.ActionForm: {1}
可能原因
Instantiating Struts-provided ActionForm class directly instead of instantiating a class derived off ActionForm. This mightoccur implicitly if you specify that a form-bean is this Struts ActionForm class rather than specifying a child of this classfor the form-bean.
Not associating an ActionForm-descended class with an action can also lead to this error.
-----------------------------------------------------------------------------------------------------------------
異常
javax.servlet.jsp.JspException: Cannot find ActionMappings or ActionFormBeans collection
可能原因
不是標(biāo)識Struts actionServlet的servlet標(biāo)記就是映射.do擴(kuò)展名的sevlet-mapping標(biāo)記或者兩者都沒有在web.xml中聲明。
在struts-config.xml中的打字或者拼寫錯誤也可導(dǎo)致這個異常的發(fā)生。例如缺少一個標(biāo)記的關(guān)閉符號/。最好使用struts console工具檢查一下。
另外,load-on-startup必須在web.xml中聲明,這要么是一個空標(biāo)記,要么指定一個數(shù)值,這個數(shù)值用來表servlet運(yùn)行的優(yōu)先級,數(shù)值越大優(yōu)先級越低。
還有一個和使用load-on-startup有關(guān)的是使用Struts預(yù)編譯JSP文件時也可能導(dǎo)致這個異常。
-----------------------------------------------------------------------------------------------------------------
異常
java.lang.NullPointerException at org.apache.struts.util.RequestUtils.forwardURL(RequestUtils.java:1223)
可能原因
在struts-config.xml中的forward元素缺少path屬性。例如應(yīng)該是如下形式:
forward name="userhome" path="/user/userhome.jsp"/
-----------------------------------------------------------------------------------------------------------------
異常
javax.servlet.jsp.JspException: Cannot find bean org.apache.struts.taglib.html.BEAN in any scope
Probable Causes
試圖在Struts的form標(biāo)記外使用form的子元素。這常常發(fā)生在你在/html:form后面使用Struts的html標(biāo)記。另外要注意可能你不經(jīng)意使用的無主體的標(biāo)記,如html:form … /,這樣web 服務(wù)器解析時就當(dāng)作一個無主體的標(biāo)記,隨后使用的所有html標(biāo)記都被認(rèn)為是在這個標(biāo)記之外的,如又使用了html:text property=”id”還有就是在使用taglib引入HTML標(biāo)記庫時,你使用的prefix的值不是html。
-----------------------------------------------------------------------------------------------------------------
異常
javax.servlet.jsp.JspException: Missing message for key xx.xx.xx
Probable Causes
這個key的值對沒有在資源文件ApplicationResources.properties中定義。如果你使用eclipse時經(jīng)常碰到這樣的情況,當(dāng)項(xiàng)目重新編譯時,eclipse會自動將classes目錄下的資源文件刪除。
資源文件ApplicationResources.properties 不在classpath中應(yīng)將資源文件放到 WEB-INF/classes 目錄下,當(dāng)然要在struts-config.xml中定義)
-----------------------------------------------------------------------------------------------------------------
異常
Cannot find message resources under key org.apache.struts.action.MESSAGE
可能原因
很顯然,這個錯誤是發(fā)生在使用資源文件時,而Struts沒有找到資源文件。
Implicitly trying to use message resources that are not available (such as using empty html:options tag instead of specifyingthe options in its body -- this assumes options are specified in ApplicationResources.properties file)
XML parser issues -- too many, too few, incorrect/incompatible versions
-----------------------------------------------------------------------------------------------------------------
異常
Strange and seemingly random characters in HTML and on screen, but not in original JSP or servlet.
可能原因
混和使用Struts的html:form標(biāo)記和標(biāo)準(zhǔn)的HTML標(biāo)記不正確。
使用的編碼樣式在本頁中不支持。
-----------------------------------------------------------------------------------------------------------------
異常
"Document contained no data" in Netscape
No data rendered (completely empty) page in Microsoft Internet Explorer
可能原因
使用一個Action的派生類而沒有實(shí)現(xiàn)perform()方法或execute()方法。在Struts1.0中實(shí)現(xiàn)的是perform()方法,在Struts1.1中實(shí)現(xiàn)的是execute()方法,但Struts1.1向后兼容perform()方法。但你使用Struts1.1創(chuàng)建一個Action的派生類,并且實(shí)現(xiàn)了execute()方法,而你在Struts1.0中運(yùn)行的話,就會得到"Document contained nodata" error message in Netscape or a completely empty (no HTML whatsoever) page rendered in Microsoft Internet Explorer.”的錯誤信息。
---------------------------------------------------------------------------------------------------------------------------
異常
ServletException: BeanUtils.populate
解決方案
在用Struts上傳文件時,遇到了javax.servlet.ServletException: BeanUtils.populate異常。
我的ActionServlet并沒有用到BeanUtils這些工具類。后來仔細(xì)檢查代碼發(fā)現(xiàn)是在jsp文件里的form忘了加enctype="multipart/form-data" 了。所以寫程序遇到錯誤或異常應(yīng)該從多方面考慮問題存在的可能性,想到系統(tǒng)提示信息以外的東西。
----------------------------------------------------------------------------------------------------------------------------
1. 定義Action后, 如果指定了name, 那么必須要定義一個與它同名的FormBean才能進(jìn)行form映射.2. 如果定義Action后, 提交頁面時出現(xiàn) "No input attribute for mapping path..." 錯誤, 則需要在其input屬性中定義轉(zhuǎn)向的頁面.3. 如果插入新的數(shù)據(jù)時出現(xiàn) "Batch update row count wrong:..." 錯誤, 則說明XXX.hbm.xml中指定的key的類型為原始類型(int, long),因?yàn)檫@種類型會自動分配值, 而這個值往往會讓系統(tǒng)認(rèn)為已經(jīng)存在該記錄, 正確的方法是使用java.lang.Integer或java.lang.Long對象.4. 如果插入數(shù)據(jù)時出現(xiàn) "argument type mismatch" 錯誤, 可能是你使用了Date等特殊對象, 因?yàn)閟truts不能自動從String型轉(zhuǎn)換成Date型,所以, 你需要在Action中手動把String型轉(zhuǎn)換成Date型.5. Hibernate中, Query的iterator()比list()方法快很多.6. 如果出現(xiàn) "equal symbol expected" 錯誤, 說明你的strtus標(biāo)簽中包含另一個標(biāo)簽或者變量, 例如:
html:select property="test" onchange="%=test%"/
或者
html:hidden property="test" value="bean:write name="t" property="p"/"/
這樣的情況...
---------------------------------------------------------------------------------------------------------------------------
錯誤:Exception in thread "main" org.hibernate.exception.SQLGrammarException: Could not execute JDBC batch update原因與解決: 因?yàn)镠ibernate Tools(或者Eclipse本身的Database Explorer)生成*.hbn.xml工具中包含有catalog="***"(*表示數(shù)據(jù)庫名稱)這樣的屬性,將該屬性刪除就可以了
---------------------------------------------------------------------------------------------------------------------------
錯誤:org.hibernate.ObjectDeletedException: deleted object would be re-saved by cascade (remove deleted object from associations)
原因與解決:
方法1 刪除Set方的cascade
方法2 解決關(guān)聯(lián)關(guān)系后,再刪除
方法3 在many-to-one方增加cascade 但值不能是none
最后一招:
檢查一下hashCode equals是否使用了id作為唯一標(biāo)示的選項(xiàng)了;我用uuid.hex時是沒有問題的;但是用了native,就不行了,怎么辦?刪除啊!
----------------------------------------------------------------------------------------------------------------------------
問題:今天用Tomcat 5.5.12,發(fā)現(xiàn)原來很好用的系統(tǒng)不能用了,反復(fù)測試發(fā)現(xiàn)頁面中不能包含 taglib,否則會出現(xiàn)以下提示:HTTP Status 500 -type Exception reportMessage description The server encountered an internal error () that prevented it from fulfilling this request.exceptionorg.apache.jasper.JasperException: /index.jsp(1,1) Unable to read TLD "META-INF/tlds/struts-bean.tld" from JAR file"file:*****/WEB-INF/lib/struts.jar":原因:更新了工程用的lib文件夾下的jar,發(fā)布時也發(fā)布了servlet.jar和jsp-api.jar。解決:把jsp-api.jar刪除就解決這個問題了。-----------------------------------------------------------------------------------------------------------------------------
錯誤: java.lang.NullPointerException
原因: 發(fā)現(xiàn) dao 實(shí)例、 manage 實(shí)例等需要注入的東西沒有被注入(俗稱空指針異常)解決:這個時候,你應(yīng)該查看日志文件;默認(rèn)是應(yīng)用服務(wù)器的 log 文件,比如 Tomcat 就是 [Tomcat 安裝目錄 ]/logs ;你會發(fā)現(xiàn)提示你:可能是:org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sf' defined in ServletContextresource [/WEB-INF/applicationContext.xml]: Initialization of bean failed; nested exception isorg.hibernate.HibernateException: could not configure from URL: file:src/hibernate.cfg.xmlorg.hibernate.HibernateException: could not configure from URL: file:src/hibernate.cfg.xml……………………….Caused by: java.io.FileNotFoundException: src\hibernate.cfg.xml可能是:org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sessionFactory' defined inServletContext resource [/WEB-INF/applicationContext.xml]: Initialization of bean failed; nested exception isorg.hibernate.MappingException: Resource: com/mcc/coupon/model/UserRole.hbm.xml not foundorg.hibernate.MappingException: Resource: com/mcc/coupon/model/UserRole.hbm.xml not found然后你就知道原因是因?yàn)榕渲梦募慕馕龀隽隋e誤,這個通過 Web 頁面是看不出來的。更多的是持久化影射文件出的錯誤;導(dǎo)致了沒有被解析;當(dāng)然你需要的功能就無法使用了。
----------------------------------------------------------------------------------------------------------------------------
錯誤:StandardWrapperValve[action]: Servlet.service() for servlet action threw exception
javax.servlet.jsp.JspException: Cannot retrieve mapping for action /settlementTypeManage
或者: type Status report message Servlet action is not available description The requested resource (Servlet action is not available) is not available.
原因: 同 上
----------------------------------------------------------------------------------------------------------------------------
錯誤StandardWrapperValve[jsp]: Servlet.service() for servlet jsp threw exceptionjava.lang.ClassNotFoundException: org.apache.struts.taglib.bean.CookieTei界面錯誤具體描述:
org.apache.jasper.JasperException: Failed to load or instantiate TagExtraInfo class: org.apache.struts.taglib.bean.CookieTei
原因與解決: 方案一你的“html:”開頭的標(biāo)簽沒有放在一個html:form中 方案二重新啟動你的應(yīng)用服務(wù)器,自動就沒有這個問題
異常處理是程序設(shè)計(jì)中一個非常重要的方面,也是程序設(shè)計(jì)的一大難點(diǎn),從C開始,你也許已經(jīng)知道如何用if...else...來控制異常了,也許是自發(fā)的,然而這種控制異常痛苦,同一個異常或者錯誤如果多個地方出現(xiàn),那么你每個地方都要做相同處理,感覺相當(dāng)?shù)穆闊?Java語言在設(shè)計(jì)的當(dāng)初就考慮到這些問題,提出異常處理的框架的方案,所有的異常都可以用一個類型來表示,不同類型的異常對應(yīng)不同的子類異常(這里的異常包括錯誤概念),定義異常處理的規(guī)范,在1.4版本以后增加了異常鏈機(jī)制,從而便于跟蹤異常!這是Java語言設(shè)計(jì)者的高明之處,也是Java語言中的一個難點(diǎn),下面是我對Java異常知識的一個總結(jié),也算是資源回收一下。
一、Java異常的基礎(chǔ)知識
異常是程序中的一些錯誤,但并不是所有的錯誤都是異常,并且錯誤有時候是可以避免的。比如說,你的代碼少了一個分號,那么運(yùn)行出來結(jié)果是提示是錯誤java.lang.Error;如果你用System.out.println(11/0),那么你是因?yàn)槟阌?做了除數(shù),會拋出java.lang.ArithmeticException的異常。 有些異常需要做處理,有些則不需要捕獲處理,后面會詳細(xì)講到。 天有不測風(fēng)云,人有旦夕禍福,Java的程序代碼也如此。在編程過程中,首先應(yīng)當(dāng)盡可能去避免錯誤和異常發(fā)生,對于不可避免、不可預(yù)測的情況則在考慮異常發(fā)生時如何處理。 Java中的異常用對象來表示。Java對異常的處理是按異常分類處理的,不同異常有不同的分類,每種異常都對應(yīng)一個類型(class),每個異常都對應(yīng)一個異常(類的)對象。 異常類從哪里來?有兩個來源,一是Java語言本身定義的一些基本異常類型,二是用戶通過繼承Exception類或者其子類自己定義的異常。Exception 類及其子類是 Throwable 的一種形式,它指出了合理的應(yīng)用程序想要捕獲的條件。 異常的對象從哪里來呢?有兩個來源,一是Java運(yùn)行時環(huán)境自動拋出系統(tǒng)生成的異常,而不管你是否愿意捕獲和處理,它總要被拋出!比如除數(shù)為0的異常。二是程序員自己拋出的異常,這個異??梢允浅绦騿T自己定義的,也可以是Java語言中定義的,用throw 關(guān)鍵字拋出異常,這種異常常用來向調(diào)用者匯報異常的一些信息。 異常是針對方法來說的,拋出、聲明拋出、捕獲和處理異常都是在方法中進(jìn)行的。 Java異常處理通過5個關(guān)鍵字try、catch、throw、throws、finally進(jìn)行管理?;具^程是用try語句塊包住要監(jiān)視的語句,如果在try語句塊內(nèi)出現(xiàn)異常,則異常會被拋出,你的代碼在catch語句塊中可以捕獲到這個異常并做處理;還有以部分系統(tǒng)生成的異常在Java運(yùn)行時自動拋出。你也可以通過throws關(guān)鍵字在方法上聲明該方法要拋出異常,然后在方法內(nèi)部通過throw拋出異常對象。finally語句塊會在方法執(zhí)行return之前執(zhí)行,一般結(jié)構(gòu)如下: try{ 程序代碼 }catch(異常類型1 異常的變量名1){ 程序代碼 }catch(異常類型2 異常的變量名2){ 程序代碼 }finally{ 程序代碼 } catch語句可以有多個,用來匹配多個異常,匹配上多個中一個后,執(zhí)行catch語句塊時候僅僅執(zhí)行匹配上的異常。catch的類型是Java語言中定義的或者程序員自己定義的,表示代碼拋出異常的類型,異常的變量名表示拋出異常的對象的引用,如果catch捕獲并匹配上了該異常,那么就可以直接用這個異常變量名,此時該異常變量名指向所匹配的異常,并且在catch代碼塊中可以直接引用。這一點(diǎn)非常非常的特殊和重要! Java異常處理的目的是提高程序的健壯性,你可以在catch和finally代碼塊中給程序一個修正機(jī)會,使得程序不因異常而終止或者流程發(fā)生以外的改變。同時,通過獲取Java異常信息,也為程序的開發(fā)維護(hù)提供了方便,一般通過異常信息就很快就能找到出現(xiàn)異常的問題(代碼)所在。 Java異常處理是Java語言的一大特色,也是個難點(diǎn),掌握異常處理可以讓寫的代碼更健壯和易于維護(hù)。
二、Java異常類類圖
下面是這幾個類的層次圖: java.lang.Object java.lang.Throwable java.lang.Exception java.lang.RuntimeException java.lang.Error java.lang.ThreadDeath
下面四個類的介紹來自java api 文檔。
1、Throwable Throwable 類是 Java 語言中所有錯誤或異常的超類。只有當(dāng)對象是此類(或其子類之一)的實(shí)例時,才能通過 Java 虛擬機(jī)或者 Java throw 語句拋出。類似地,只有此類或其子類之一才可以是 catch 子句中的參數(shù)類型。 兩個子類的實(shí)例,Error 和 Exception,通常用于指示發(fā)生了異常情況。通常,這些實(shí)例是在異常情況的上下文中新近創(chuàng)建的,因此包含了相關(guān)的信息(比如堆棧跟蹤數(shù)據(jù))。
2、Exception Exception 類及其子類是 Throwable 的一種形式,它指出了合理的應(yīng)用程序想要捕獲的條件,表示程序本身可以處理的異常。
3、Error Error 是 Throwable 的子類,表示僅靠程序本身無法恢復(fù)的嚴(yán)重錯誤,用于指示合理的應(yīng)用程序不應(yīng)該試圖捕獲的嚴(yán)重問題。 在執(zhí)行該方法期間,無需在方法中通過throws聲明可能拋出但沒有捕獲的 Error 的任何子類,因?yàn)镴ava編譯器不去檢查它,也就是說,當(dāng)程序中可能出現(xiàn)這類異常時,即使沒有用try...catch語句捕獲它,也沒有用throws字句聲明拋出它,還是會編譯通過。
4、RuntimeException RuntimeException 是那些可能在 Java 虛擬機(jī)正常運(yùn)行期間拋出的異常的超類。Java編譯器不去檢查它,也就是說,當(dāng)程序中可能出現(xiàn)這類異常時,即使沒有用try...catch語句捕獲它,也沒有用throws字句聲明拋出它,還是會編譯通過,這種異??梢酝ㄟ^改進(jìn)代碼實(shí)現(xiàn)來避免。
5、ThreadDeath 調(diào)用 Thread 類中帶有零參數(shù)的 stop 方法時,受害線程將拋出一個 ThreadDeath 實(shí)例。 僅當(dāng)應(yīng)用程序在被異步終止后必須清除時才應(yīng)該捕獲這個類的實(shí)例。如果 ThreadDeath 被一個方法捕獲,那么將它重新拋出非常重要,因?yàn)檫@樣才能讓該線程真正終止。 如果沒有捕獲 ThreadDeath,則頂級錯誤處理程序不會輸出消息。 雖然 ThreadDeath 類是“正常出現(xiàn)”的,但它只能是 Error 的子類而不是 Exception 的子類,因?yàn)樵S多應(yīng)用程序捕獲所有出現(xiàn)的 Exception,然后又將其放棄。
以上是對有關(guān)異常API的一個簡單介紹,用法都很簡單,關(guān)鍵在于理解異常處理的原理,具體用法參看Java API文檔。
三、Java異常處理機(jī)制
對于可能出現(xiàn)異常的代碼,有兩種處理辦法: 第一、在方法中用try...catch語句捕獲并處理異常,catach語句可以有多個,用來匹配多個異常。例如: public void p(int x){ try{ ... }catch(Exception e){ ... }finally{ ... } }
第二、對于處理不了的異?;蛘咭D(zhuǎn)型的異常,在方法的聲明處通過throws語句拋出異常。例如: public void test1() throws MyException{ ... if(....){ throw new MyException(); } } 如果每個方法都是簡單的拋出異常,那么在方法調(diào)用方法的多層嵌套調(diào)用中,Java虛擬機(jī)會從出現(xiàn)異常的方法代碼塊中往回找,直到找到處理該異常的代碼塊為止。然后將異常交給相應(yīng)的catch語句處理。如果Java虛擬機(jī)追溯到方法調(diào)用棧最底部main()方法時,如果仍然沒有找到處理異常的代碼塊,將按照下面的步驟處理: 第一、調(diào)用異常的對象的printStackTrace()方法,打印方法調(diào)用棧的異常信息。 第二、如果出現(xiàn)異常的線程為主線程,則整個程序運(yùn)行終止;如果非主線程,則終止該線程,其他線程繼續(xù)運(yùn)行。 通過分析思考可以看出,越早處理異常消耗的資源和時間越小,產(chǎn)生影響的范圍也越小。因此,不要把自己能處理的異常也拋給調(diào)用者。 還有一點(diǎn),不可忽視:finally語句在任何情況下都必須執(zhí)行的代碼,這樣可以保證一些在任何情況下都必須執(zhí)行代碼的可靠性。比如,在數(shù)據(jù)庫查詢異常的時候,應(yīng)該釋放JDBC連接等等。finally語句先于return語句執(zhí)行,而不論其先后位置,也不管是否try塊出現(xiàn)異常。finally語句唯一不被執(zhí)行的情況是方法執(zhí)行了System.exit()方法。System.exit()的作用是終止當(dāng)前正在運(yùn)行的 Java 虛擬機(jī)。finally語句塊中不能通過給變量賦新值來改變return的返回值,也建議不要在finally塊中使用return語句,沒有意義還容易導(dǎo)致錯誤。
最后還應(yīng)該注意一下異常處理的語法規(guī)則: 第一、try語句不能單獨(dú)存在,可以和catch、finally組成 try...catch...finally、try...catch、try...finally三種結(jié)構(gòu),catch語句可以有一個或多個,finally語句最多一個,try、catch、finally這三個關(guān)鍵字均不能單獨(dú)使用。 第二、try、catch、finally三個代碼塊中變量的作用域分別獨(dú)立而不能相互訪問。如果要在三個塊中都可以訪問,則需要將變量定義到這些塊的外面。 第三、多個catch塊時候,Java虛擬機(jī)會匹配其中一個異常類或其子類,就執(zhí)行這個catch塊,而不會再執(zhí)行別的catch塊。 第四、throw語句后不允許有緊跟其他語句,因?yàn)檫@些沒有機(jī)會執(zhí)行。 第五、如果一個方法調(diào)用了另外一個聲明拋出異常的方法,那么這個方法要么處理異常,要么聲明拋出。
那怎么判斷一個方法可能會出現(xiàn)異常呢?一般來說,方法聲明的時候用了throws語句,方法中有throw語句,方法調(diào)用的方法聲明有throws關(guān)鍵字。
throw和throws關(guān)鍵字的區(qū)別 throw用來拋出一個異常,在方法體內(nèi)。語法格式為:throw 異常對象。 throws用來聲明方法可能會拋出什么異常,在方法名后,語法格式為:throws 異常類型1,異常類型2...異常類型n。
四、如何定義和使用異常類
1、使用已有的異常類,假如為IOException、SQLException。 try{ 程序代碼 }catch(IOException ioe){ 程序代碼 }catch(SQLException sqle){ 程序代碼 }finally{ 程序代碼 }
2、自定義異常類 創(chuàng)建Exception或者RuntimeException的子類即可得到一個自定義的異常類。例如: public class MyException extends Exception{ public MyException(){} public MyException(String smg){ super(smg); } }
3、使用自定義的異常 用throws聲明方法可能拋出自定義的異常,并用throw語句在適當(dāng)?shù)牡胤綊伋鲎远x的異常。例如: 在某種條件拋出異常 public void test1() throws MyException{ ... if(....){ throw new MyException(); } }
將異常轉(zhuǎn)型(也叫轉(zhuǎn)譯),使得異常更易讀易于理解 public void test2() throws MyException{ ... try{ ... }catch(SQLException e){ ... throw new MyException(); } }
還有一個代碼,很有意思: public void test2() throws MyException{ ... try { ... } catch (MyException e) { throw e; } }
這段代碼實(shí)際上捕獲了異常,然后又和盤托出,沒有一點(diǎn)意義,如果這樣還有什么好處理的,不處理就行了,直接在方法前用throws聲明拋出不就得了。異常的捕獲就要做一些有意義的處理。
五、運(yùn)行時異常和受檢查異常
Exception類可以分為兩種:運(yùn)行時異常和受檢查異常。 1、運(yùn)行時異常 RuntimeException類及其子類都被稱為運(yùn)行時異常,這種異常的特點(diǎn)是Java編譯器不去檢查它,也就是說,當(dāng)程序中可能出現(xiàn)這類異常時,即使沒有用try...catch語句捕獲它,也沒有用throws字句聲明拋出它,還是會編譯通過。例如,當(dāng)除數(shù)為零時,就會拋出java.lang.ArithmeticException異常。 2、受檢查異常 除了RuntimeException類及其子類外,其他的Exception類及其子類都屬于受檢查異常,這種異常的特點(diǎn)是要么用try...catch捕獲處理,要么用throws語句聲明拋出,否則編譯不會通過。 3、兩者的區(qū)別 運(yùn)行時異常表示無法讓程序恢復(fù)運(yùn)行的異常,導(dǎo)致這種異常的原因通常是由于執(zhí)行了錯誤的操作。一旦出現(xiàn)錯誤,建議讓程序終止。 受檢查異常表示程序可以處理的異常。如果拋出異常的方法本身不處理或者不能處理它,那么方法的調(diào)用者就必須去處理該異常,否則調(diào)用會出錯,連編譯也無法通過。當(dāng)然,這兩種異常都是可以通過程序來捕獲并處理的,比如除數(shù)為零的運(yùn)行時異常: public class HelloWorld { public static void main(String[] args) { System.out.println("Hello World!!!"); try{ System.out.println(1/0); }catch(ArithmeticException e){ System.out.println("除數(shù)為0!"); } System.out.println("除數(shù)為零后程序沒有終止啊,呵呵!!!"); } }
運(yùn)行結(jié)果:
Hello World!!! 除數(shù)為0! 除數(shù)為零后程序沒有終止啊,呵呵!!!
4、運(yùn)行時錯誤 Error類及其子類表示運(yùn)行時錯誤,通常是由Java虛擬機(jī)拋出的,JDK中與定義了一些錯誤類,比如VirtualMachineError 和OutOfMemoryError,程序本身無法修復(fù)這些錯誤.一般不去擴(kuò)展Error類來創(chuàng)建用戶自定義的錯誤類。而RuntimeException類表示程序代碼中的錯誤,是可擴(kuò)展的,用戶可以創(chuàng)建特定運(yùn)行時異常類。 Error(運(yùn)行時錯誤)和運(yùn)行時異常的相同之處是:Java編譯器都不去檢查它們,當(dāng)程序運(yùn)行時出現(xiàn)它們,都會終止運(yùn)行。
5、最佳解決方案 對于運(yùn)行時異常,我們不要用try...catch來捕獲處理,而是在程序開發(fā)調(diào)試階段,盡量去避免這種異常,一旦發(fā)現(xiàn)該異常,正確的做法就會改進(jìn)程序設(shè)計(jì)的代碼和實(shí)現(xiàn)方式,修改程序中的錯誤,從而避免這種異常。捕獲并處理運(yùn)行時異常是好的解決辦法,因?yàn)榭梢酝ㄟ^改進(jìn)代碼實(shí)現(xiàn)來避免該種異常的發(fā)生。 對于受檢查異常,沒說的,老老實(shí)實(shí)去按照異常處理的方法去處理,要么用try...catch捕獲并解決,要么用throws拋出! 對于Error(運(yùn)行時錯誤),不需要在程序中做任何處理,出現(xiàn)問題后,應(yīng)該在程序在外的地方找問題,然后解決。
六、異常轉(zhuǎn)型和異常鏈 異常轉(zhuǎn)型在上面已經(jīng)提到過了,實(shí)際上就是捕獲到異常后,將異常以新的類型的異常再拋出,這樣做一般為了異常的信息更直觀!比如: public void run() throws MyException{ ... try{ ... }catch(IOException e){ ... throw new MyException(); }finally{ ... } }
異常鏈,在JDK1.4以后版本中,Throwable類支持異常鏈機(jī)制。Throwable 包含了其線程創(chuàng)建時線程執(zhí)行堆棧的快照。它還包含了給出有關(guān)錯誤更多信息的消息字符串。最后,它還可以包含 cause(原因):另一個導(dǎo)致此 throwable 拋出的 throwable。它也稱為異常鏈 設(shè)施,因?yàn)?cause 自身也會有 cause,依此類推,就形成了異常鏈,每個異常都是由另一個異常引起的。 通俗的說,異常鏈就是把原始的異常包裝為新的異常類,并在新的異常類中封裝了原始異常類,這樣做的目的在于找到異常的根本原因。
通過Throwable的兩個構(gòu)造方法可以創(chuàng)建自定義的包含異常原因的異常類型: Throwable(String message, Throwable cause) 構(gòu)造一個帶指定詳細(xì)消息和 cause 的新 throwable。 Throwable(Throwable cause) 構(gòu)造一個帶指定 cause 和 (cause==null ? null :cause.toString())(它通常包含類和 cause 的詳細(xì)消息)的詳細(xì)消息的新 throwable。 getCause() 返回此 throwable 的 cause;如果 cause 不存在或未知,則返回 null。 initCause(Throwable cause) 將此 throwable 的 cause 初始化為指定值。 在Throwable的子類Exception中,也有類似的指定異常原因的構(gòu)造方法: Exception(String message, Throwable cause) 構(gòu)造帶指定詳細(xì)消息和原因的新異常。 Exception(Throwable cause) 根據(jù)指定的原因和 (cause==null ? null : cause.toString()) 的詳細(xì)消息構(gòu)造新異常(它通常包含 cause 的類和詳細(xì)消息)。 因此,可以通過擴(kuò)展Exception類來構(gòu)造帶有異常原因的新的異常類。
七、Java異常處理的原則和技巧
1、避免過大的try塊,不要把不會出現(xiàn)異常的代碼放到try塊里面,盡量保持一個try塊對應(yīng)一個或多個異常。 2、細(xì)化異常的類型,不要不管什么類型的異常都寫成Excetpion。 3、catch塊盡量保持一個塊捕獲一類異常,不要忽略捕獲的異常,捕獲到后要么處理,要么轉(zhuǎn)譯,要么重新拋出新類型的異常。 4、不要把自己能處理的異常拋給別人。 5、不要用try...catch參與控制程序流程,異常控制的根本目的是處理程序的非正常情況。
一般這種情況是應(yīng)用后臺服務(wù)器轉(zhuǎn)賬時出現(xiàn)了錯誤導(dǎo)致拋出異常,一般這種情況下轉(zhuǎn)賬是不會成功的。
java檢查服務(wù)器用戶名密碼錯誤:如果用戶名和密碼不正確,請重新配置用戶名和密碼。 說明: 建議配置密碼時采用字母和數(shù)字的組合,不要包含特殊字符。 第一步,新建一個類class,然后命名為登錄的login方法
第二步,采用HttpServletRequest獲取前端傳來的用戶名和密碼,然后判斷是否為空,存在空則提示
第三步,根據(jù)用戶登錄的賬號從數(shù)據(jù)庫中查詢數(shù)據(jù),查詢不到則表示用戶不存在,此時報出提示第四步,根據(jù)前端傳來的用戶名和密碼進(jìn)行加密對比,如果不一致,則需要賬號或密碼錯誤,如圖采用封裝的JsonResult方法返回錯誤信息
第五步,如果上面的都通過,表示可以登錄,此時需要記錄session和登錄的權(quán)限。