最近の更新

2013年7月25日木曜日

h:formの出力内容

【目的】
JSF2.2でh:formを実行します。
formのみを出力します。
※特に意味はありませんが、JSF2.2でformがどのようなHTMLを出力するのかを確認します。



【手順1】
1.「JSF2.2プロジェクトの作成方法」の作成手順で、「JSF22Sample101-h-form」といプロジェクトを作成。
※プロジェクトの設定は以下の通り。
※他の項目は任意。
ウィザード名 項目名 項目に設定する値
動的 Web プロジェクト プロジェクト名 JSF22Sample101-h-form
ターゲット・ランタイム GlassFish 4.0
動的 web モジュールバージョン 3.1
プロジェクト・ファセット JavaServer Faces チェック有り バージョン(2.2)
Java ビルド・パス上のソース・フォルダー src
デフォルト出力フォルダー build\classes
Web モジュール コンテキスト・ルート JSF22Sample101-h-form
コンテンツ・ディレクトリー WebContent
web.xml デプロイメント記述子の作成 チェックあり
JSF 機能 JSF 実装ライブラリー GlassFish System Library
Configure JSF servlet in deployment descriptor チェック有り
JSF 構成ファイル /WEB-INF/faces-config.xml
JSF サーブレット名 Faces Servlet
JSF Servlet Class Name javax.faces.webapp.FacesServlet
URL マッピング・パターン /faces/*



2.「WebContent/WEB-INF/web.xml」を以下の様に入力。
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns="http://xmlns.jcp.org/xml/ns/javaee"
    xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
    id="WebApp_ID" version="3.1">

    <display-name>JSF22Sample101-h-form</display-name>

    <welcome-file-list>
        <welcome-file>faces/index.xhtml</welcome-file>
    </welcome-file-list>

    <servlet>
        <servlet-name>Faces Servlet</servlet-name>
        <servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
        <load-on-startup>1</load-on-startup>
    </servlet>

    <servlet-mapping>
        <servlet-name>Faces Servlet</servlet-name>
        <url-pattern>/faces/*</url-pattern>
    </servlet-mapping>
</web-app>

4.「Ctrl+Shift+F」を押し、ソースコードをフォーマッティング、「Ctrl+S」でファイルを保存。
5.「任意のファイルの作成方法」の手順で、「WebContent/」ディレクトリに「index.xhtml」というファイルを作成。
6.「index.xhtml」を以下の様に入力。
<html xmlns="http://www.w3.org/1999/xhtml"
    xmlns:h="http://xmlns.jcp.org/jsf/html">
<h:head>
</h:head>
<h:body>
    <h:form>
        formのみ。
    </h:form>
</h:body>
</html>

7.「Ctrl+Shift+F」を押し、ソースコードをフォーマッティング、「Ctrl+S」でファイルを保存。
8.「動的Webアプリケーションをサーバーに配置する方法」の手順で、作成したプロジェクトをサーバーに配置します。
9.「サーバーをデバッグモードで起動する方法」の手順で、サーバーを起動します。
10.ブラウザで以下のURLにアクセスします。
http://localhost:8080/JSF22Sample101-h-form/faces/index.xhtml

11.以下の様に表示されれば成功です。













































12.ソースコードは以下の様に出力されていました。(見やすく整形しています)
<html xmlns="http://www.w3.org/1999/xhtml">
    <head id="j_idt2">
    </head>
    <body>
        <form id="j_idt4" name="j_idt4" method="post" action="/JSF22Sample101-h-form/faces/index.xhtml;jsessionid=4d320b02deee3bea332ab37d7c78" enctype="application/x-www-form-urlencoded">
            <input type="hidden" name="j_idt4" value="j_idt4" />
            formのみ。
            <input type="hidden" name="javax.faces.ViewState" id="j_id1:javax.faces.ViewState:0" value="-6567124597442535192:1682591068202106085" autocomplete="off" />
        </form>
    </body>
</html>



【結論】
formのタグのみで、上記のformタグと2つのhiddenタグが出力されるようです。



以上です。

0 件のコメント:

コメントを投稿

注: コメントを投稿できるのは、このブログのメンバーだけです。

関連記事