1. 程式人生 > >stsuts常見錯誤和解決方法

stsuts常見錯誤和解決方法

   剛剛接觸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 ”
    特別提示:因為有很多中情況會導致這個錯誤的發生,所以推薦大家調高你的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.
錯誤十四:“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.”的錯誤資訊。