本篇文章包含了在用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
工具來檢查。
|
?
Cannot retrieve definition for form bean null
|
異常
|
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
|
異常
|
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類。
你的action類必須繼承自Struts提供的Action類。
|
你的classpath的問題。例如web server沒有發現你的資源文件,資源文件必須在
WEB-INF/classes/目錄下
。
|
Problem in
struts-config.xml
file with action mapping.
|
Problem with
data-sources.xml
file.
|
相關鏈接
|
|
?
No getter method for property XXXX of bean org.apache.struts.taglib.html.BEAN
|
異常
|
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
”。
|
Related Links
|
|
?
java.lang.NoClassDefFoundError: org/apache/struts/action/ActionForm
|
錯誤
|
java.lang.NoClassDefFoundError: org/apache/struts/action/ActionForm
|
可能原因
|
這個錯誤主要發生在在
classpath
中找不到相應的
Java .class
文件。如果這個錯誤發生在
web
應用程序的運行時,主要是因為指定的
class
文件不在
web server
的
classpath
中(
/WEB-INF/classes
和
/WEB-INF/lib)。
在上面的錯誤中,原因是找不到ActionForm類。
|
This error is sometimes seen when one or more
ActionForm.class
instances are actually in the classpath. This most often occurs when
ActionForm.class
is made available correctly by placing
struts.jar
in the
/WEB-INF/lib
directory. When this library has been correctly placed and it is verified that
ActionForm.class
actually is present in the
struts.jar
file, the problem is either that more than one copy of
ActionForm.class
is in the classpath or (more likely) that duplicate versions of class files other than
ActionForm
are in the same classpath, causing confusion. This is especially true if a class that extends
ActionForm
is made available twice, such as in an
.ear
file that encompasses a
.war
file as well as in the
.war
file's own classpath (
/WEB-INF/classes
). This problem can be resolved by guaranteeing that there are no redundant classes, especially those related to Struts (directly from Struts or extensions of Struts), in the web application's view.
|
相關連接
|
|
?
Exception creating bean of class org.apache.struts.action.ActionForm: {1}
|
異常
|
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 might occur implicitly if you specify that a form-bean is this Struts
ActionForm
class rather than specifying a child of this class for the form-bean.
|
Not associating an
ActionForm
-descended class with an
action
can also lead to this error.
|
Related Links
|
?
|
?
Cannot find ActionMappings or ActionFormBeans collection
|
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
文件時也可能導致這個異常。
|
相關鏈接
|
|
?
NullPointerException at ... RequestUtils.forwardURL
|
異常
|
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"/>
|
?
Cannot find bean org.apache.struts.taglib.html.BEAN in any scope
|
Exception
|
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。?
|
相關連接
|
|
?
Missing message for key xx.xx.xx
|
Exception
|
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
|
異常
|
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
|
Related Links
|
|
?
No input attribute for mapping path /loginAction
|
錯誤
|
No input attribute for mapping path /xxxxAction
|
可能原因
e
|
No
input
attribute in action mapping in
struts-config.xml
file for the action with the name specified in the error message. An
input
attribute is not required if form validation is not performed (either because the
validate
attribute is set to
false
or because the validation method in the relevant form class is not implemented. The
input
attribute specifies the page leading to this action because that page is used to display error messages from the form validation.
|
Related Links
|
?
|
?
Strange Output Characters
|
錯誤
|
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" or no data rendered on page
|
錯誤
|
"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.”
的錯誤信息。
|
?
posted on 2006-07-24 12:26
matthew 閱讀(260)
評論(0) 編輯 收藏 所屬分類:
JavaEE