1 つのアクション クラスと 1 つのインターセプターを持つ単純な struts2 Web アプリケーションがあります。getTitle()
アクション クラスには、セッションから文字列を取得するgetter メソッドがあります。インターセプターはデフォルト スタックの一番下にあるため、呼び出しの最後と最初に実行されます。これは、アクション呼び出しの BEFORE および AFTER 呼び出しのセッションにあるタイトルを変更できるように構築されています。結果の JSP ページには、このタイトルが表示されます。
次のロジックが適用されると思いました。
- 呼び出し実行前のインターセプター ロジック
- アクション クラス ロジックの実行
- 呼び出し実行後のインターセプター ロジック
- struts は結果を認識し、結果の
.jsp
ページを取得します- struts は、アクション クラスの
<:s>
タグ.jsp
と呼び出しを埋めます。getTitle()
しかし、これはうまくいきませんでした。結果の JSP には、ステップ 3 が実行される前のタイトルが常に表示されていました。Javaコードに簡単なログを追加したところ、私の疑いが確認されました。実行順序は次のとおりです。
- ログ: 呼び出しが実行される前のインターセプター ロジック
- ログ: アクション クラス ロジックの実行
- log:
getTitle()
アクション クラスからのメソッドが実行されます- ログ: 呼び出し実行後のインターセプター ロジック
どういうわけか、ステップ 6 がステップ 3 になりました。これはなぜですか。また、タイトルを変更するアクション呼び出しの後にインターセプターにロジックを追加するにはどうすればよいですか?