6.

Struts JSP タグ完全リファレンス(Struts 1/2 + Spring MVC への移行)

編集
この記事の要点
  • Struts 1 の JSP タグは (form 系) / (値出力) / (条件分岐) の 3 系統に分かれる
  • Struts 2 では 1 つに統一され、OGNL でアクションのプロパティに直接アクセス
  • JSTL + EL でも同じことができるため、新規開発は Struts タグを避けて JSTL を使うのが王道
  • Spring MVC への移行は など Spring 専用タグへ 1 対 1 で置き換え可能
  • TLD (Tag Library Descriptor) が欠落していると Unable to find taglib uri エラーになる

Struts JSP タグの概要

Struts はカスタムタグライブラリを提供し、JSP 側で <% %> スクリプトレットを書かずに HTML フォームや繰り返し処理を表現できます。Struts 1 と Struts 2 でタグ体系が大きく異なるため、それぞれ把握する必要があります。

Struts 1 のタグ体系

接頭辞TLD URI用途
htmlhttp://struts.apache.org/tags-htmlHTML フォーム要素
beanhttp://struts.apache.org/tags-beanBean / メッセージ表示
logichttp://struts.apache.org/tags-logic条件分岐・繰り返し
nestedhttp://struts.apache.org/tags-nestedネストプロパティ
tileshttp://struts.apache.org/tags-tilesTiles レイアウト

Struts 1 タグ使用例

<%@ taglib uri="http://struts.apache.org/tags-html"  prefix="html"  %>
<%@ taglib uri="http://struts.apache.org/tags-bean"  prefix="bean"  %>
<%@ taglib uri="http://struts.apache.org/tags-logic" prefix="logic" %>


    ユーザー ID: 
    パスワード: 
    


<%-- メッセージ表示 --%>

    
<%-- 繰り返し --%> <%-- 条件分岐 --%> 管理者メニュー

Struts 2 のタグ体系

Struts 2 では 接頭辞に統一され、OGNL で Action のプロパティに直接アクセスできます。

<%@ taglib prefix="s" uri="/struts-tags" %>

<%-- フォーム --%>

    
    
    
    


<%-- 条件 --%>

    


    ようこそ 


<%-- 繰り返し --%>

    : 


<%-- URL 生成 --%>

ログアウト

<%-- 国際化 --%>

Struts 1 タグ ⇔ Struts 2 タグ対応表

用途Struts 1Struts 2JSTL/Spring MVC
フォーム (Spring)
テキスト入力
パスワード
セレクト
サブミット
値出力${var} /
繰り返し
条件 (=)
エラー表示

TLD (Tag Library Descriptor) とは

カスタムタグの定義ファイルです。JAR 内の META-INF/*.tld に同梱され、JSP コンテナがタグ名とハンドラクラスを対応付けるのに使います:



    1.3
    html
    http://struts.apache.org/tags-html

    
        text
        org.apache.struts.taglib.html.TextTag
        JSP
        
            property
            true
        
    

よくあるエラー

1. Unable to find taglib uri

org.apache.jasper.JasperException: /WEB-INF/views/login.jsp(2,1)
PWC6188: The absolute uri: http://struts.apache.org/tags-html cannot be
resolved in either web.xml or the jar files deployed with this application

原因と対処:

  • struts-taglib.jar (Struts 1) または struts2-core.jar (Struts 2) が WEB-INF/lib/ にない → 追加
  • uri の綴り間違い → 公式の URI に合わせる
  • JAR バージョン違い (1.3 系で 1.2 系の uri 等) → JAR と uri を一致させる

2. property を見つけられない (No getter method for property)

javax.servlet.jsp.JspException: No getter method for property userId
of bean org.apache.struts.taglib.html.BEAN

ActionForm に getUserId() / setUserId(String) がないため。Bean 規約に従って getter/setter を追加。

Spring MVC への移行例

Struts 1 のフォームを Spring MVC へ書き換えるパターン:

<%-- Struts 1 --%>

    
    
    
    


<%-- Spring MVC --%>
<%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %>

    
    
    
    

JSTL のみで Struts タグを置き換える

Struts タグを使わず JSTL + 標準 HTML だけで書く方が、移植性が高くお勧めです:

<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

FAQ

Q: Struts 1 と Struts 2 のタグを同じ JSP に混在できる?
A: 技術的には可能ですが避けるべき。Tag handler の競合や OGNL/EL の混在で問題が起きやすい。移行するならページ単位で書き換える。

Q: TLD ファイルは web.xml に書く必要がある?
A: Servlet 2.4+ では JAR の META-INF に同梱した TLD が自動検出されるため不要。古いコードに残っているだけ。

Q: カスタムタグを自作したい
A: JSP 2.0 以降は .tag ファイル (WEB-INF/tags/ に配置) で簡単に作成可能。Java クラス + TLD を書く必要はない。

関連項目

  • JSTL — JSP 標準タグライブラリ
  • EL (Expression Language) — JSP/Servlet 標準の式言語
  • Spring MVC form タグ — 移行先の標準
  • Thymeleaf — タグライブラリ不要の HTML テンプレート
編集
Post Share
子ページ
  1. logic:messagesPresent
同階層のページ
  1. 導入方法
  2. struts-config.xmlの説明
  3. ActionForm
  4. Action
  5. エラー一覧
  6. JSP タグ
  7. カスタムタグ(tablib)