stsuts常見錯誤和解決方法
阿新 • • 發佈:2019-02-13
剛剛接觸struts,感覺好多的東西都不太明白,感覺最重要的就是看不懂錯誤以及解決方法。這兩天在網上找了些資料,copy了過來,為以後方便以後的繼續學習打個基礎。
PS:以下所說的struts-config.xml和ApplicationResources.properties等檔名是預設時使用的,如果你使用了多模組,或指定了不同的資原始檔名稱,這些名字要做相應的修改。
錯誤一:“No bean found under attribute key XXX”
在struts-config.xml裡定義了一個ActionForm,但type屬性指定的類不存在,type屬性的值應該是Form類的全名。或者是,在Action的定義中,name或attribute屬性指定的ActionForm不存在。 我在實際開發中也因為將<logic:equal>標籤中的Scope屬性設定為“request”而出現這種錯誤,將scope的設定值去掉就解決問題了。
錯誤二:“Cannot find bean XXX in any scope”
在Action裡一般會request.setAttribute()一些物件,然後在轉向的jsp檔案裡(用tag或request.getAttribute()方法)得到這些物件並顯示出來。這個異常是說jsp要得到一個物件,但前面的Action裡並沒有將物件設定到request(也可以是session、servletContext)裡。
可能是名字錯了,請檢查jsp裡的tag的一般是name屬性,或getAttribute()方法的引數值;或者是Action邏輯有問題沒有執行setAttribute()方法就先轉向了。
還有另外一個可能,純粹是jsp檔案的問題,例如<logic:iterate>會指定一個id值,然後在迴圈裡<bean: write>使用這個值作為name的值,如果這兩個值不同,也會出現此異常。(都是一個道理,request裡沒有對應的物件。)
另外要注意可能你不經意使用的無主體的標記,如<html:form … />,這樣web 伺服器解析時就當作一個無主體的標記,隨後使用的所有<html>標記都被認為是在這個標記之外的,如又使用了<html:text property=”id”>。還有就是在使用taglib引入HTML標記庫時,你使用的prefix的值不是html。
錯誤三:“Missing message for key "XXX"”
缺少所需的資源,檢查ApplicationResources.properties檔案裡是否有jsp檔案裡需要的資源,例如:
<bean:message key="msg.name.prompt"/>
這行程式碼會找msg.name.prompt資源,如果AppliationResources.properties裡沒有這個資源就會出現本異常。在 使用多模組時,要注意在模組的struts-config-xxx.xml裡指定要使用的資原始檔名稱,否則當然什麼資源也找不到,這也是一個很容易犯的 錯誤。
錯誤四:“No getter method for property XXX of bean teacher”
這 條異常資訊說得很明白,jsp裡要取一個bean的屬性出來,但這個bean並沒有這個屬性。你應該檢查jsp中某個標籤的property屬性的值。例 如下面程式碼中的cade應該改為code才對:<bean:write name="teacher" property="cade" filter="true"/>。還有,要注意這裡的property的值首字母必須是小寫的哦!
錯誤五:“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檔案時也可能導致這個異常。 錯誤六:“Cannot retrieve mapping for action XXX”
action沒有再struts-config.xml 中定義,或沒有找到匹配的action,例如在JSP檔案中使用 <html:form action="Login.do".將表單提交給Login.do處理,如果出現上述異常,請檢視struts-config.xml中的定義部分,有時可能是打錯了字元或者是某些不符合規則,可以使用struts console工具來檢查。 錯誤七:HTTP Status 404 - /xxx/xxx.jsp
Forward的path屬性指向的jsp頁面不存在,請檢查路徑和模組,對於同一模組中的Action轉向,path中不應包含模組名;模組間轉向,記住使用contextRelative="true"。 錯誤八:沒有任何異常資訊,顯示空白頁面
可能是Action裡使用的forward與struts-config.xml裡定義的forward名稱不匹配。
錯誤九:“The element type "XXX" must be terminated by the matching end-tag "XXX".”
這個是struts-config.xml檔案的格式錯誤,仔細檢查它是否是良構的xml檔案,關於xml檔案的格式這裡就不贅述了。 錯誤十:“Servlet.init() for servlet action threw exception”
一般出現這種異常在後面會顯示一個關於ActionServlet的異常堆疊資訊,其中指出了異常具體出現在程式碼的哪一行。我曾經遇到的一次提示如下: java.lang.NullPointerException
at org.apache.struts.action.ActionServlet.parseModuleConfigFile(ActionServlet.java:1003)
at org.apache.struts.action.ActionServlet.initModuleConfig(ActionServlet.java:955)
為解決問題,先下載struts的原始碼包,然後在ActionServlet.java的第1003行插入斷點,並對各變數進行監視。很丟人,我竟然把struts-config.xml檔案弄丟了,因此出現了上面的異常,應該是和CVS同步時不小心刪除的。 錯誤十一:“Resources not defined for Validator”
這個是利用Validator外掛做驗證時可能出現的異常,這時你要檢查validation.xml檔案,看裡面使用的資源是否確實有定義,form的名稱是否正確,等等。 錯誤十二:“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 ”
錯誤十四:“java.lang.NoClassDefFoundError: org/apache/struts/action/ActionForm ”
這個錯 誤主要發生在在classpath中找不到相應的Java .class檔案。如果這個錯誤發生在web應用程式的執行時,主要是因為指定的class檔案不在web server的classpath中(/WEB-INF/classes 和 /WEB-INF/lib)。 在上面的錯誤中,原因是找不到ActionForm類。
錯誤十五:“NullPointerException at ... RequestUtils.forwardURL”
在struts-config.xml中的forward元素缺少path屬性。例如應該是如下形式:
<forward name="userhome" path="/user/userhome.jsp"/> 錯誤十六:“Strange Output Characters ” 混和使用Struts的html:form標記和標準的HTML標記不正確。 使用的編碼樣式在本頁中不支援。 錯誤十七:"Document contained no data" or no data rendered on page” 使用一個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.”的錯誤資訊。
在struts-config.xml裡定義了一個ActionForm,但type屬性指定的類不存在,type屬性的值應該是Form類的全名。或者是,在Action的定義中,name或attribute屬性指定的ActionForm不存在。 我在實際開發中也因為將<logic:equal>標籤中的Scope屬性設定為“request”而出現這種錯誤,將scope的設定值去掉就解決問題了。
錯誤二:“Cannot find bean XXX in any scope”
在Action裡一般會request.setAttribute()一些物件,然後在轉向的jsp檔案裡(用tag或request.getAttribute()方法)得到這些物件並顯示出來。這個異常是說jsp要得到一個物件,但前面的Action裡並沒有將物件設定到request(也可以是session、servletContext)裡。
可能是名字錯了,請檢查jsp裡的tag的一般是name屬性,或getAttribute()方法的引數值;或者是Action邏輯有問題沒有執行setAttribute()方法就先轉向了。
還有另外一個可能,純粹是jsp檔案的問題,例如<logic:iterate>會指定一個id值,然後在迴圈裡<bean: write>使用這個值作為name的值,如果這兩個值不同,也會出現此異常。(都是一個道理,request裡沒有對應的物件。)
錯誤三:“Missing message for key "XXX"”
缺少所需的資源,檢查ApplicationResources.properties檔案裡是否有jsp檔案裡需要的資源,例如:
<bean:message key="msg.name.prompt"/>
這 條異常資訊說得很明白,jsp裡要取一個bean的屬性出來,但這個bean並沒有這個屬性。你應該檢查jsp中某個標籤的property屬性的值。例 如下面程式碼中的cade應該改為code才對:<bean:write name="teacher" property="cade" filter="true"/>。還有,要注意這裡的property的值首字母必須是小寫的哦!
錯誤五:“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檔案時也可能導致這個異常。 錯誤六:“Cannot retrieve mapping for action XXX”
action沒有再struts-config.xml 中定義,或沒有找到匹配的action,例如在JSP檔案中使用 <html:form action="Login.do".將表單提交給Login.do處理,如果出現上述異常,請檢視struts-config.xml中的定義部分,有時可能是打錯了字元或者是某些不符合規則,可以使用struts console工具來檢查。 錯誤七:HTTP Status 404 - /xxx/xxx.jsp
Forward的path屬性指向的jsp頁面不存在,請檢查路徑和模組,對於同一模組中的Action轉向,path中不應包含模組名;模組間轉向,記住使用contextRelative="true"。 錯誤八:沒有任何異常資訊,顯示空白頁面
可能是Action裡使用的forward與struts-config.xml裡定義的forward名稱不匹配。
錯誤九:“The element type "XXX" must be terminated by the matching end-tag "XXX".”
這個是struts-config.xml檔案的格式錯誤,仔細檢查它是否是良構的xml檔案,關於xml檔案的格式這裡就不贅述了。 錯誤十:“Servlet.init() for servlet action threw exception”
一般出現這種異常在後面會顯示一個關於ActionServlet的異常堆疊資訊,其中指出了異常具體出現在程式碼的哪一行。我曾經遇到的一次提示如下: java.lang.NullPointerException
at org.apache.struts.action.ActionServlet.parseModuleConfigFile(ActionServlet.java:1003)
at org.apache.struts.action.ActionServlet.initModuleConfig(ActionServlet.java:955)
為解決問題,先下載struts的原始碼包,然後在ActionServlet.java的第1003行插入斷點,並對各變數進行監視。很丟人,我竟然把struts-config.xml檔案弄丟了,因此出現了上面的異常,應該是和CVS同步時不小心刪除的。 錯誤十一:“Resources not defined for Validator”
這個是利用Validator外掛做驗證時可能出現的異常,這時你要檢查validation.xml檔案,看裡面使用的資源是否確實有定義,form的名稱是否正確,等等。 錯誤十二:“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類不能被找到有很多種原因,例如:
|
在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.
|
<forward name="userhome" path="/user/userhome.jsp"/> 錯誤十六:“Strange Output Characters ” 混和使用Struts的html:form標記和標準的HTML標記不正確。 使用的編碼樣式在本頁中不支援。 錯誤十七:"Document contained no data" or no data rendered on page” 使用一個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.”的錯誤資訊。