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

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

新規登録して質問してみよう
ただいま回答率
85.48%
JSF

JSF (JavaServer Faces)とは、JavaベースのWebアプリケーションフレームワークの一つです。

Java EE

Java EE(Java Enterprise Edition)はJavaベースのテクノロジーとその相互運用の仕様をまとめたものです。サーバとクライアントのアーキテクチャを規定し、特定アプリケーションのクラス用に定義されたテクノロジー設定のプロファイルを使用します。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Q&A

解決済

2回答

3092閲覧

データテーブルを検索→検索結果から詳細ページへ移動 がうまくいかない

anonyrabbit

総合スコア78

JSF

JSF (JavaServer Faces)とは、JavaベースのWebアプリケーションフレームワークの一つです。

Java EE

Java EE(Java Enterprise Edition)はJavaベースのテクノロジーとその相互運用の仕様をまとめたものです。サーバとクライアントのアーキテクチャを規定し、特定アプリケーションのクラス用に定義されたテクノロジー設定のプロファイルを使用します。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

0グッド

0クリップ

投稿2017/01/11 21:31

primefacesのデータテーブルを利用して、データベースの内容を表示しています。このデータテーブルには検索機能をつけたのですが、この検索機能を使って検索すると正しい詳細ページへのリンクができなくなります。検索してから一番上のコラムのリンクをクリックして詳細ページに飛んでも、検索機能を実行する前の一番上のコラムのリンクをクリックするときと同じページの飛んでしまうのです。

Bb.java

Java

1 2@ManagedBean(name = "bb", eager = true) 3@SessionScoped 4public class Bb extends SuperBb implements Serializable { 5 6 protected List<OldCoupleInformation> coupleList; 7 private String search; 8 9 @PostConstruct 10 public void filt() { 11 System.out.println("filt()"); 12 coupleList = db.getAll(); 13 if (search != null) { 14 coupleList = db.filterTable(search); 15 System.out.println("coupleList = db.filterTable(search);\n"); 16 17 } 18 19 } 20 21 public String detail(Integer id) { 22 System.out.println("detail()"); 23 oci = db.find(id); 24 return "detail-content.xhtml"; 25 } 26//getter, setter 27}

Db.java

Java

1@Stateful 2 3public class Db<T> implements Serializable { 4 5 @PersistenceContext 6 private EntityManager em; 7 protected Class<T> entityClass; 8 9public Information find(Integer id) throws IllegalArgumentException { 10 return em.find(Information.class, id); 11 } 12public List<Information> filterTable(String search) { 13 if(search == null) return null; 14 Query query = em.createQuery("SELECT c FROM Information c WHERE c.addressOne LIKE :search", Information.class); 15 query.setParameter("search", "%" + search + "%"); 16 return query.getResultList(); 17 }

find.xhtml

xhtml

1 <h:form> 2 <p:inputText id="search" value="#{bb.search}" style="width:150px"/> <br/> 3 <br/> 4 <h:commandLink type="submit" value="検索" action="#{bb.filt()}" class="Button"/> 5 6 7 <p:dataTable id="examplej" class="table couple-table" 8 var="info" value="#{bb.coupleList}" widgetVar="couple" rows="10" paginatorTemplate="{RowsPerPageDropdown} {FirstPageLink} {PreviousPageLink} {CurrentPageReport} {NextPageLink} {LastPageLink}" 9 rowsPerPageTemplate="5,10,15" paginator="true" emptyMessage="住所を入力して検索してください"> 10 <f:facet name="header"> 11 <!--<p:outputPanel>--> 12 <h:outputText value="地域で検索" /> 13 14 <p:column class="column-couple"> 15 <h:outputText value="#{info.firstName}" />さん 16 <h:outputText value="#{info.id}" /> 17 18 19 </p:column> 20 21 <p:column class="column-couple"> 22 <h:outputText value="#{info.addressOne}" /> 23 </p:column> 24 25 26 <p:column class="column-couple"> 27 <h:commandLink action="#{bb.detail(info.id)}"><!-- 試したもの:bb.oci, bb.coupleList, filt()でOldcoupleInformationをflashでdetail()に渡す--> 28 詳細へ 29 </h:commandLink> 30 </p:column> 31 32 33 </p:dataTable> 34 </h:form> 35

”Q”で検索した時のログになります。

filt()で検索を実行

Info: filt()

Info: null
Info: filt()
Info: coupleList = db.filterTable(search);
Info: Q
検索結果の一番上のカラムのリンクをクリック(detail()を実行)
Info: filt()
Info: null
Info: detail()
Warning: JSF1064: Unable to find or serve resource, resources/css/detail.css.
Info: filt()
Warning: JSF1064: Unable to find or serve resource, resources/css/detail.css.
Info: null

ログを見る限り、detail()メソッドを実行したとき@PostConstructで指定したメソッド(filt())がdetail()メソッドより先に実行され、リストが初期化されてしまっているようなのですが@PostConstructを使わずにリストを初期化したところdetail()がinvokeできなくなった覚えがあります。
長くなりましたが、なんとかこの機能を実装したいと思っているので、お分かりになる方ご回答のほうよろしくお願いいたします。

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

BlueMoon

2017/01/12 00:31

SessionScopeにおけるインスタンスの生成契機と、PostConstructを指定したメソッドの実行契機についてはお調べ済みでしょうか。。
anonyrabbit

2017/01/12 06:33

それらについては調べましたが、この問題を解決するまでには至りませんでした。どこを直せば良いでしょうか。
anonyrabbit

2017/01/12 06:35

余談ですが、契機とタイミングは違う言葉です。
guest

回答2

0

ベストアンサー

以下の2点を教えていただけますでしょうか?

  • ご利用されているアプリケーションサーバとそのバージョン情報
  • import文の部分

手元のGlassFish4.1.1では、上記コードをベースにDB部分はダミーのリスト値として試しましたが、ちゃんと検索で絞られた後でも正常にリンクのオブジェクトが取得できました。ログでも、リンクを押したときにdetail()だけが呼び出され、filt()は呼ばれません。ただ、Beanの継承元となっているSuperBbクラスがわからないので、そこは入れていないコードで試してます。

実際に試す前に気になっていた所としては

  1. 番号リスト <f:facet>タグが閉じていない
  2. 番号リスト @SessionScopedがJSFかCDIのかで間違っていないか
  3. 番号リスト @ManagedBeanは使わず@Namedを使う(Java EE6,7なら)
  4. 番号リスト h:commandLinkのtype="submit"は不要

辺りでした。手元では1点目の<f:facet>タグは閉じるのを追加しましたが、3,4は上記コードのまま(2はimport javax.faces.bean.SessionScoped)でも動きました。可能でしたら、3,4変えて試して一度試してみていただけると嬉しいです。

投稿2017/01/14 04:17

kikutaro

総合スコア37

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

anonyrabbit

2017/01/14 04:48

import文を、import javax.faces.bean.SessionScoped;に変えたら即動きました!enterpriseの方にしていたのが悪かったのですね。両者の違いが全く分からず適当に使っていたのがよくなかったです。本当にありがとうございました。これからもブログの更新楽しみにしています。
kikutaro

2017/01/14 05:07

良かったです!!JSF管理Bean(@ManagedBean)とCDI管理Bean(@Named)で世界が違っているのですが、@RequestScopedや@SessionScopedはどちらの管理Beanでも被ってしまっているのでホント間違えやすいでお気を付けください~。
guest

0

ログを拝見しますと、

検索結果の一番上のカラムのリンクをクリック(detail()を実行)

の後に

Info: filt() Info: null

が表示されているので、詳細画面が表示される直前でcoupleList = db.getAll()によってリストが全件抽出に戻っているのではないでしょうか。そうなる理由までは判りません。

投稿2017/01/12 06:47

BlueMoon

総合スコア1339

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問