質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

87.35%

org.apache.jasper.JasperExceptionエラーの解決について

解決済

回答 3

投稿

  • 評価
  • クリップ 1
  • VIEW 14K+

score 11

Strutus2、Javaで外部のDBシステムと連携したシステムを作っています。
JSP側の変数宣言名などに問題はないと思うのですが、時々以下のようなエラーがでて後の処理へ遷移できません。
何がおかしいのでしょうか?

tag 'select', field 'list', name 'txtProtcol': The requested list key 'listProtcol' could not be resolved as a collection/array/map/enumeration/iterator type. Example: people or people.{name} - [unknown location]
org.apache.jasper.JasperException: tag 'select', field 'list', name 'txtProtcol': The requested list key 'listProtcol' could not be resolved as a collection/array/map/enumeration/iterator type. Example: people or people.{name} - [unknown location]
at org.apache.jasper.servlet.JspServletWrapper.handleJspException(JspServletWrapper.java:591)
at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:476)
at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:396)
at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:340)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:729)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:292)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:207)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:240)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:207)
at org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:720)
at org.apache.catalina.core.ApplicationDispatcher.processRequest(ApplicationDispatcher.java:466)
at org.apache.catalina.core.ApplicationDispatcher.doForward(ApplicationDispatcher.java:391)
at org.apache.catalina.core.ApplicationDispatcher.forward(ApplicationDispatcher.java:318)
at org.apache.struts2.dispatcher.ServletDispatcherResult.doExecute(ServletDispatcherResult.java:164)
at org.apache.struts2.dispatcher.StrutsResultSupport.execute(StrutsResultSupport.java:191)
at com.opensymphony.xwork2.DefaultActionInvocation.executeResult(DefaultActionInvocation.java:372)
at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:276)
at org.apache.struts2.interceptor.DeprecationInterceptor.intercept(DeprecationInterceptor.java:41)
at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:245)
at org.apache.struts2.interceptor.debugging.DebuggingInterceptor.intercept(DebuggingInterceptor.java:256)
at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:245)
at com.opensymphony.xwork2.interceptor.DefaultWorkflowInterceptor.doIntercept(DefaultWorkflowInterceptor.java:168)
at com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:98)
at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:245)
at com.opensymphony.xwork2.validator.ValidationInterceptor.doIntercept(ValidationInterceptor.java:265)
-中略-
at org.apache.struts2.interceptor.validation.AnnotationValidationInterceptor.doIntercept
at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:729)
at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:438)
... 88 more

該当のソースコード

エラー対象の項目は以下のように記述しています。
JSP
<td><div>プロトコル種別<span class="pba04d06_yellow">(必須)</span></div></td>
<td class="pba04d06_itemInput">
<s:select name="txtProtcol" list="listProtcol" value="dateList.Protcol"/>
</td>
Java
private String txtProtcol; //プロトコル種別
private String txtProtcol; //プロトコル種別
ゲッター、セッターも作成しています。

試したこと

ゲッターセッターの作成漏れを疑い、確認したが作成されていた。
変数の宣言名と異なっているのかと思い、つづりを確認、Java側宣言の変数名をコピペしてみた。

補足情報(言語/FW/ツール等のバージョンなど)

同じ画面に、ほかにもセレクトボックスはありますが、
一番最初にあるこのセレクトボックスだけがこのような状態になっています。
セレクトボックスの作成は、共通の部品で実装しているためこれだけがおかしいとは考えにくいのです。

以上、お知恵をお借りできれば助かります...。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 3

checkベストアンサー

+1

<s:select list="listProtcol" />


のlistProtocolが、中身が全く定義されていないか、java.utilパッケージのcollection,array,map,enumeration,iteratorの型になっていないため例外がスローしています。

また、Actionクラスで型が正しく定義されていたとしても、listに定義した変数がnullの場合 は同じ例外になります。
※NullPointerExceptionをスローしてくれればわかりやすいんですけれどね。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/06/29 00:56

    ありがとうございます。
    リストに指定している変数自体はクラス変数としてメソッド外にて宣言しており、
    初期表示から画面に戻り、ボタン押下で画面の入力項目の値の読み込みとバリデーションチェックをしています。
    値を読み込んで用意しておいたBeanにセットするときには値があるので、それ以降のどこかでlistProtocolから値が取得出来ずにnullになっているイメージでしょうか. .?

    キャンセル

  • 2016/06/29 09:46

    Actionクラスまわりの実装がないと正確なことは言えませんが、listProtocolがnullになっているか、または上記のcollection,array,,などの型になっていない場合もありますね。

    また「値を読み込んで用意しておいたBeanにセットするときには値がある」のはActionクラスで、Validationにかかった/かかってない場合でも異なるのではないかと。
    Struts2標準の設定では、Validationエラーにかかると、Actionクラスの実装部分は実行されません。(WorkflowInterceptorにより、自動的にResult="input"のレスポンスを実行します)

    キャンセル

+1

エラーメッセージに以下のように書いてあります。

The requested list key 'listProtcol' could not be resolved as a collection/array/map/enumeration/iterator type.


おそらく、キーlistProtcolに対応するフィールドが null になっているのではないでしょうか?
掲題のエラーが発生した際、このフィールドがどのような値になっているかを確認してみてください。

また、以下を追記すると、より具体的な回答が得られる可能性が高くなると思います。

  • 掲題のエラーが発生する具体的な条件
  • キーlistProtcolに対応するフィールドに値を代入している部分のJavaコード

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/06/29 00:48

    ありがとうございます。
    手元にソースコードが無いため、エラー発生時の操作となりますが、

    画面の初期表示で該当のものも含めてリストにプロパティファイルから作成した各リストの値を代入してリスト作成。

    ボタン押下処理(テキストエリアの入力バリデーションチェックなど)

    ログを見る限り、対象のリストとは関係ない部分の処理でエラー発生する。
    となります。

    リスト自体は、プロパティファイルに記載された値を記入されている書式に則りString型二つのマップに代入したものを取得して作成しています。

    キャンセル

  • 2016/06/29 00:54

    情報の追記、ありがとうございます。

    しかし、これだけでは状況が分かりません。
    やはり、ソースコードを提示していただく必要があります。

    また、
    > ログを見る限り、対象のリストとは関係ない部分の処理でエラー発生する。
    のエラーログと、該当箇所のソースコードも追記いただくと、より詳しい状況が分かると思います。

    キャンセル

0

デバッグしてみたところ、listProtocolがnullになっていたので、暫定対応としてボタン押下時の処理の頭で、メソッド化していたリスト作成の処理を呼び出させるようにしました。
私がその現場から離れる事が決まっている為、綺麗なソースを残せないのは歯がゆいですが他作業に支障をきたすので取り急ぎそうしました。

回答してくださった方々、ありがとうございます。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 87.35%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る