struts的一些異常和錯誤[摘]

已經有很長時間沒有直接使用Struts自己的框架做開發了,在網上突然看到這個異常錯誤的筆記.於是就摘抄下來了.

方便以後查錯誤啦! 

本篇文章包含了在用Struts開發web應用時經常碰到的一些異常和錯誤,根據異常或錯誤信息本身,經常可以找到潛在的錯誤發生原因。

下面列出了一些Struts的常見錯誤和異常,並給出了一些可能發生此類錯誤或異常的原因。有的後面有相關連接,你可以通過它找到更多的信息。

Cannot retrieve mapping for action 
 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處理,如果出現上述異常,請查看struts-config.xml中的定義部分,有時可能是打錯了字符或者是某些不符合規則,可以使用struts console工具來檢查。 

org.apache.jasper.JasperException: Cannot retrieve definition for form bean null 
 
可能原因       
        
 這個異常是因爲Struts根據struts-config.xml中的mapping沒有找到action期望的form bean。大部分的情況可能是因爲在form-bean中設置的name屬性和action中設置的name屬性不匹配所致。換句話說,action和form都應該各自有一個name屬性,並且要精確匹配,包括大小寫。這個錯誤當沒有name屬性和action關聯時也會發生,如果沒有在action中指定name屬性,那麼就沒有name屬性和action相關聯。當然當action製作某些控制時,譬如根據參數值跳轉到相應的jsp頁面,而不是處理表單數據,這是就不用name屬性,這也是action的使用方法之一。 
 

 No action instance for path /xxxx could be created 
 
可能原因 
 特別提示:因爲有很多中情況會導致這個錯誤的發生,所以推薦大家調高你的web服務器的日誌/調試級別,這樣可以從更多的信息中看到潛在的、在試圖創建action類時發生的錯誤,這個action類你已經在struts-config.xml中設置了關聯(即添加了<action>標籤)。 
 
在struts-config.xml中通過action標籤的class屬性指定的action類不能被找到有很多種原因,例如: 

定位編譯後的.class文件失敗。Failure to place compiled .class file for the action in the classpath (在web開發中,class的的位置在r WEB-INF/classes,所以你的action class必須要在這個目錄下。例如你的action類位於WEB-INF/classes/action/Login.class,那麼在struts-config.xml中設置action的屬性type時就是action.Login). 
拼寫錯誤,這個也時有發生,並且不易找到,特別注意第一個字母的大小寫和包的名稱。 
 
在struts-config.xml中指定的action類沒有繼承自Stuts的Action類,或者你自定義的Action類沒有繼承自Struts提供的Action類。
 
javax.servlet.jsp.JspException: No getter method for property username of bean org.apache.struts.taglib.html.BEAN 
 
可能原因 
 沒有位form bean中的某個變量定義getter 方法 
 
這個錯誤主要發生在表單提交的FormBean中,用struts標記<html:text property=”username”>時,在FormBean中必須有一個getUsername()方法。注意字母“U”。 
 
java.lang.NoClassDefFoundError: org/apache/struts/action/ActionForm 
 
可能原因 
 這個錯誤主要發生在在classpath中找不到相應的Java .class文件。如果這個錯誤發生在web應用程序的運行時,主要是因爲指定的class文件不在web server的classpath中(/WEB-INF/classes 和 /WEB-INF/lib)。 

在上面的錯誤中,原因是找不到ActionForm類。 
 
Exception 
 javax.servlet.jsp.JspException: Cannot find ActionMappings or ActionFormBeans collection 
 
可能原因 
 不是標識Struts actionServlet的<servlet>標記就是映射.do擴展名的<sevlet-mapping>標記或者兩者都沒有在web.xml中聲明。 
 
在struts-config.xml中的打字或者拼寫錯誤也可導致這個異常的發生。例如缺少一個標記的關閉符號/>。最好使用struts console工具檢查一下。 
 
另外,load-on-startup必須在web.xml中聲明,這要麼是一個空標記,要麼指定一個數值,這個數值用來表servlet運行的優先級,數值越大優先級越低。 
 
還有一個和使用load-on-startup有關的是使用Struts預編譯JSP文件時也可能導致這個異常。
 
java.lang.NullPointerException at org.apache.struts.util.RequestUtils.forwardURL(RequestUtils.java:1223) 
 
可能原因 
 在struts-config.xml中的forward元素缺少path屬性。例如應該是如下形式:
<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標記外使用form的子元素。這常常發生在你在</html:form>後面使用Struts的html標記。

另外要注意可能你不經意使用的無主體的標記,如<html:form … />,這樣web 服務器解析時就當作一個無主體的標記,隨後使用的所有<html>標記都被認爲是在這個標記之外的,如又使用了<html:text property=”id”>

還有就是在使用taglib引入HTML標記庫時,你使用的prefix的值不是html。 
 
javax.servlet.jsp.JspException: Missing message for key xx.xx.xx 
 
Probable Causes 
 這個key的值對沒有在資源文件ApplicationResources.properties中定義。如果你使用eclipse時經常碰到這樣的情況,當項目重新編譯時,eclipse會自動將classes目錄下的資源文件刪除。 
 
資源文件ApplicationResources.properties 不在classpath中 應將資源文件放到 WEB-INF/classes 目錄下,當然要在struts-config.xml中定義) 
 
Cannot find message resources under key org.apache.struts.action.MESSAGE 
 
可能原因 
 很顯然,這個錯誤是發生在使用資源文件時,而Struts沒有找到資源文件。 
 
Implicitly trying to use message resources that are not available (such as using empty html:options tag instead of specifying the 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標記和標準的HTML標記不正確。 
 
使用的編碼樣式在本頁中不支持。 
 
"Document contained no data" in Netscape 
No data rendered (completely empty) page in Microsoft Internet Explorer 

 
可能原因 
 使用一個Action的派生類而沒有實現perform()方法或execute()方法。在Struts1.0中實現的是perform()方法,在Struts1.1中實現的是execute()方法,但Struts1.1向後兼容perform()方法。

但你使用Struts1.1創建一個Action的派生類,並且實現了execute()方法,而你在Struts1.0中運行的話,就會得到"Document contained no data" error message in Netscape or a completely empty (no HTML whatsoever) page rendered in Microsoft Internet Explorer.”的錯誤信息。 

 

該文章出自:http://www.xyhot.com/article.asp?id=273

作者:web交互設計

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章