2016-09-30 2 views
-1

NetBeansを使用してJavaServerFacesフレームワークを使用してWebアプリケーションを作成しています。 私のfaces-config xmlファイルには、ホームページに戻るためのナビゲーションリンクが含まれています。 ホームページには、スライドショーとドロップダウンコンボボックスが含まれています。選択すると、別のページに移動します。このページは私をホームページに戻すリンクです。 [email protected]期待できない>>コンポーネント:別のページホーム・ページに戻るには、リンクをクリックして、使用コンボボックスでエラーが発生しますし、私は恐ろしいJSFアプリケーションで壊れたページを修正する方法

java.lang.IllegalStateExceptionを取得しますタイプ。期待される:>>> javax.faces.component.UIForm。おそらくあなたはタグを紛失しているでしょうか?

エラーです。 また、私のすべてのページはf:viewタグでラップされています。 誰かがこれに対する修正を提案できますか? ありがとうございました。 マイホームJSPページ:これは、選択は、ホームページ上でコンボボックスから作られたときに現れるページのリンクを示し <navigation-rule> <navigation-case> <from-outcome>welcome</from-outcome> <to-view-id>/quote.jsp</to-view-id> </navigation-case> </navigation-rule>

 <title>Quotes</title> 
    </head> 
    <body> 
     <h1>Quote Home Page</h1> 

      <h:form> 
      <h:commandLink action="#{QuoteMB.createSetup}" value="Add New Quote"/> 
      </h:form> 
      <h:form> 
       <h:commandLink action="#{Login.logout}" value="Log Out" /> 
      </h:form> 
     </div> 
     <FORM ACTION="quoteview.jsp" METHOD="POST" > 
      <div style="text-align:center"> 
       <h3>Please select the quote you want to display:</h3> 
       <BR> 


       <% 
        int count = 0; 
        int i = 0; 
        int reversecount = 0; 
        int originalcount = 0; 
        Connection connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/babylon", "root", "sequence"); 

        Statement statement = connection.createStatement(); 
        //import java.util.HashMap; 
        ResultSet resultset = statement.executeQuery("SELECT quotetext FROM quote"); 
        java.util.HashMap <Integer,String> nametoValueMap = new java.util.HashMap <Integer,String>(); 
        if (!resultset.next()) { 
         out.println("Sorry, no records found. "); 
        } else { 
         int j=0; 
         resultset.previous(); 
         while(resultset.next()){ 

         j++; 
          String qt=resultset.getString(1); 
         int len=0; 
         len=qt.indexOf("\n"); 
         if(len==-1)len=30; 
         if(len>30)len=30; 
         System.out.println("search length= "+len); 
          qt=qt.substring(0,len); 
         qt=qt.replace("'", "''"); 
         System.out.println("final qt= "+qt); 
          nametoValueMap.put(j,qt); 
         System.out.println("Putting j "+j+" with "+qt); 
         } 
         count = j; 
         originalcount = count; 

         System.out.println("originalcount= "+originalcount); 
         out.print("<select name=\"id\">"); 

         while (count != 0) { 
          String text=nametoValueMap.get(reversecount); 
          System.out.println("Text = "+text+" reversecount= "+reversecount); 
          reversecount = originalcount - (count - 1); 
          //out.print("<option><column>" + reversecount + "</column></option>"); // where column1 is the column in the database table 
          out.print("<option><column>" + nametoValueMap.get(reversecount) + "</column></option>"); 
          count--; 
         } 
         out.print("</select>"); 
        } 

         resultset.close(); 
         statement.close(); 
         connection.close(); 

       %> 
       <INPUT TYPE="SUBMIT" value="Go" class="input"> 
      </div> 
     </FORM> 
     <br/> 
     <div style="text-align:center"> 
      <a href="javascript:gotoshow()"><img src="Shakespeare2.jpg" name="slide" id="borderimg1" ></a> 
     </div> 
     <br/> 
</html> 

これは、ナビゲーション・ルールです `引用ビュー

  <h:commandLink action="#{QuoteMB.listSetup}" value="Show Quotes"/> 
      <br> 
      <h:commandLink value="Home" action="welcome" immediate="true" /> 

     </h:form> 

`

+0

[mcve] –

+0

を入力してくださいコードを確認してください...これは明白でなければなりません...良いインデントで開始し、すぐに見つかるでしょう。 – Kukeltje

+0

Kukeltje - すみませんが、私はちょうどあなたに何が分かりか分かりません。説明できますか? – Reggie

答えて

0

私のJSPファイルは、Webフォルダと同様にページフォルダの下にある必要があるようです。 これは私にとっては奇妙なことですが、ファイルを両方のフォルダにコピーすると問題は解決されました。 これで誰かの時間をとって申し訳ありません。 ありがとうございました。

関連する問題