001/* 002 * Copyright (c) 2009 The openGion Project. 003 * 004 * Licensed under the Apache License, Version 2.0 (the "License"); 005 * you may not use this file except in compliance with the License. 006 * You may obtain a copy of the License at 007 * 008 * http://www.apache.org/licenses/LICENSE-2.0 009 * 010 * Unless required by applicable law or agreed to in writing, software 011 * distributed under the License is distributed on an "AS IS" BASIS, 012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, 013 * either express or implied. See the License for the specific language 014 * governing permissions and limitations under the License. 015 */ 016package org.opengion.hayabusa.taglib; 017 018import static org.opengion.fukurou.util.StringUtil.nval; 019 020import java.io.IOException; 021import java.io.ObjectInputStream; 022import java.io.ObjectOutputStream; 023import java.net.InetAddress; 024import java.net.UnknownHostException; 025import java.util.Arrays; 026import java.util.Collections; 027import java.util.Enumeration; 028import java.util.HashMap; 029import java.util.Locale; 030import java.util.Map; 031 032import javax.servlet.ServletContext; 033import javax.servlet.ServletRequest; 034import javax.servlet.http.Cookie; 035import javax.servlet.http.HttpServletRequest; 036import javax.servlet.http.HttpServletResponse; 037import javax.servlet.http.HttpSession; 038import javax.servlet.jsp.JspWriter; 039import javax.servlet.jsp.tagext.BodyContent; 040import javax.servlet.jsp.tagext.BodyTagSupport; 041import javax.servlet.jsp.tagext.TryCatchFinally; 042 043import org.opengion.fukurou.db.DBFunctionName; 044import org.opengion.fukurou.util.ApplicationInfo; 045import org.opengion.fukurou.util.Attributes; 046import org.opengion.fukurou.util.StringUtil; 047import org.opengion.fukurou.util.HybsDateUtil; 048import org.opengion.hayabusa.common.HybsSystem; 049import org.opengion.hayabusa.common.HybsSystemException; 050import org.opengion.hayabusa.db.DBColumn; 051import org.opengion.hayabusa.db.DBEventColumn; 052import org.opengion.hayabusa.db.DBLastSql; 053import org.opengion.hayabusa.db.DBTableModel; 054import org.opengion.hayabusa.resource.GUIInfo; 055import org.opengion.hayabusa.resource.LabelInterface; 056import org.opengion.hayabusa.resource.ResourceFactory; 057import org.opengion.hayabusa.resource.ResourceManager; 058import org.opengion.hayabusa.resource.UserInfo; 059 060/** 061 * TagSupport から継承されたサブクラスです。 062 * 063 * 汎用属性 のsetterメソッドと、Attributes オブジェクトを持っています。 064 * それ以外に、{@XXXX} 変数の対応と、lang属性のメソッドも用意しています。 065 * 066 * ロケールは、ユーザー情報の lang 属性をデフォルトで使用し、 067 * セットされていない場合は、リクエスト情報のロケールから取得します。 068 * 069 * 各属性は、{@XXXX} 変数が使用できます。 070 * これは、ServletRequest から、XXXX をキーに値を取り出し,この変数に 071 * 割り当てます。つまり、このXXXXをキーにリクエストすれば、 072 * この変数に値をセットすることができます。 073 * 074 * http://localhost/query.jsp?KEY1=VLA1&KEY2=VAL2 075 * 076 * のようなリクエストで、{@KEY1} とすれば、 VAL1 がセットされます。 077 * 078 * このタグは、ラベル部分と入力フィールド部分がテーブルタグの<td> 079 * により左右に分割されます。HTML 表示時は、前後に<tr>タグで囲って, 080 * 整形できます。 081 * 082 * @og.group 画面制御 083 * 084 * @version 4.0 085 * @author Kazuhiko Hasegawa 086 * @since JDK5.0, 087 */ 088class CommonTagSupport extends BodyTagSupport implements TryCatchFinally { 089 private static final long serialVersionUID = 574220140320L ; // 5.7.4.2 (2014/03/20) 090 091 private transient Attributes attri = new Attributes(); 092 private transient ResourceManager resource = null; 093 private transient UserInfo userInfo = null; 094 private transient GUIInfo guiInfo = null; 095 private transient HttpSession session = null; 096 private transient ServletRequest request = null; 097 private transient Map<String,String[]> requestCache = null; // 3.5.6.2 (2004/07/05) 098 private transient LabelInterface msglbl = null; // 4.0.0 (2005/01/31) 099 private String language = null; 100 private boolean debugFlag = false; // 3.5.5.3 (2004/04/09) 101 private boolean isReqNull = false; 102 private boolean quotCheck = false; // 4.0.0 (2005/08/31) 103 private String scope = "session"; // "request","page","session","applicaton" 104 // 3.1.7.0 (2003/05/02) value値の使用可否を指定する、useValue 属性を追加。 105 private Long startTransaction = null; // 3.6.0.8 (2004/11/19) 106 private int[] rowNo = null; // 4.0.0 (2005/01/31) 107 private boolean xssCheck = HybsSystem.sysBool( "USE_XSS_CHECK" ); // 5.0.0.2 (2009/09/15) 108 private boolean useTrans = false; // 5.1.6.0 (2010/05/01) 109 110 private String caseKey = null; // 5.2.2.0 (2010/11/01) 新規追加 111 private String caseVal = null; // 5.2.2.0 (2010/11/01) 新規追加 112 private boolean caseNN = true; // 5.6.7.0 (2013/07/27) 新規追加 113 private boolean caseNull = true; // 5.6.8.0 (2013/09/06) 新規追加 114 115 private boolean isSanitized = false; // 5.7.4.2 (2014/03/20) 新規追加 116 117 /** 118 * Taglibの開始タグが見つかったときに処理する doStartTag() を オーバーライドします。 119 * 120 * @return 後続処理の指示(SKIP_BODY) 121 */ 122 @Override 123 public int doStartTag() { 124 return SKIP_BODY ; // Body を評価しない 125 // return( EVAL_BODY_INCLUDE ); // Body インクルード( extends TagSupport 時) 126 // return EVAL_BODY_BUFFERED ; // Body を評価する。( extends BodyTagSupport 時) 127 } 128 129 /** 130 * Taglibのタグ本体を処理する doAfterBody() を オーバーライドします。 131 * 132 * @return 後続処理の指示(SKIP_BODY) 133 */ 134 @Override 135 public int doAfterBody() { 136 return SKIP_BODY ; // Body を評価しない 137 // return( EVAL_BODY_AGAIN ); // ボディーを再評価( extends TagSupport 時) 138 // return EVAL_BODY_BUFFERED ; // ボディーを再評価( extends BodyTagSupport 時) 139 } 140 141 /** 142 * Taglibの終了タグが見つかったときに処理する doEndTag() を オーバーライドします。 143 * 144 * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応。release2() を doEndTag()で呼ぶ。 145 * 146 * @return 後続処理の指示 147 */ 148 @Override 149 public int doEndTag() { 150 debugPrint(); // 4.0.0 (2005/02/28) 151 152 return EVAL_PAGE ; // ページの残りを評価する。( extends TagSupport 時) 153 // return(SKIP_PAGE); // ページの残りの処理を行わない。 154 } 155 156 /** 157 * タグの処理中(セッターメソッドを除く)の例外を全て受け取ります。 158 * 159 * タグの中のボディ部の評価中、または Tag.doStartTag(), Tag.doEndTag(), 160 * IterationTag.doAfterBody(), BodyTag.doInitBody() のいずれもの 161 * メソッドの中で、Throwableが投げられたときに呼び出されます。 162 * 163 * このメソッドはセッターメソッドの中でThrowableが起きた場合は呼び出されません。 164 * 165 * @og.rev 3.5.0.0 (2003/09/17) TryCatchFinally インターフェースを適用。 166 * 167 * @param th このタグを通過してきたThrowableな例外 168 */ 169 @Override 170 public void doCatch(final Throwable th) throws Throwable { 171 throw th; 172 } 173 174 /** 175 * タグの処理毎の、doEndTag()の後で呼び出されます。 176 * 177 * Tag,IterationTag,BodyTagを実装した全てのクラスの doEndTag()の 178 * 後で呼び出されます。 このメソッドはタグのボディ部や Tag.doStartTag(), 179 * Tag.doEndTag(), IterationTag.doAfterBody() ,BodyTag.doInitBody()の 180 * すべてのメソッドで例外が発生した後でも呼び出されます。 181 * 182 * このメソッドはセッターメソッドの中でThrowableが起きた場合は呼び出されません。 183 * 184 * このメソッドからは例外を投げるべきではありません。 185 * このメソッドは呼び出し毎のデータの整合性をとることとリソース管理の 186 * 動作をさせることを意図しています。 187 * 188 * @og.rev 3.5.0.0 (2003/09/17) TryCatchFinally インターフェースを適用。 189 * 190 */ 191 @Override 192 public void doFinally() { 193 release2(); 194 } 195 196 /** 197 * タグリブオブジェクトをリリースします。 198 * キャッシュされて再利用されるので、フィールドの初期設定を行います。 199 * 200 * @og.rev 2.0.0.4 (2002/09/27) カスタムタグの release() メソッドを、追加 201 * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応。release2() を doEndTag()で呼ぶ。 202 * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応。HybsRequestWrapper 廃止。直接 Mapでキャッシュする。 203 * @og.rev 3.1.3.0 (2003/04/10) エンコード情報の取得を廃止する。 204 * @og.rev 3.1.7.0 (2003/05/02) value値の使用可否を指定する、useValue 属性を追加。 205 * @og.rev 3.5.5.3 (2004/04/09) debugFlag を、String ではなく、boolean 型に変更 206 * @og.rev 3.6.0.8 (2004/11/19) startTransaction 属性を追加 207 * @og.rev 3.8.0.2 (2005/07/11) rightNow 属性を追加 208 * @og.rev 5.0.0.2 (2009/09/15) XSS対応 209 * @og.rev 5.1.6.0 (2010/05/01) DBLastSQL周りの実装見直し 210 * @og.rev 5.1.8.0 (2010/07/01) isNullSet 属性 廃止にともなう、useValue 属性廃止 211 * @og.rev 5.2.2.0 (2010/11/01) caseKey、caseVal 属性の追加 212 * @og.rev 5.3.2.0 (2011/02/01) paramNames 属性の追加 213 * @og.rev 5.6.7.0 (2013/07/27) caseNN 属性の追加 214 * @og.rev 5.6.8.0 (2013/09/06) caseNull 属性の追加 215 * @og.rev 5.7.4.1 (2014/03/14) rightNow 属性 廃止 216 * @og.rev 5.7.4.1 (2014/03/14) isSanitized 属性の追加 217 */ 218 protected void release2() { 219 language = null; 220 attri = new Attributes(); 221 resource = null; 222 debugFlag = false; // 3.5.5.3 (2004/04/09) 223 userInfo = null; 224 guiInfo = null; 225 session = null; 226 request = null; 227 isReqNull = false; 228 scope = "session"; // "request","page","session","applicaton" 229 requestCache = null; 230 startTransaction = null; // 3.6.0.8 (2004/11/19) 231 rowNo = null; // 4.0.0 (2005/01/31) 232 msglbl = null; // 4.0.0 (2005/01/31) 233 quotCheck = false; // 4.0.0 (2005/08/31) 234 xssCheck = HybsSystem.sysBool( "USE_XSS_CHECK" ); // 5.0.0.2 (2009/09/15) 235 useTrans = false; // 5.1.6.0 (2010/05/01) 236 caseKey = null; // 5.2.2.0 (2010/11/01) 237 caseVal = null; // 5.2.2.0 (2010/11/01) 238 caseNN = true; // 5.6.7.0 (2013/07/27) 新規追加 239 caseNull = true; // 5.6.8.0 (2013/09/06) 新規追加 240 isSanitized = false; // 5.7.4.2 (2014/03/20) 新規追加。一応入れておくが都度、初期化しています。 241 } 242 243 /** 244 * 【TAG】タグ内部で使用する言語コード[ja/en/zh/…]を指定します。 245 * 246 * @og.tag 247 * この言語コードに基づいて、表示のラベルをリソースから作成します。 248 * 249 * @param lang 言語コード[ja/en/zh/…] 250 * @see #getLanguage() 251 */ 252 public void setLanguage( final String lang ) { 253 language = getRequestParameter( lang ); 254 } 255 256 /** 257 * 言語コード[ja/en/zh/…]を取得します。 258 * 259 * 言語コードが、セットされている場合は,設定値を優先します。 260 * 設定されていない場合は、ログインユーザーの持つLANG属性を、それが null の場合は、 261 * 実行環境のリクエストの言語を返します。 262 * 263 * @og.rev 2.1.1.0 (2002/11/08) セッション情報から取得できない場合に、クライアントの 264 * リクエスト情報のロケールから取得する処理を追加 265 * @og.rev 2.2.0.0 (2002/12/17) セッション情報から取得するのではなく、ユーザー情報より 266 * 取得するように変更。そこにない場合は、リクエスト情報の 267 * ロケールから取得する 268 * 269 * @return 言語コード[ja/en/zh/…] 270 * @see #setLanguage( String ) 271 */ 272 protected String getLanguage() { 273 if( language == null ) { 274 language = getUser().getLang(); 275 if( language == null ) { 276 language = getRequest().getLocale().getLanguage(); 277 } 278 } 279 280 if( language != null ) { 281 return language ; 282 } 283 284 String errMsg = "言語コードがセットされていません。" ; 285 throw new HybsSystemException( errMsg ); 286 } 287 288 /** 289 * 【TAG】ラベルリソースのラベルIDを指定します。 290 * 291 * @og.tag 292 * ラベルを変更するときに、lbl属性を使います。 293 * 294 * ラベルID は、所定の language に基づく ResourceManager の 295 * getLabelData( id ) を呼び出し、その結果のLabelInterfaceを使用します。 296 * getMsglbl() で取り出せます。 297 * ラベルとメッセージは統一されました。 298 * 299 * @og.rev 4.0.0.0 (2005/01/31) label 変数は、生データを保管するように変更。 300 * 301 * @param lbl ラベルID 302 * @see #getMsglbl() 303 */ 304 public void setLbl( final String lbl ) { 305 msglbl = (LabelInterface)getResource().getLabelData( getRequestParameter( lbl ) ) ; // 4.0.0 (2005/01/31) 306 } 307 308 /** 309 * 【TAG】デバッグ情報を出力するかどうか[true/false]を指定します(初期値:false)。 310 * 311 * @og.tag 312 * デバッグ情報を [true:出力する/false:しない]を指定します。 313 * 出力形式自体は、個々のタグによって異なります。 314 * 315 * @og.rev 3.5.5.3 (2004/04/09) debugFlag を、String ではなく、boolean 型に変更 316 * 317 * @param flag [true:出力する/それ以外:しない] 318 */ 319 public void setDebug( final String flag ) { 320 debugFlag = nval( getRequestParameter( flag ),debugFlag ); 321 } 322 323 /** 324 * 【TAG】キャッシュする場合のスコープ[request/page/session/applicaton]を指定します(初期値:session)。 325 * 326 * @og.tag 327 * "request","page","session","applicaton" が指定できます。 328 * JSPのスコープは、「変数の有効範囲」を表すもので、フレームワーク上では、 329 * 主にテーブルモデルを管理するスコープを指します。 330 * 331 * <table border="1" frame="box" rules="all" > 332 * <caption>テーブルモデルを管理するスコープ変数の有効範囲</caption> 333 * <tr><th>スコープ </th><th>変数の有効範囲</th><th>説明</th></tr> 334 * <tr><td>page </td><td>JSPページ内</td> 335 * <td>そのJSPページ内のみで有効です。フレームワーク的には、JSPページにまたがる処理が多いため、ほとんど使う機会はありません。</td></tr> 336 * <tr><td>request </td><td>HTTPリクエスト</td> 337 * <td>リクエストの一連の処理期間中に有効な変数で、メモリに多くの情報を残したくない場合に利用します。検索系やポップアップのJSP画面等に利用します。</td></tr> 338 * <tr><td>session </td><td>HTTPセッション</td> 339 * <td>初期設定されているスコープで、ログインユーザー単位にログアウトまで保持されます。 340 * 内部的には、同じキーワード(tableId)で管理しているため、検索都度、破棄されます。 341 * (ガーベジコレクションにて破棄されるのを待ちます。)</td></tr> 342 * <tr><td>application</td><td>Webアプリケーション</td> 343 * <td>ユーザー間で共有する場合のスコープになります。JSP画面の開発では、まず使うことはありません。</td></tr> 344 * </table> 345 * 346 * @param scp スコープ[request/page/session/applicaton] 347 * @see #getScope() 348 */ 349 public void setScope( final String scp ) { 350 scope = nval( getRequestParameter( scp ),scope ); 351 } 352 353 /** 354 * キャッシュする場合のスコープ[request/page/session/applicaton]を返します。 355 * 356 * "request","page","session","applicaton" があります。 357 * 358 * @og.rev 3.5.5.8 (2004/05/20) 新規追加 359 * 360 * @return スコープ[request/page/session/applicaton] 361 * @see #setScope( String ) 362 */ 363 public String getScope() { 364 return scope ; 365 } 366 367 /** 368 * 【TAG】このタグ自体を利用するかどうかの条件キーを指定します(初期値:null)。 369 * 370 * @og.tag 371 * caseKey.matches( caseVal ) の値が、true の場合は、このタグは使用されます。 372 * false の場合は、このタグは使用されません。 373 * 374 * caseKey , caseVal ともに null の場合は、true です。どちらかが、非null の場合は、 375 * もう片方も 非null で、かつ、caseKey.matches( caseVal ) が成立する必要があります。 376 * この属性は、caseKey , caseVal , caseNN , caseNull とともに useTag() の判定で使用されます。 377 * 378 * @og.rev 5.2.2.0 (2010/11/01) 新規追加 379 * @og.rev 5.6.3.3 (2013/04/19) 条件変更のためのコメント修正 380 * 381 * @param ckey 条件キー(何も指定されない場合は、使用すると判断) 382 * @see #setCaseVal( String ) 383 * @see #useTag() 384 */ 385 public void setCaseKey( final String ckey ) { 386 caseKey = nval( getRequestParameter( ckey ),caseKey ); 387 } 388 389 /** 390 * 【TAG】このタグ自体を利用するかどうかの条件値を指定します(初期値:null)。 391 * 392 * @og.tag 393 * caseKey.matches( caseVal ) の値が、true の場合は、このタグは使用されます。 394 * false の場合は、このタグは使用されません。 395 * 396 * caseKey , caseVal ともに null の場合は、true です。どちらかが、非null の場合は、 397 * もう片方も 非null で、かつ、caseKey.matches( caseVal ) が成立する必要があります。 398 * この属性は、caseKey , caseVal , caseNN , caseNull とともに useTag() の判定で使用されます。 399 * 400 * @og.rev 5.2.2.0 (2010/11/01) 新規追加 401 * @og.rev 5.6.3.3 (2013/04/19) 条件変更のためのコメント修正 402 * 403 * @param cval 条件値(何も指定されない場合は、使用すると判断) 404 * @see #setCaseKey( String ) 405 * @see #useTag() 406 */ 407 public void setCaseVal( final String cval ) { 408 caseVal = nval( getRequestParameter( cval ),caseVal ); 409 } 410 411 /** 412 * 【TAG】このタグ自体を利用するかどうかの条件として、NotNullかどうか判定します(初期値:true)。 413 * 414 * @og.tag 415 * この値が、null/ゼロ文字列 でない場合(Not Null=NN)は、このタグは使用されます。 416 * null/ゼロ文字列 の場合は、このタグは使用されません。 417 * 何も指定しない場合は、使用されます。 418 * caseNull と逆の動きをします。 419 * {@XXXX} で、指定した場合は、値が設定されなければ、使用されません。 420 * 421 * この属性は、caseKey , caseVal , caseNN , caseNull とともに useTag() の判定で使用されます。 422 * 423 * @og.rev 5.6.7.0 (2013/07/27) 新規追加 424 * 425 * @param cnn NotNullかどうか判定する属性(何も指定されない場合は、使用すると判断) 426 * @see #setCaseVal( String ) 427 * @see #useTag() 428 */ 429 public void setCaseNN( final String cnn ) { 430 String tempNN = nval( getRequestParameter( cnn ),null ); 431 432 caseNN = tempNN != null && !tempNN.isEmpty() ; 433 } 434 435 /** 436 * 【TAG】このタグ自体を利用するかどうかの条件として、Nullかどうか判定します(初期値:true)。 437 * 438 * @og.tag 439 * この値が、null/ゼロ文字列 の場合は、このタグは使用されます。 440 * null/ゼロ文字列 でない場合は、このタグは使用されません。 441 * 何も指定しない場合は、使用されます。 442 * caseNN と逆の動きをします。 443 * {@XXXX} で、指定した場合は、値が設定されていなければ、使用されます。 444 * 445 * この属性は、caseKey , caseVal , caseNN , caseNull とともに useTag() の判定で使用されます。 446 * 447 * @og.rev 5.6.8.0 (2013/09/06) 新規追加 448 * 449 * @param cnul NotNullかどうか判定する属性(何も指定されない場合は、使用すると判断) 450 * @see #setCaseVal( String ) 451 * @see #useTag() 452 */ 453 public void setCaseNull( final String cnul ) { 454 String tempNull = nval( getRequestParameter( cnul ),null ); 455 456 caseNull = tempNull == null || tempNull.isEmpty() ; 457 } 458 459 /** 460 * このタグ自体を利用するかどうかの条件判定を行います。 461 * 462 * caseNN && caseNull && 463 * ( (caseKey == null && caseVal == null) || 464 * (caseKey != null && caseVal != null && caseKey.matches( caseVal ))) 465 * の結果を返します。 466 * 467 * これは、タグ本体に、条件式を登録できる機能です。必要なタグには、tld ファイルで、 468 * caseKey 、caseVal 、caseNN 、caseNull属性が使用できるように、設定します。 469 * 各タグを、equals タグで括る方法では、ソースの見通しが悪くなるため、 470 * ある程度タグ自身に判定機能を設けることで対応できるようにしました。 471 * ただ、本来、JSP 側にロジックを持ち込むのはよくないので、利用に関しては、 472 * 慎重にお願いします。 473 * 474 * @og.rev 5.2.2.0 (2010/11/01) 新規追加 475 * @og.rev 5.6.3.3 (2013/04/19) 条件変更(caseKey と caseVal が 両方とも null の場合のみ true) 476 * @og.rev 5.6.7.0 (2013/07/27) caseNN 属性追加。先のcaseKey、caseVal 条件と、AND 結合になります。 477 * @og.rev 5.6.8.0 (2013/09/06) caseNull 属性追加。先の条件と、AND 結合になります。 478 * 479 * @return このタグ自体を利用するかどうか(true:利用する/false:利用しない) 480 * @see #setCaseVal( String ) 481 * @see #setCaseKey( String ) 482 * @see #setCaseNN( String ) 483 */ 484 protected boolean useTag() { 485 return caseNN && caseNull && 486 ( (caseKey == null && caseVal == null) || 487 (caseKey != null && caseVal != null && caseKey.matches( caseVal ))) ; 488 } 489 490 /** 491 * (通常使いません)タグで処理される処理がメインとなるトランザクション処理かどうかを指定します(初期値:false)。 492 * 493 * この値は、ファイルダウンロード処理に影響します。この値がtrueに指定された時にcommitされたDBTableModelが 494 * ファイルダウンロードの対象の表になります。 495 * 496 * このパラメーターは、通常、各タグにより実装され、ユーザーが指定する必要はありません。 497 * 但し、1つのJSP内でDBTableModelが複数生成される場合に、前に処理したDBTableModelについてファイルダウンロードをさせたい 498 * 場合は、後ろでDBTableModelを生成するタグで、明示的にこの値をfalseに指定することで、ファイルダウンロード処理の対象から 499 * 除外することができます。 500 * 501 * @og.rev 5.1.6.0 (2010/05/01) 新規作成 502 * 503 * @param flag メイントランザクションかどうか 504 */ 505 protected void useMainTrans( final boolean flag ) { 506 useTrans = flag; 507 } 508 509 /** 510 * メッセージラベル(msglbl)を取得します。 511 * 512 * メッセージラベルは、lbl属性で登録された値を、 513 * それぞれのリソースに応じて各言語に変換した結果を格納しています。 514 * 515 * @og.rev 4.0.0.0 (2005/01/31) msglbl は、LabelInterface オブジェクトを利用 516 * 517 * @return メッセージラベル 518 * @see #setLbl( String ) 519 */ 520 protected String getMsglbl() { 521 String rtn = null; 522 523 if( msglbl != null ) { rtn = msglbl.getLabel(); } 524 525 return rtn ; 526 } 527 528 /** 529 * メッセージラベル(msglbl)のチップス表記を取得します。 530 * 531 * メッセージラベルは、lbl属性で登録された値を、 532 * それぞれのリソースに応じて各言語に変換した結果を格納しています。 533 * 別途、title属性を指定している場合は、置き換えます。 534 * 535 * @og.rev 4.0.0.0 (2005/01/31) msglbl は、LabelInterface オブジェクトを利用 536 * 537 * @return メッセージラベル 538 */ 539 protected String getLongLabel() { 540 String rtn = null; 541 542 if( msglbl != null ) { 543 rtn = msglbl.getLongLabel( get( "title" ) ); 544 } 545 546 return rtn ; 547 } 548 549 /** 550 * メッセージラベル(LabelInterface)を取得します。 551 * 552 * メッセージラベルは、lbl属性で登録された値を、 553 * それぞれのリソースに応じて各言語に変換した結果を格納しています。 554 * 555 * @return メッセージラベル 556 */ 557 protected LabelInterface getLabelInterface() { 558 return msglbl ; 559 } 560 561 /** 562 * ResourceManager を取得します。 563 * 564 * ページスコープ にセットされた ResourceManager があれば、それを、 565 * なければ、language 属性よりデフォルト ResourceManager を構築します。 566 * LOCAL_RES_KEY で管理される ResourceManager は、LocalResourceTag で 567 * 登録されたリソースです。これは、ローカルリソース情報として、使用されます。 568 * 569 * @return ResourceManagerオブジェクト 570 */ 571 protected ResourceManager getResource() { 572 if( resource == null ) { 573 resource = (ResourceManager)pageContext.getAttribute( HybsSystem.LOCAL_RES_KEY ); 574 if( resource == null ) { 575 resource = ResourceFactory.newInstance( getLanguage() ); 576 } 577 } 578 return resource; 579 } 580 581 /** 582 * デバッグ状態 を取得します。 583 * 584 * setDebug( String )で登録します。 585 * 初期値は、false です。 586 * 587 * @og.rev 3.5.5.3 (2004/04/09) getDebug() から、メソッド名変更 588 * 589 * @return true(デバッグ状態)/ false(通常) 590 */ 591 protected boolean isDebug() { 592 return debugFlag ; 593 } 594 595 /** 596 * ラベル文字列を返します。 597 * 598 * これは、{@LBL.XXXX %Y} 引数処理をおこなうための、サポートメソッドです。 599 * 引数は、"XXXX %Y" という状態で受け取ります。(LBL. ははずした形) 600 * ラベルには、通常のラベル(Label)以外に、Short,Tips,Description,RawShortLabel の情報を持っています。 601 * {@LBL.XXXX %Y} の Y に、先のLabel,Short,Tips,Description,RawShortLabel,CodeData の頭文字('L','S','T','D','R','C')を 602 * 指定することで、それぞれの状態を取得することが可能になります。 603 * Y を指定しない場合({@LBL.XXXX}) は、'L' が指定された場合と同じ効果があります。 604 * Y は、先頭文字1文字で判断していますので、{@LBL.XXXX %Short}と記述できます。 605 * Y 引数には、@で始まるリクエスト引数が指定できます。例えば、{@LBL.XXXX @ZZ} 606 * とすると、ZZ のリクエスト引数の値が Y に適用されます。 607 * ラベルキーそのものをパラメータ化することが出来ます。 608 * これは、{@LBL.@XXXX}という形式になります。引数は、先の説明と同じです。 609 * この場合は、XXXX をキーにリクエスト引数の値が、ラベルリソースのキーになります。 610 * 611 * @og.rev 4.0.0.0 (2007/10/17) メッセージリソース統合に伴い、{@LBL.XXXX Y}⇒{@LBL.XXXX %Y} 612 * @og.rev 5.4.0.1 (2011/11/01) ラベル形式('L','S','T','D') に、R(RawShortLabel) を追加 613 * @og.rev 5.5.7.2 (2012/10/09) ラベル形式('L','S','T','D','R') に、C(CodeData) を追加 614 * 615 * @param lbl ラベルのキー 616 * 617 * @return ラベル文字列 618 */ 619 protected String getLabel( final String lbl ) { 620 621 String key = lbl ; 622 String val = null; 623 624 int spc = lbl.indexOf( ' ' ); // " " があるかどうか 625 if( spc > 0 ) { 626 key = lbl.substring( 0,spc ); 627 if( key.charAt(0) == '@' ) { key = getRequestValue( key.substring( 1 ) ); } 628 629 // リクエスト引数が指定された場合 630 char ch = lbl.length() > spc+1 ? lbl.toUpperCase( Locale.JAPAN ).charAt( spc+1 ) : ' '; // Label,Short,Tips,Description 631 char ch2 = lbl.length() > spc+2 ? lbl.toUpperCase( Locale.JAPAN ).charAt( spc+2 ) : ' '; // Label,Short,Tips,Description 632 if( ch == '@' ) { 633 String tmp = getRequestValue( lbl.substring( spc+2 ) ); 634 if( tmp != null && tmp.length() > 0 ) { 635 ch = tmp.toUpperCase( Locale.JAPAN ).charAt( 0 ); 636 ch2 = tmp.length() > 1 ? tmp.toUpperCase( Locale.JAPAN ).charAt( 1 ) : ' '; 637 } 638 } 639 // 4.0.0.0 (2007/10/19) 640 if( ch == '%' ) { 641 switch( ch2 ) { 642 case 'L': val = getResource().getLabel( key ); break; 643 case 'S': val = getResource().getLabelData( key ).getShortLabel(); break; 644 case 'T': val = getResource().getLabelData( key ).getLongLabel(); break; 645 case 'D': val = getResource().getLabelData( key ).getDescription(); break; 646 case 'R': val = getResource().getLabelData( key ).getRawShortLabel(); break; // 5.4.0.1 (2011/11/01) 647 case 'C': val = getResource().getLabelData( key + "." + getRequestValue( key ) ).getShortLabel(); break; // 5.5.7.2 (2012/10/09) 648 default : break; 649 } 650 } 651 else if( ch != ' ' ) { 652 String[] msgVals = StringUtil.csv2Array( lbl.substring( spc+1 ),' ' ); 653 for( int i=0; i<msgVals.length; i++ ) { 654 // リクエスト文字パラメータ時の処理。その他は、ラベル文字は処理不要。 655 if( msgVals[i].startsWith( "@" ) ) { 656 msgVals[i] = getRequestValue( msgVals[i].substring( 1 ) ); 657 } 658 } 659 val = getResource().getLabel( key,msgVals ); 660 } 661 } 662 else { 663 if( key.charAt(0) == '@' ) { key = getRequestValue( key.substring( 1 ) ); } 664 } 665 666 if( val == null ) { val = getResource().getLabel( key ); } 667 return val; 668 } 669 670 /** 671 * DBColumn オブジェクトを返します。 672 * 673 * これは、キーを元に DBColumnオブジェクトをカラムリソースの 674 * 定義ファイルより取得して、リソースマネージャで管理します。 675 * 676 * @param key オブジェクトのキー 677 * 678 * @return DBColumnオブジェクト 679 */ 680 protected DBColumn getDBColumn( final String key ) { 681 return getResource().makeDBColumn( key ) ; 682 } 683 684 /** 685 * 内部の Attributes オブジェクトに、属性値をセットします。 686 * 687 * 同じキーの値が登録されていた場合は、置き換えられます。 688 * 689 * @param key キー 690 * @param value 属性値 691 * @see #add( String , String ) 692 */ 693 protected void set( final String key, final String value ) { 694 attri.set( key,value ); 695 } 696 697 /** 698 * 内部の Attributes オブジェクトに、属性値を追加します。 699 * 700 * ここでは、すでに同じキーが登録されている場合は、その値に、 701 * 標準セパレータ(スペース)を追加して、文字列結合します。 702 * たとえば、class 属性などは、値をスペースで追加する事で、 703 * CSS で処理することができます。 704 * 705 * @og.rev 4.0.0.0 (2007/05/18) 新規追加 706 * 707 * @param key キー 708 * @param value 属性値 709 * @see #add( String , String , String ) 710 * @see #set( String , String ) 711 */ 712 protected void add( final String key, final String value ) { 713 attri.add( key,value ); 714 } 715 716 /** 717 * 内部の Attributes オブジェクトに、属性値を追加します。 718 * 719 * ここでは、すでに同じキーが登録されている場合は、その値に、 720 * 引数のセパレータを追加して、文字列結合します。 721 * 722 * @og.rev 3.5.0.0 (2003/09/17) 新規追加 723 * @og.rev 3.5.5.9 (2004/06/07) セパレータ引数付きのメソッドに変更 724 * 725 * @param key キー 726 * @param value 属性値 727 * @param sepa セパレータ 728 * @see #add( String , String ) 729 */ 730 protected void add( final String key, final String value, final String sepa ) { 731 attri.add( key,value,sepa ); 732 } 733 734 /** 735 * 内部の Attributes オブジェクトから、属性値を取得します。 736 * 737 * @param key キー 738 * 739 * @return 属性値 740 * @see #set( String , String ) 741 */ 742 protected String get( final String key ) { 743 return attri.get( key ); 744 } 745 746 /** 747 * 属性オブジェクトの取得。 748 * 749 * Attributes オブジェクトを取得します。 750 * 751 * @return Attributesオブジェクト 752 */ 753 protected Attributes getAttributes() { 754 return attri; 755 } 756 757 /** 758 * {@XXXX} 形式の文字列から XXXX をキーとして ServletRequest から getParameter で値を取り出します。 759 * 760 * 他の文字列に混在した {@XXXX} 文字を変換可能です。 761 * ただし、処理の簡素化のため、上記形式以外は変換いたしません。 762 * エラー例)× { @XXXX }、{@ XXXX }、{@XXXX@yyyy}、{@XXXX{@yyyy}} 763 * また、"{@" を通常の記述で使うことは無いと考え、エスケープも用意して 764 * いません。よって、"{@" のパターンが見つかって,"}" で閉じられていない 765 * 場合は,エラーとして、HybsSystemException を throw します。 766 * 767 * @og.rev 3.8.0.4 (2005/08/08) {} の処理方法見直し。連続処理、単体処理を可能にします。 768 * 769 * @param key リクエストのキー 770 * 771 * @return リクエストの値 772 */ 773 protected String getRequestParameter( final String key ) { 774 isReqNull = false; 775 776 if( key == null ) { isReqNull = true; return ""; } 777 int index = key.indexOf( "{@" ); 778 if( index < 0 ) { return key; } 779 780 // 変数が "{@XXXX}" の場合を優先的に検索。 781 // これにより多くのパターンで、StringTokenizer による 782 // 文字列操作を行う必要がなくなります。 783 if( index == 0 && 784 ( key.indexOf( '}' ) == key.lastIndexOf( '}' ) ) && 785 ( key.charAt(key.length()-1) == '}' ) ) { 786 return getRequestValue( key.substring( 2,key.length()-1 ) ); 787 } 788 789 // 3.8.0.4 (2005/08/08) {} の処理方法見直し。連続処理、単体処理を可能にします。 790 StringBuilder rtn = new StringBuilder( HybsSystem.BUFFER_SMALL ); 791 int start = 0; 792 while( index >= 0 ) { 793 int end = key.indexOf( '}',index ); 794 if( end < 0 ) { 795 String errMsg = "{@ と } との対応関係がずれています。" + HybsSystem.CR 796 + "key=[" + key + "] : index=" + index ; 797 throw new HybsSystemException( errMsg ); 798 } 799 800 // {@ より前方の文字列を追加 801 if( index > 0 ) { rtn.append( key.substring( start,index ) ); } 802 803 // {@XXXX} の XXXX部分を処理 804 String val = getRequestValue( key.substring( index+2,end ) ); 805 if( val != null ) { rtn.append( val ); } 806 807 start = end+1 ; 808 index = key.indexOf( "{@",start ); 809 } 810 rtn.append( key.substring( start ) ); 811 812 return rtn.toString(); 813 } 814 815 /** 816 * {@XXX.YYYY} 形式の文字列から値を取得します。 817 * 予約語のみ処理をし、それ以外は{@xxx}のままとします。 818 * 819 * 他の文字列に混在した {@XXXX} 文字を変換可能です。 820 * ただし、処理の簡素化のため、上記形式以外は変換いたしません。 821 * エラー例)× { @XXXX }、{@ XXXX }、{@XXXX@yyyy}、{@XXXX{@yyyy}} 822 * また、"{@" を通常の記述で使うことは無いと考え、エスケープも用意して 823 * いません。よって、"{@" のパターンが見つかって,"}" で閉じられていない 824 * 場合は,エラーとして、HybsSystemException を throw します。 825 * 826 * @og.rev 5.5.4.0 (2012/07/02) 新規作成 827 * 828 * @param key リクエストのキー 829 * 830 * @return リクエストの値 831 */ 832 protected String getReservedParameter( final String key ) { 833 isReqNull = false; 834 835 if( key == null ) { isReqNull = true; return ""; } 836 int index = key.indexOf( "{@" ); 837 if( index < 0 ) { return key; } 838 839 // 変数が "{@XXXX}" の場合を優先的に検索。 840 // これにより多くのパターンで、StringTokenizer による 841 // 文字列操作を行う必要がなくなります。 842 if( index == 0 && 843 ( key.indexOf( '}' ) == key.lastIndexOf( '}' ) ) && 844 ( key.charAt(key.length()-1) == '}' ) ) { 845 return getReservedValue( key.substring( 2,key.length()-1 ) ); 846 } 847 848 // 3.8.0.4 (2005/08/08) {} の処理方法見直し。連続処理、単体処理を可能にします。 849 StringBuilder rtn = new StringBuilder( HybsSystem.BUFFER_SMALL ); 850 int start = 0; 851 while( index >= 0 ) { 852 int end = key.indexOf( '}',index ); 853 if( end < 0 ) { 854 String errMsg = "{@ と } との対応関係がずれています。" + HybsSystem.CR 855 + "key=[" + key + "] : index=" + index ; 856 throw new HybsSystemException( errMsg ); 857 } 858 859 // {@ より前方の文字列を追加 860 if( index > 0 ) { rtn.append( key.substring( start,index ) ); } 861 862 // {@XXXX} の XXXX部分を処理 863 String val = getReservedValue( key.substring( index+2,end ) ); 864 if( val != null ) { rtn.append( val ); } 865 866 start = end+1 ; 867 index = key.indexOf( "{@",start ); 868 } 869 rtn.append( key.substring( start ) ); 870 871 return rtn.toString(); 872 } 873 874 /** 875 * {@XXXX} 形式の文字列から XXXX をキーとして ServletRequest から getParameterValues で値を取り出します。 876 * 877 * これは、複数(配列)でリクエストを取り出すことが可能です。 878 * そのため、他の文字列に混在させて変換することができません。 879 * "{@XXXX}" 形式 からのみの変換となります。 880 * 881 * @og.rev 3.6.0.0 (2004/09/22) キーがnull のときにnullではなく長さ0の配列を返します。 882 * 883 * @param key リクエストのキー 884 * 885 * @return リクエストの値 886 */ 887 protected String[] getRequestParameterValues( final String key ) { 888 if( key == null ) { return new String[0]; } // 3.6.0.0 (2004/09/22) 889 int index = key.indexOf( "{@" ); 890 if( index < 0 ) { return StringUtil.csv2Array( key ); } 891 892 if( index == 0 && key.charAt( key.length()-1 ) == '}' ) { 893 return getRequestValues( key.substring( 2,key.length()-1 ) ); 894 } 895 896 String errMsg = "引数の形式が異なります。 [" + key + "]" ; 897 throw new HybsSystemException( errMsg ); 898 } 899 900 /** 901 * 引数 in が、引数 check の文字列の中に存在すれば、 true を、存在しなければ、false を返します。 902 * 903 * check は、 非null のString を、in は、null でも構いません。 904 * 905 * @param in チェックする文字列 906 * @param check チェック用の基本文字列 907 * 908 * @return 存在する true / 存在しない false 909 */ 910 protected boolean check( final String in, final String check ) { 911 if( in == null ) { return false; } 912 return check.indexOf( in ) >= 0 ; 913 } 914 915 /** 916 * 引数 in が、引数 check の文字列配列の中に存在すれば、 true を、存在しなければ、false を返します。 917 * 918 * check は、 String配列 を、in は、null でも構いません。 919 * 920 * @og.rev 2.1.0.3 (2002/11/08) 文字列配列を引数に取るメソッドを追加 921 * 922 * @param in チェックする文字列 923 * @param check チェック用の基本文字列配列 924 * 925 * @return 存在する true / 存在しない false 926 */ 927 protected boolean check( final String in, final String[] check ) { 928 if( in == null || check == null ) { return false; } 929 for( int i=0; i<check.length; i++ ) { 930 if( in.equals( check[i] ) ) { return true; } 931 } 932 return false ; 933 } 934 935 /** 936 * ユーザーオブジェクトが持っている内部情報を取得します。 937 * 938 * これは、UserInfo#getAttribute( String ) で取得される情報です。 939 * ユーザーパラメータとは異なります。 940 * 941 * @og.rev 2.2.0.0 (2002/12/17) 中国語(国際化)対応 getUser() を使用するように変更 942 * 943 * @param user ユーザー情報を取り出すキー 944 * 945 * @return ユーザー情報文字列 946 */ 947 protected String getUserInfo( final String user ) { 948 if( user == null ) { return null; } 949 950 String key = user ; 951 if( key.charAt(0) == '@' ) { 952 key = getRequestValue( key.substring( 1 ) ); 953 } 954 955 return getUser().getAttribute( key ); 956 } 957 958 /** 959 * ユーザー情報を設定します。 960 * 961 * 初めての場合は、session 登録項目 の HybsSystem#USERINFO_KEY キー の値で 962 * 取得します。 963 * 964 * @og.rev 2.1.1.4 (2002/11/25) ユーザー情報をセットするメソッドを追加 965 * @og.rev 2.2.0.0 (2002/12/17) 中国語(国際化)対応 getUser() を使用するように変更 966 * @og.rev 4.3.4.0 (2008/12/01) GE20(ユーザー定数)へ登録するかのフラグを追加 967 * 968 * @param key ユーザー情報をセットするキー 969 * @param value ユーザー情報文字列 970 * @param save GE20(ユーザー定数)に情報を保存するか 971 */ 972 protected void setUserInfo( final String key,final String value, final boolean save ) { 973 if( key != null ) { 974 getUser().setAttribute( key, value, save ); 975 } 976 } 977 978 /** 979 * ユーザー情報オブジェクトを取得します。 980 * 981 * 初めての場合は、session 登録項目 の HybsSystem#USERINFO_KEY キー の値で 982 * 取得します。 983 * 984 * @og.rev 2.2.0.0 (2002/12/17) 中国語(国際化)対応 新規追加 985 * @og.rev 3.6.0.0 (2004/09/17) private ⇒ protected 化します。 986 * 987 * @return ユーザー情報オブジェクト 988 */ 989 protected UserInfo getUser() { 990 if( userInfo == null ) { 991 userInfo = (UserInfo)getSessionAttribute( HybsSystem.USERINFO_KEY ); 992 } 993 if( userInfo == null ) { 994 String errMsg = "ユーザーオブジェクトが存在しません。"; 995 throw new HybsSystemException( errMsg ); 996 } 997 return userInfo ; 998 } 999 1000 /** 1001 * 画面情報(GUIInfo)を取得します。 1002 * 1003 * これは、session 登録項目 の HybsSystem#GUIMAP_KEY キー の値で 1004 * 登録された MAP を取り出し、そこから取得します。 1005 * 画面情報は、ログインユーザー毎に個別に持っています。 1006 * 1007 * @og.rev 4.0.0.0 (2005/01/31) GUIInfo が存在しない場合も処理を続けます。 1008 * 1009 * @param gamenId 画面ID 1010 * 1011 * @return 画面情報(GUIInfo) 1012 */ 1013 protected GUIInfo getGUIInfo( final String gamenId ) { 1014 return getUser().getGUIInfo( gamenId ); 1015 } 1016 1017 /** 1018 * 画面情報(GUIInfo)の属性値を取得します。 1019 * 1020 * これは、{@GUI.XXXX ID} 引数処理をおこなうための、サポートメソッドです。 1021 * 引数は、"XXXX ID" という状態で受け取ります。(GUI. ははずした形) 1022 * XXXXには、画面情報(GUIInfo)の属性キーを指定します。IDが指定されない場合は、 1023 * 実行中の自分自身の画面が指定されたことになります。 1024 * これは、session 登録項目 の HybsSystem#GUIINFO_KEY キー の値で取得します。 1025 * この値は,画面が呼び出される毎に毎回設定されており、リクエスト毎に 1026 * 所得し直す必要があります。 1027 * 1028 * ID に、画面IDを指定した場合は、@ 指定によるリクエスト引数の値を適用できます。 1029 * {@GUI.@XXXX ID} や、{@GUI.XXXX @ID} です。(同時指定も可能) 1030 * 1031 * @og.rev 3.6.0.6 (2004/10/22) GUIInfo が存在しない場合も処理を続けます。 1032 * @og.rev 4.0.0.0 (2004/11/30) 画面ID引数や、リクエスト引数の使用を可能にします。 1033 * 1034 * @param attkey 画面情報を取り出すキー 1035 * 1036 * @return 画面情報文字列 1037 */ 1038 protected String getGUIInfoAttri( final String attkey ) { 1039 if( attkey == null ) { return null; } 1040 1041 String key = attkey ; 1042 final GUIInfo gui ; 1043 1044 int spc = key.indexOf( ' ' ); // " " があるかどうか 1045 if( spc > 0 ) { 1046 key = attkey.substring( 0,spc ); 1047 String id = attkey.substring( spc+1 ); 1048 if( id.charAt(0) == '@' ) { id = getRequestValue( id.substring( 1 ) ); } 1049 1050 gui = getUser().getGUIInfo( id ); 1051 } 1052 else { 1053 if( guiInfo == null ) { 1054 guiInfo = (GUIInfo)getSessionAttribute( HybsSystem.GUIINFO_KEY ); 1055 } 1056 gui = guiInfo; 1057 } 1058 if( gui == null ) { return "Not Found[" + attkey + "]"; } 1059 if( key.charAt(0) == '@' ) { key = getRequestValue( key.substring( 1 ) ); } 1060 1061 return gui.getAttribute( key ); 1062 } 1063 1064 /** 1065 * {@NVL.XXX 値} で、XXXが NULLの場合、値を返します。 1066 * 1067 * ORACLE等の COALESCE ( expr_list ) 処理に近い結果を返します。 1068 * NVL ( expr1 , expr2 ) は、expr1 が NULL の場合、expr2 を返しますが、 1069 * COALESCE は、第一引数が NULLなら、次の引数、それも NULL なら、さらに次と 1070 * 引数リストを順次処理していきます。 1071 * それと同じく、XXX が NULL なら、その次・・と順次評価していき、NULL でない 1072 * 値が返ってきたところで、その値を返します。 1073 * これは、{@NVL.XXX @YYY ZZZ ・・・} 形式を処理します。 1074 * これは、パラメータ XXX が NULLの場合、次の値を使います。(@YYY) 1075 * @YYY は、YYY パラメータの事で、これも NULL の場合は、ZZZ を使います。 1076 * 最後まで NULL の場合は、 ゼロ文字列が返されます。 1077 * 1078 * @og.rev 5.6.4.0 (2013/05/02) 新規追加 1079 * 1080 * @param attkey NVL情報を取り出すパラメータ 1081 * 1082 * @return NULL以外の値が出てくるまで、順次評価した結果 1083 */ 1084 protected String getNVLAttri( final String attkey ) { 1085 if( attkey == null ) { return null; } 1086 1087 String[] keys = attkey.split( " " ); // スペースで、パラメータを分解する。 1088 String val = getRequestValue( keys[0] ); // 第一パラメータは、そのままのキーで検索 1089 1090 // val が null の間は、チェックする。 1091 if( val == null || val.isEmpty() ) { 1092 for( int i=1; i<keys.length; i++ ) { 1093 val = keys[i]; 1094 // 先頭が @ の場合は、リクエスト変数のキーとして、値を判定 1095 if( val.charAt(0) == '@' ) { val = getRequestValue( val.substring( 1 ) ); } 1096 if( val != null && val.length() > 0 ) { break; } 1097 } 1098 } 1099 1100 if( val == null ) { val = ""; } // NULL の場合は、 ゼロ文字列を返す。 1101 1102 return val; 1103 } 1104 1105 /** 1106 * {@LAST.XXX} で、XXXが 最後に使われた値を返します。 1107 * 1108 * XXX は、command="NEW" でセットされたリクエスト値です。通常、{@MEM.XXX} は 1109 * 画面単位に、既存のキャッシュから値を取り出しますが、{@LAST.XXX} は、 1110 * 画面に関係なく、ユーザー単位に管理しています。 1111 * また、値は、データベース(GE20)に保管されますので、次回ログイン時にも有効です。 1112 * この処理が呼び出されたときに、リクエスト変数に、XXXX が存在した場合は、そちらを優先に 1113 * 使います。その場合は、command に関係なく、値を設定しておきます。 1114 * 1115 * command="NEW"の場合のリクエスト変数の値の設定は、RequestCacheTag で行います。 1116 * 1117 * ※ データベースには、画面アクセス情報のセーブ時に行われます。 1118 * valueタグのsave属性の様に、リアルタイムではありませんので、Tomcatが 1119 * 異常終了した場合は、セーブされません。 1120 * 1121 * @og.rev 5.6.8.1 (2013/09/13) 新規追加 1122 * 1123 * @param attkey 最後に使われた値をを取り出すパラメータ 1124 * 1125 * @return XXXが 最後に使われた値 1126 * @see org.opengion.hayabusa.taglib.RequestCacheTag#commandExec( String ,ServletRequest ) 1127 * @see org.opengion.hayabusa.resource.UserInfo#getLastRequestValue( String ) 1128 */ 1129 protected String getLASTAttri( final String attkey ) { 1130 if( attkey == null ) { return null; } 1131 1132 // 最新のリクエスト変数をチェック 1133 String[] vals = getRequest().getParameterValues( attkey ); 1134 1135 String val = null; 1136 if( vals == null ) { 1137 val = getUser().getLastRequestValue( attkey ); // なければ、取得 1138 } 1139 else { 1140 for( int i=0; i<vals.length; i++ ) { 1141 val = vals[i]; 1142 if( ! "0".equals( val ) ) { break; } // チェックボックス対応 1143 } 1144 getUser().setLastRequestValue( attkey,val ); // あれば、最新の値をセット 1145 } 1146 1147 return val ; 1148 } 1149 1150 /** 1151 * 予約語に関する情報の文字列を取得します。 1152 * 1153 * @og.rev 5.5.4.0 (2012/07/02) 予約語部分のみ分離 1154 * @og.rev 5.6.4.0 (2013/05/02) NVL 追加 1155 * @og.rev 5.6.8.1 (2013/09/13) LAST 追加 1156 * 1157 * @param key キー 1158 * 1159 * @return リクエスト情報の文字列 1160 */ 1161 protected String getReservedValue( final String key ) { 1162 if( key == null ) { isReqNull = true; return ""; } // 3.4.0.3 (2003/09/10) 1163 1164 String rtn ; 1165 int adrs = key.indexOf( '.' ); 1166 if( adrs > 0 ) { 1167 String subKey = key.substring( adrs+1 ); 1168 if( key.startsWith( "USER." ) ) { 1169 rtn = getUserInfo( subKey ); 1170 } 1171 else if( key.startsWith( "GUI." ) ) { 1172 rtn = getGUIInfoAttri( subKey ); // 4.0.0 (2005/01/31) 1173 } 1174 else if( key.startsWith( "SYS." ) ) { 1175 rtn = sys( subKey ); // 3.5.6.6 (2004/08/23) 1176 } 1177 else if( key.startsWith( "SESSION." ) ) { // 3.5.5.3 (2004/04/09) 1178 rtn = String.valueOf( getSessionAttribute( subKey ) ); 1179 } 1180 // 3.4.0.3 (2003/09/10) MEM.XXXX で、REQUEST_CACHE の値を取得できるように修正。 1181 else if( key.startsWith( "MEM." ) ) { 1182 // 3.5.4.7 (2004/02/06) getRequestCacheData を使用するように修正 1183 rtn = getRequestCacheData( subKey ); 1184 } 1185 // 3.8.0.2 (2005/07/11) MSG.XXXX で、メッセージリソースの値を取得できるように追加。 1186 // 3.8.0.2 (2005/07/11) LBL.XXXX で、ラベルリソースの値を取得できるように追加。 1187 else if( key.startsWith( "LBL." ) ) { 1188 rtn = getLabel( subKey ); 1189 } 1190 // 3.8.0.2 (2005/07/11) DATE.XXXX で、日付関係の値を取得できるように追加。 1191 else if( key.startsWith( "DATE." ) ) { 1192 rtn = getDateFormat( subKey ); 1193 } 1194 // 3.8.0.1 (2005/06/17) NVAR.XXXX で、getUnicodeEscape 変換() を行います。 1195 // NVAR. を取り除いた XXXX で再度、リクエスト値を取得し、それを Escape変換します。 1196 else if( key.startsWith( "NVAR." ) ) { 1197 rtn = StringUtil.getUnicodeEscape( getRequestValue( subKey ) ); 1198 } 1199 // 4.3.6.0 (2009/04/01) メールモジュール用の予約語 1200 else if( key.startsWith( "MAIL." ) ) { 1201 rtn = ( String )getSessionAttribute( key ); 1202 } 1203 // 4.3.7.0 (2009/06/01) DB関数名の取得 1204 else if( key.startsWith( "DBF." ) ) { 1205 rtn = getDBFunctionName( subKey ); 1206 } 1207 // 4.4.0.0 (2009/08/02) データロールに基づく条件式の取得 1208 else if( key.startsWith( "SEC." ) ) { 1209 rtn = getDataCondition( subKey ); 1210 } 1211 // 5.3.9.0 (2011/09/01) URLエンコード変換 1212 else if( key.startsWith( "URL." ) ) { 1213 rtn = StringUtil.urlEncode( getRequestValue( subKey ) ); 1214 } 1215 // 5.5.1.3 (2012/04/09) エスケープ変換 1216 else if( key.startsWith( "ESC." ) ) { 1217 rtn = StringUtil.htmlFilter( getRequestValue(subKey,false) ); 1218 } 1219 // 5.6.4.0 (2013/05/02) NVL 追加 1220 else if( key.startsWith( "NVL." ) ) { 1221 rtn = getNVLAttri( subKey ); 1222 } 1223 // 5.6.8.1 (2013/09/13) LAST 追加 1224 else if( key.startsWith( "LAST." ) ) { 1225 rtn = getLASTAttri( subKey ); 1226 } 1227 // 4.0.0 (2007/06/12) DB.XXXX は、直接取り出すように変更します。 1228 else { // 4.0.0.0 (2007/11/16) 1229 rtn = (String)getRequestAttribute( key ); // ※ 取り出しは、key で 1230 } 1231 } 1232 else{ 1233 rtn = "{@" + key + "}"; // 予約語以外は括弧を付けて書き戻します。 1234 } 1235 return rtn; 1236 } 1237 1238 /** 1239 * リクエスト情報の文字列を取得します。 1240 * 1241 * @og.rev 5.0.0.2 (2009/09/15) XSS対策 1242 * 1243 * @param key キー 1244 * 1245 * @return リクエスト情報の文字列 1246 */ 1247 protected String getRequestValue( final String key ) { 1248 return getRequestValue( key, xssCheck); 1249 } 1250 1251 /** 1252 * リクエスト情報の文字列を取得します。 1253 * 1254 * @og.rev 2.2.0.0 (2002/12/17) 中国語(国際化)対応 エンコードの取得方法変更 1255 * @og.rev 3.0.0.0 (2002/12/25) StringUtil#changeString 廃止 1256 * @og.rev 3.0.0.0 (2002/12/25) ValueTag追加の為、指定の scope の Attributeより取得 1257 * @og.rev 3.1.0.1 (2003/03/26) Valueタグの値と、request情報の値の所得優先順位を、request が優先されるように変更。 1258 * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応。HybsRequestWrapper 廃止。直接 Mapでキャッシュする。 1259 * @og.rev 3.1.5.0 (2003/04/22) SYS.XXXX で、システムパラメータ の値を取得できるように修正。 1260 * @og.rev 3.1.7.0 (2003/05/02) リクエスト情報の取得順序を、Request、キャッシュ、Value の順に変更。 1261 * @og.rev 3.1.7.0 (2003/05/02) value値の使用可否を指定する、useValue 属性を追加。 1262 * @og.rev 3.4.0.3 (2003/09/10) MEM.XXXX で、REQUEST_CACHE の値を取得できるように修正。 1263 * @og.rev 3.5.4.7 (2004/02/06) getRequestCacheData を使用するように修正 1264 * @og.rev 3.5.5.3 (2004/04/09) {@SESSION.XXXX} で、session.getAttribute( "XXXX" ) の値を取得するように修正 1265 * @og.rev 3.5.6.6 (2004/08/23) SYS.XXXX の処理を getSystemParameter( String key ) メソッドへ移動 1266 * @og.rev 3.8.0.1 (2005/06/17) NVAR.XXXX で、getUnicodeEscape 変換() を行います。 1267 * @og.rev 3.8.0.2 (2005/07/11) MSG.XXXX , LBL.XXXX の処理を追加 1268 * @og.rev 3.8.0.2 (2005/07/11) チェックボックス対応で、重複リクエストに対応させます。 1269 * @og.rev 3.8.8.8 (2007/05/11) 重複リクエスト処理の場所を移動。リクエストのみ対象とする。 1270 * @og.rev 4.0.0.0 (2005/08/31) quotCheck によるSQLインジェクション対策 1271 * @og.rev 4.0.0.0 (2005/08/31) getSystemParameter を sys に名称変更 1272 * @og.rev 4.0.0.0 (2007/04/02) Valueタグの値と、キャッシュでは、Valueタグの値を優先するように変更 1273 * @og.rev 4.0.0.0 (2007/11/16) "."付きのパラメータのエラー処理をなくし、getRequestAttributeで取得する。 1274 * @og.rev 4.3.0.0 (2008/07/04) DB.XXXX は、必ずStringオブジェクトとし、String.valueOf しない。 1275 * @og.rev 4.3.6.0 (2009/04/01) メールモジュール用の予約語MAIL.XXXXの取得対応 1276 * @og.rev 4.4.0.0 (2009/08/02) データロール対応(SEC.xxxの取得対応) 1277 * @og.rev 5.0.0.2 (2009/09/15) XSS対策用にメソッドにフラグを追加 1278 * @og.rev 5.1.8.0 (2010/07/01) isNullSet 属性 廃止にともなう、useValue 属性廃止 1279 * @og.rev 5.3.9.0 (2011/09/01) URL.XXXX処理を追加 1280 * @og.rev 5.5.1.3 (2012/04/09) ESC.XXXX処理を追加 1281 * @og.rev 5.5.4.0 (2012/07/01) 予約語の処理を分離 1282 * @og.rev 5.7.4.2 (2014/03/20) サニタイズ処理は、getSanitizedBodyString() ではなく、ここで行います。 1283 * 1284 * @param key キー 1285 * @param xssCheckFlg XSS対策用 1286 * 1287 * @return リクエスト情報の文字列 1288 */ 1289 protected String getRequestValue( final String key, final boolean xssCheckFlg ) { 1290 if( key == null ) { isReqNull = true; return ""; } // 3.4.0.3 (2003/09/10) 1291 1292 String rtn ; 1293 int adrs = key.indexOf( '.' ); 1294 1295 if( adrs > 0 ) { 1296 rtn = getReservedValue( key ); // 5.5.4.0 (2012/07/02) 1297 } 1298 else { 1299 rtn = getRequest().getParameter( key ); 1300 1301 // 5.7.4.2 (2014/03/20) サニタイズ処理は、getSanitizedBodyString() ではなく、ここで行います。 1302 // 6.0.0.1 (2014/04/25) These nested if statements could be combined 1303 if( isSanitized && rtn != null && rtn.indexOf( '[' ) >= 0 ) { 1304 rtn = rtn.replace( "[", "\\]\\" ); 1305 } 1306 1307 // 5.0.0.2 (2009/09/15) tagCheck によるthan signチェック Parameterのみにかけるためこの位置 1308 if( rtn != null && rtn.length() > 0 && xssCheckFlg && ( rtn.indexOf( '<' ) >= 0 || rtn.indexOf( '>' ) >= 0 ) ) { 1309 String errMsg = "リクエスト引数に Less/Greater than sign(<,>)を含むことは出来ません。" + HybsSystem.CR 1310 + " 処理が正しい場合は、xssCheck 属性を false にセットしてください。" + HybsSystem.CR 1311 + " key=[" + key + "]" 1312 + " val=[" + rtn + "]" 1313 + " tag=[" + getTagName() + "]" ; 1314 throw new HybsSystemException( errMsg ); 1315 } 1316 1317 // 3.8.8.8 (2007/05/11) 重複リクエスト処理の場所を移動。リクエストのみ対象とする。 1318 // 3.8.0.2 (2005/07/11) チェックボックス対応で、重複リクエストに対応させます。 1319 // {@XXXX} で、値が"0"の場合、複数リクエストを確認して、"1"が含まれていれば、"1"とします。 1320 if( "0".equals(rtn) ) { 1321 boolean backFlag = isReqNull ; 1322 String[] vals = getRequestValues( key ); 1323 if( vals != null && vals.length > 1 ) { 1324 for( int i=0; i<vals.length; i++ ) { 1325 if( "1".equals( vals[i] ) ) { rtn = "1"; break; } 1326 } 1327 } 1328 isReqNull = backFlag; // 3.8.8.8 (2007/05/11) getRequestValues での NULLセット解除 1329 } 1330 1331 // 3.1.0.1 (2003/03/26) Valueタグの値と、request情報の値の取得優先順位を、 1332 // request が優先されるように変更。 1333 if( ( rtn == null || rtn.length() == 0 ) && requestCache != null ) { 1334 String[] str = requestCache.get( key ); 1335 if( str != null && str.length > 0 ) { 1336 rtn = str[0]; 1337 } 1338 } 1339 // 5.1.8.0 (2010/07/01) isNullSet 属性 廃止にともなう、useValue 属性廃止 1340 if( rtn == null || rtn.length() == 0 ) { 1341 Object obj = pageContext.findAttribute( key ); 1342 if( obj != null ) { 1343 rtn = obj.toString(); 1344 } 1345 } 1346 } 1347 if( rtn == null || rtn.length() == 0 ) { 1348 isReqNull = true; 1349 rtn = ""; 1350 } 1351 // 4.0.0 (2005/08/31) quotCheck によるSQLインジェクション対策 1352 else if( quotCheck && rtn.indexOf( "'" ) >= 0 && !key.startsWith( "SEC." ) ) { 1353 String errMsg = "リクエスト引数に、クォーティション(')を含むことは出来ません。" + HybsSystem.CR 1354 + " 処理が正しい場合は、quotCheck 属性を false にセットしてください。" + HybsSystem.CR 1355 + " key=[" + key + "]" 1356 + " val=[" + rtn + "]" 1357 + " tag=[" + getTagName() + "]" ; 1358 throw new HybsSystemException( errMsg ); 1359 } 1360 1361 return rtn ; 1362 } 1363 1364 /** 1365 * リクエスト情報の文字列を取得します。 1366 * 1367 * @og.rev 2.2.0.0 (2002/12/17) 中国語(国際化)対応 エンコードの取得方法変更 1368 * @og.rev 3.0.0.0 (2002/12/25) StringUtil#changeString 廃止 1369 * @og.rev 3.1.8.0 (2003/05/16) RequestCache データをリクエスト配列情報にも適用する。 1370 * @og.rev 5.3.8.0 (2011/08/01) Attribute等からも値が取得できるようにする。 1371 * 1372 * @param key キー 1373 * 1374 * @return リクエスト情報の文字列 1375 */ 1376 protected String[] getRequestValues( final String key ) { 1377 String[] rtn = getRequest().getParameterValues( key ); 1378 1379 // 3.1.8.0 (2003/05/16) RequestCache データをリクエスト配列情報にも適用する。 1380 if( ( rtn == null || rtn.length == 0 ) && requestCache != null ) { 1381 rtn =requestCache.get( key ); 1382 } 1383 1384 // 5.3.8.0 (2011/08/01) Attribute等からも値が取得できるようにする。 1385 if( rtn == null || rtn.length == 0 ) { 1386 String tmp = getRequestValue( key ); 1387 if( tmp != null && tmp.length() > 0 ) { 1388 rtn = new String[]{ tmp }; 1389 } 1390 } 1391 1392 if( rtn == null || rtn.length == 0 ) { isReqNull = true; } 1393 return rtn ; 1394 } 1395 1396 /** 1397 * リクエスト情報の文字列のキー集合を取得します。 1398 * 1399 * @og.rev 5.3.2.0 (2011/02/01) パラメーターの外部指定対応 1400 * 1401 * @return リクエスト情報の文字列のキー集合 1402 */ 1403 protected Enumeration<?> getParameterNames() { // 4.3.3.6 (2008/11/15) Generics警告対応 1404 String[] names = (String[])getRequestAttribute( HybsSystem.PARAM_NAMES_KEY ); 1405 return names == null ? getRequest().getParameterNames() : Collections.enumeration( Arrays.asList( names ) ) ; 1406 } 1407 1408 /** 1409 * リクエスト情報の文字列のキー集合をセットします。 1410 * 1411 * @og.rev 5.3.2.0 (2011/02/01) パラメーターの外部指定対応 1412 * 1413 * @param names リクエスト情報の文字列のキー配列 1414 */ 1415 protected void setParameterNames( final String[] names ) { 1416 setRequestAttribute( HybsSystem.PARAM_NAMES_KEY, names ); 1417 } 1418 1419 /** 1420 * リクエスト情報の文字列に NULL が存在していたかどうかを取得します。 1421 * 1422 * これは、getRequestParameter( String ) の呼出し毎に設定されます。 1423 * つまり、上記メソッドの実行直後の値を取り出す必要があります。 1424 * NULL が含まれていた(true)/含まれていなかった。(false) 1425 * 1426 * @return NULLが含まれていた(true)/含まれていなかった。(false) 1427 */ 1428 protected boolean isNull() { 1429 return isReqNull; 1430 } 1431 1432 /** 1433 * セッションに登録されているオブジェクトを取得します。 1434 * 1435 * @param key キー 1436 * 1437 * @return セッションに登録されているオブジェクト 1438 */ 1439 protected Object getSessionAttribute( final String key ) { 1440 if( session == null ) { session = pageContext.getSession(); } 1441 return session.getAttribute( key ); 1442 } 1443 1444 /** 1445 * セッションに 指定のキーでオブジェクトをセットします。 1446 * 1447 * @param key キー 1448 * @param object セッションに登録するオブジェクト 1449 */ 1450 protected void setSessionAttribute( final String key ,final Object object ) { 1451 if( session == null ) { session = pageContext.getSession(); } 1452 session.setAttribute( key,object ); 1453 } 1454 1455 /** 1456 * セッションに指定のキーで登録されているオブジェクトを 削除します。 1457 * 1458 * @param key キー 1459 */ 1460 protected void removeSessionAttribute( final String key ) { 1461 if( session == null ) { session = pageContext.getSession(); } 1462 session.removeAttribute( key ); 1463 } 1464 1465 /** 1466 * リクエストに登録されているオブジェクトを取得します。 1467 * 1468 * @param key キー 1469 * 1470 * @return リクエストンに登録されているオブジェクト 1471 */ 1472 protected Object getRequestAttribute( final String key ) { 1473 return getRequest().getAttribute( key ); 1474 } 1475 1476 /** 1477 * リクエストに 指定のキーでオブジェクトをセットします。 1478 * 1479 * @param key キー 1480 * @param object リクエストに登録するオブジェクト 1481 */ 1482 protected void setRequestAttribute( final String key ,final Object object ) { 1483 getRequest().setAttribute( key,object ); 1484 } 1485 1486 /** 1487 * リクエストに指定のキーで登録されているオブジェクトを 削除します。 1488 * 1489 * @param key キー 1490 */ 1491 protected void removeRequestAttribute( final String key ) { 1492 getRequest().removeAttribute( key ); 1493 } 1494 1495 /** 1496 * コンテキスト(applicaton)に登録されているオブジェクトを取得します。 1497 * 1498 * scope属性に、"applicaton" が指定された場合に、実行されます。 1499 * 1500 * @og.rev 3.0.0.0 (2002/12/25) scope="applicaton" 指定の追加 1501 * 1502 * @param key キー 1503 * 1504 * @return コンテキスト(applicaton)に登録されているオブジェクト 1505 */ 1506 protected Object getContextAttribute( final String key ) { 1507 ServletContext applicaton = pageContext.getServletContext(); 1508 return applicaton.getAttribute( key ); 1509 } 1510 1511 /** 1512 * コンテキスト(applicaton)指定のキーでオブジェクトをセットします。 1513 * 1514 * scope属性に、"applicaton" が指定された場合に、実行されます。 1515 * 1516 * @og.rev 3.0.0.0 (2002/12/25) scope="applicaton" 指定の追加 1517 * 1518 * @param key キー 1519 * @param object コンテキスト(applicaton)に登録するオブジェクト 1520 */ 1521 protected void setContextAttribute( final String key ,final Object object ) { 1522 ServletContext applicaton = pageContext.getServletContext(); 1523 applicaton.setAttribute( key,object ); 1524 } 1525 1526 /** 1527 * コンテキスト(applicaton)指定のキーで登録されているオブジェクトを 削除します。 1528 * 1529 * scope属性に、"applicaton" が指定された場合に、実行されます。 1530 * 1531 * @og.rev 3.0.0.0 (2002/12/25) scope="applicaton" 指定の追加 1532 * 1533 * @param key キー 1534 */ 1535 protected void removeContextAttribute( final String key ) { 1536 ServletContext applicaton = pageContext.getServletContext(); 1537 applicaton.removeAttribute( key ); 1538 } 1539 1540 /** 1541 * アプリケーションサーバーのコンテキストパスのURLを返します。 1542 * 1543 * @return コンテキストパス 1544 */ 1545 protected String getContextPath() { 1546 return ((HttpServletRequest)getRequest()).getContextPath(); 1547 } 1548 1549 /** 1550 * スコープに応じて登録されているオブジェクトを取得します。 1551 * 1552 * @og.rev 3.0.0.0 (2002/12/25) scope="applicaton" 指定の追加 1553 * 1554 * @param key キー 1555 * 1556 * @return スコープに応じて登録されているオブジェクト 1557 */ 1558 protected Object getObject( final String key ) { 1559 if( "session".equals( scope ) ) { return getSessionAttribute( key ); } 1560 else if( "request".equals( scope ) ) { return getRequestAttribute( key ); } 1561 else if( "applicaton".equals( scope ) ) { return getContextAttribute( key ); } 1562 else { 1563 String errMsg = "このスコープはサポートされていません。[" + scope + "]"; 1564 throw new IllegalArgumentException( errMsg ); 1565 } 1566 } 1567 1568 /** 1569 * スコープに応じて登録されているオブジェクトを指定のキーでセットします。 1570 * 1571 * @og.rev 3.0.0.0 (2002/12/25) scope="applicaton" 指定の追加 1572 * 1573 * @param key キー 1574 * @param object リクエストに登録するオブジェクト 1575 * @see #setObject( String ,Object ,String ) 1576 */ 1577 protected void setObject( final String key ,final Object object ) { 1578 setObject( key,object,scope ); 1579 } 1580 1581 /** 1582 * スコープに応じて登録されているオブジェクトを指定のキーでセットします。 1583 * 1584 * 引数にスコープを指定します。スコープが null の場合は、オリジナルの 1585 * スコープを使用します。 1586 * 1587 * @og.rev 5.2.2.0 (2010/11/01) 新規追加 1588 * 1589 * @param key キー 1590 * @param object リクエストに登録するオブジェクト 1591 * @param scp スコープ 1592 * @see #setObject( String ,Object ) 1593 */ 1594 protected void setObject( final String key ,final Object object ,final String scp ) { 1595 String inScp = (scp == null) ? scope : scp ; 1596 1597 if( "session".equals( inScp ) ) { setSessionAttribute( key,object ); } 1598 else if( "request".equals( inScp ) ) { setRequestAttribute( key,object ); } 1599 else if( "applicaton".equals( inScp ) ) { setContextAttribute( key,object ); } 1600 else { 1601 String errMsg = "このスコープはサポートされていません。[" + inScp + "]"; 1602 throw new IllegalArgumentException( errMsg ); 1603 } 1604 } 1605 1606 /** 1607 * スコープに応じて登録されているオブジェクトを指定のキーで削除します。 1608 * 1609 * @og.rev 3.0.0.0 (2002/12/25) scope="applicaton" 指定の追加 1610 * 1611 * @param key キー 1612 */ 1613 protected void removeObject( final String key ) { 1614 if( "session".equals( scope ) ) { removeSessionAttribute( key ); } 1615 else if( "request".equals( scope ) ) { removeRequestAttribute( key ); } 1616 else if( "applicaton".equals( scope ) ) { removeContextAttribute( key ); } 1617 else { 1618 String errMsg = "このスコープはサポートされていません。[" + scope + "]"; 1619 throw new IllegalArgumentException( errMsg ); 1620 } 1621 } 1622 1623 /** 1624 * リクエストオブジェクトを取得します。 1625 * 1626 * @og.rev 2.2.0.0 (2002/12/17) 中国語(国際化)対応 エンコードの取得方法変更 1627 * @og.rev 2.2.0.0 (2002/12/17) 文字化け対策 setCharacterEncoding が効いていないので削除 1628 * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応。HybsRequestWrapper 廃止。直接 Mapでキャッシュする。 1629 * @og.rev 3.4.0.3 (2003/09/10) 冗長な個所や、無意味な個所を、等価な内容のロジックに置き換える。 1630 * @og.rev 3.5.5.0 (2004/03/12) command=RESET 時にも、キャッシュを取り出すように変更します。 1631 * 1632 * @return リクエストオブジェクト 1633 */ 1634 @SuppressWarnings(value={"unchecked"}) 1635 protected ServletRequest getRequest() { 1636 if( request == null ) { 1637 request = pageContext.getRequest(); 1638 // リクエストキャッシュ機能 1639 String cmd =request.getParameter( "command" ); 1640 if( "RENEW".equals( cmd ) || "RESET".equals( cmd ) ) { // 3.5.5.0 1641 requestCache = (Map<String,String[]>)getSessionAttribute( HybsSystem.REQ_CACHE_KEY ); 1642 } 1643 } 1644 return request; 1645 } 1646 1647 /** 1648 * BodyContent オブジェクトを取得して、ボディの内容を取得します。 1649 * 1650 * 処理としては、getRequestParameter() によるパラメータ処理も含みます。 1651 * このメソッドは、必ず doAfterBody() から呼び出してください。それ以外(例えば、 1652 * doEndTag()等)では、すでに Body情報が破棄/再利用されている可能性があり、 1653 * 正常に動作しなくなる可能性があります。 1654 * 1655 * @og.rev 3.1.1.0 (2003/03/28) BodyContent オブジェクトを取得して、ボディの内容を取得する処理を追加 1656 * 1657 * @return ボディ文字列 1658 */ 1659 protected String getBodyString() { 1660 BodyContent body = getBodyContent(); 1661 return getRequestParameter( body.getString() ); 1662 } 1663 1664 /** 1665 * BodyContent オブジェクトを取得して、ボディの内容を取得します。 1666 * 1667 * {@XXXX}を変換しない生のBODY文を返します 1668 * 1669 * @og.rev 4.3.6.0 (2009/04/01) 新規作成 1670 * 1671 * @return ボディ文字列 1672 */ 1673 protected String getBodyRawString() { 1674 BodyContent body = getBodyContent(); 1675 return body.getString(); 1676 } 1677 1678 /** 1679 * BodyContent オブジェクトを取得して、ボディの内容を取得します。 1680 * 1681 * {@XXXX}の変換を行いますが、その変換結果に、"["が含まれる場合は、 1682 * "\\]\\"に変換して、フォーマット処理されないようにサニタイズします。 1683 * 1684 * @og.rev 5.1.7.0 (2010/06/01) 新規作成 1685 * @og.rev 5.7.4.2 (2014/03/20) サニタイズ処理を、標準の処理で行う。 1686 * 1687 * @return ボディ文字列 1688 */ 1689 protected String getSanitizedBodyString() { 1690 isSanitized = true; 1691 String rtn = getBodyString(); 1692 isSanitized = false; // 一連の処理の中だけ、有効とします。 1693 1694 return rtn; 1695 } 1696 1697 /** 1698 * JspWriter を使用した画面出力です。 1699 * 1700 * @param msg 画面に出力する文字列 1701 */ 1702 protected void jspPrint( final String msg ) { 1703 if( msg == null ) { return ; } 1704 try { 1705 JspWriter out = pageContext.getOut(); 1706 out.print( msg ); 1707 } catch(IOException ex) { 1708 String errMsg = "画面出力時の PageContext の取得時にエラーが発生しました。" 1709 + ex.getMessage(); // 5.1.8.0 (2010/07/01) errMsg 修正 1710 throw new HybsSystemException( errMsg,ex ); // 3.5.5.4 (2004/04/15) 引数の並び順変更 1711 } 1712 } 1713 1714 /** 1715 * デバッグ用の文字列を JspWriter を使用して画面に出力します。 1716 * このメソッドは、debugFlag=true の場合のみ動作します。 1717 * 1718 * 出力内容は,各オブジェクトの toString() 文字列です。 1719 * 1720 * @og.rev 4.0.0.0 (2005/02/28) debugFlag の条件式を追加。 1721 * @og.rev 4.0.0.0 (2005/02/28) 簡易リファレンスへのリンクを追加。 1722 */ 1723 protected void debugPrint() { 1724 if( debugFlag ) { 1725 try { 1726 JspWriter out = pageContext.getOut(); 1727 out.println( getDocumentLink() ); // 4.0.0 (2005/02/28) 1728 out.println( "<pre>" ); 1729 out.println( toString() ); 1730 out.println( "</pre>" ); 1731 } catch(IOException ex) { 1732 String errMsg = "デバッグ画面出力時の PageContext の取得時にエラーが発生しました。" 1733 + ex.getMessage(); // 5.1.8.0 (2010/07/01) errMsg 修正 1734 throw new HybsSystemException( errMsg,ex ); // 3.5.5.4 (2004/04/15) 引数の並び順変更 1735 } 1736 } 1737 } 1738 1739 /** 1740 * GAMENID付のリクエストキャッシュ情報を取り出します。 1741 * 1742 * @og.rev 3.5.4.7 (2004/02/06) 新規作成 1743 * 1744 * @param key リクエストキャッシュのキー情報 1745 * 1746 * @return リクエスト情報(存在しない場合は、null) 1747 */ 1748 protected String getRequestCacheData( final String key ) { 1749 String rtn = null; 1750 1751 String memKey = HybsSystem.REQ_CACHE_KEY + getGUIInfoAttri( "KEY" ); // 4.0.0 (2005/01/31) 1752 Map<?,?> mem = (Map<?,?>)getSessionAttribute( memKey ); // 4.3.3.6 (2008/11/15) Generics警告対応 1753 1754 if( mem != null ) { 1755 String[] vals = (String[])mem.get( key ); 1756 if( vals != null && vals.length > 0 ) { 1757 rtn = vals[0]; 1758 } 1759 } 1760 return rtn ; 1761 } 1762 1763 /** 1764 * GAMENID付のリクエストキャッシュ情報を取り出します。 1765 * 1766 * @og.rev 3.5.4.7 (2004/02/06) 新規作成 1767 * 1768 * @param key リクエストキャッシュのキー情報 1769 * @param value リクエストキャッシュに登録する値 1770 */ 1771 @SuppressWarnings(value={"unchecked"}) 1772 protected void setRequestCacheData( final String key,final String value ) { 1773 String[] vals = new String[] { value } ; 1774 1775 String memKey = HybsSystem.REQ_CACHE_KEY + getGUIInfoAttri( "KEY" ); // 4.0.0 (2005/01/31) 1776 Map<String,String[]> mem = (Map<String,String[]>)getSessionAttribute( memKey ); 1777 if( mem != null ) { 1778 mem.put( key,vals ); 1779 } 1780 } 1781 1782 /** 1783 * カンマ区切り引数(CSV引数)を配列に分解して返します。 1784 * 1785 * カンマ区切り引数(CSV引数)で複数指定されたリクエストパラメータを 1786 * 文字列配列に分解して、返します。 1787 * 引数は、{@XXXX} 変数も使用できます。 1788 * 分解方法は、CSV変数を先に分解してから、getRequestParameter で値を取得します。 1789 * こうしないとデータ自身にカンマを持っている場合に分解をミスる為です。 1790 * 1791 * @og.rev 3.5.6.2 (2004/07/05) 新規作成 1792 * 1793 * @param csvKey カンマ区切り引数(CSV引数) 1794 * 1795 * @return 配列に分解されたリクエストパラメータ値 1796 */ 1797 protected String[] getCSVParameter( final String csvKey ) { 1798 String[] keys = StringUtil.csv2Array( csvKey ); 1799 String[] vals = new String[keys.length]; 1800 for( int i=0; i<keys.length; i++ ) { 1801 vals[i] = getRequestParameter( keys[i] ) ; 1802 } 1803 return vals ; 1804 } 1805 1806 /** 1807 * リクエスト変数 {@SYS.XXXX} に対する値の取得を行います。 1808 * 1809 * 本来は、システムパラメータ の値を取得できますが、 1810 * システム的な共有値も取得できるように機能追加しています。 1811 * また、ユーザー個別にシステムパラメータを変更できます。この取得は、 1812 * システムパラメータとして取得します。(値はユーザー個別値を返します。) 1813 * ここで、引数に、@変数が使用できます。具体的には、{@SYS.@XXXX} 1814 * で、@XXXX をリクエスト変数から取得した値を利用します。 1815 * この中で、@GUIID だけが、さらに特殊で、実行中の画面IDを割り当てます。 1816 * この @GUIID は、ここまでの文字列を画面IDに置き換えるとともに、それ以降の 1817 * 文字列を、画面IDに連結させます。 1818 * {@SYS.@GUIID_XXXX} ⇒ 画面ID_XXXX 文字列で、システムパラメータ の値を取得します。 1819 * 1820 * SERVER_NAME このTomcatが実行しているサーバー名 localhost 等 1821 * SERVER_URL Portも含むURLアドレス http://localhost:8823/ 1822 * CONTEXT_URL 実行しているコンテキストのURLアドレス http://localhost:8823/dbdef2/ 1823 * REAL_PATH / ルートに対応する物理ディレクトリ d:/webapps/dbdef2/ 等 1824 * CONTEXT_NAME コンテキスト名(webapps 直下の仮想フォルダ名) dbdef 等 1825 * DATE YMDH とほぼ同じですが、'yyyy/MM/dd HH:mm:ss' の形式で取得できます。 1826 * HOSTNAME スペース区切りで指定したIPアドレスからホスト名を逆引きします 1827 * 任意 ユーザーパラメータ(GE16) の値/システムパラメータ(GE12)の値を取得 1828 * @GUIID_XXXX 既存の画面IDに、_XXXX を追加した文字列 1829 * @XXXX XXXX でリクエスト変数から取得した文字列 1830 * XXXX XXXX の文字列 1831 * 1832 * @og.rev 3.5.6.6 (2004/08/23) 新規作成 1833 * @og.rev 3.7.0.3 (2005/03/01) クッキー取得機能を追加 1834 * @og.rev 4.0.0.0 (2005/11/30) ユーザーパラメータは、システムパラメータとして取得します。 1835 * @og.rev 5.1.6.0 (2010/05/01) システムパラメータに、@GUIID という特殊パラメータが使用できるように対応します。 1836 * @og.rev 5.6.6.2 (2013/07/19) SYS.HOSTNAMEに対応します。 1837 * 1838 * @param key {@SYS.XXXX} の XXXX 部分の文字列(キー) 1839 * 1840 * @return キーに対する値。なければ、null 1841 */ 1842 protected String sys( final String key ) { 1843 final String rtn; 1844 1845 if( key.startsWith( "COOKIE." ) ) { // 3.7.0.3 (2005/03/01) 1846 rtn = getCookie( key.substring( "COOKIE.".length() ) ); 1847 } 1848 else if( key.startsWith( "DATE" ) ) { 1849 int idx = key.indexOf( ' ' ); 1850 if( idx >= 0 ) { 1851 rtn = HybsSystem.getDate( key.substring( idx+1 ) ); 1852 } 1853 else { 1854 rtn = HybsSystem.getDate(); 1855 } 1856 } 1857 else if( key.startsWith( "HOSTNAME" ) ) { // 5.6.6.2 (2013/07/19) 1858 int idx = key.indexOf( ' ' ); 1859 if( idx >= 0 ) { 1860 String key2 = key.substring( idx+1 ) ; 1861 if( key2.startsWith( "@" ) ) { 1862 rtn = getHostName( getRequestValue( key2.substring( 1 ) ) ); 1863 } 1864 else{ 1865 rtn = getHostName( key2 ); 1866 } 1867 } 1868 else{ 1869 rtn = getUser().getParameter( key ); 1870 } 1871 } 1872 // 5.1.6.0 (2010/05/01) {@SYS.@GUIID_XXXX} パラメータ対応 1873 else if( key.startsWith( "@GUIID" ) ) { 1874 String key2 = getGUIInfoAttri( "ID" ) + key.substring( "@GUIID".length() ); 1875 rtn = getUser().getParameter( key2 ); 1876 } 1877 // 5.1.6.0 (2010/05/01) {@SYS.@XXXX} パラメータ対応 1878 else if( key.startsWith( "@" ) ) { 1879 String key2 = getRequestValue( key.substring( 1 ) ); 1880 rtn = getUser().getParameter( key2 ); 1881 } 1882 else { 1883 rtn = getUser().getParameter( key ); 1884 } 1885 1886 return rtn ; 1887 } 1888 1889 /** 1890 * システムパラメータの値を、boolean 型に変換して返します。 1891 * 1892 * 本来は、システムパラメータ の値を取得できますが、 1893 * システム的な共有値も取得できるように機能追加しています。 1894 * また、ユーザー個別にシステムパラメータを変更できます。この取得は、 1895 * システムパラメータとして取得します。(値はユーザー個別値を返します。) 1896 * 1897 * @og.rev 4.0.0.0 (2005/11/30) 新規追加 1898 * 1899 * @param key システム設定 キー 1900 * 1901 * @return システム設定値(boolean型) 1902 */ 1903 protected boolean sysBool( final String key ) { 1904 return Boolean.valueOf( sys( key ) ).booleanValue(); 1905 } 1906 1907 /** 1908 * システムパラメータの値を、int 型に変換して返します。 1909 * 1910 * 本来は、システムパラメータ の値を取得できますが、 1911 * システム的な共有値も取得できるように機能追加しています。 1912 * また、ユーザー個別にシステムパラメータを変更できます。この取得は、 1913 * システムパラメータとして取得します。(値はユーザー個別値を返します。) 1914 * 1915 * ※ システムパラメータの値が数字でない場合、HybsSystemException が throw されます。 1916 * ※ キーの値が nullの場合、HybsSystemException が throw されます。 1917 * 1918 * @og.rev 4.0.0.0 (2005/11/30) 新規追加 1919 * 1920 * @param key システム設定 キー 1921 * 1922 * @return システム設定値(int型) 1923 */ 1924 protected int sysInt( final String key ) { 1925 String tmp = null; 1926 int rtn ; 1927 try { 1928 tmp = sys( key ); 1929 rtn = Integer.parseInt( tmp ); 1930 } 1931 catch( NumberFormatException ex ) { 1932 String errMsg = "システムパラメータの値が数字ではありません。" + HybsSystem.CR 1933 + " Resource key=[" + key + "] val=[" + tmp + "]" ; 1934 throw new HybsSystemException( errMsg,ex ); // 3.5.5.4 (2004/04/15) 引数の並び順変更 1935 } 1936 catch( IllegalArgumentException ex ) { 1937 String errMsg = "キーの値が null です。key=[" + key + "] val=[" + tmp + "]"; 1938 throw new HybsSystemException( errMsg,ex ); // 3.5.5.4 (2004/04/15) 引数の並び順変更 1939 } 1940 1941 return rtn; 1942 } 1943 1944 /** 1945 * session に、処理開始時刻を設定します。 1946 * これは、DBTableModel を登録する場合に、一連の処理が連続であるかどうかを 1947 * 判断する時に使用します。 1948 * 処理が一連でない(start 時のタイムスタンプが書き換えられている)場合は、 1949 * DBTableModel の登録処理を行いません。 1950 * なお、判断処理を行うのは、scope が session の場合のみです。 1951 * 判定は、commitTableObject( String ,DBTableModel ) で行います。 1952 * 1953 * @og.rev 3.6.0.8 (2004/11/19) 新規追加 1954 * @og.rev 4.3.0.0 (2008/07/04) fileUD 対応。 1955 * @og.rev 5.1.6.0 (2010/05/01) DBLastSqlの処理は、DBTableModelが新規作成された処理でのみ行う。 1956 * 1957 * @param tableId キー 1958 * @see #commitTableObject( String ,DBTableModel ) 1959 */ 1960 protected void startQueryTransaction( final String tableId ) { 1961 if( "session".equals( scope ) ) { 1962 startTransaction = Long.valueOf( System.currentTimeMillis() ); 1963 setSessionAttribute( tableId+"_TRANSACTION", startTransaction ); 1964 } 1965 1966 // 5.1.6.0 (2010/05/01) DBLastSqlの処理の見直し 1967 if( useTrans ) { 1968 // 4.3.0.0 (2008/07/04) fileUD 対応 1969 removeSessionAttribute( HybsSystem.DB_LAST_SQL_KEY ); // 無条件削除 1970 } 1971 } 1972 1973 /** 1974 * スコープに応じて登録されている DBTableModel を指定のキーでセットします。 1975 * これは、startQueryTransaction( String ) でセッションに登録した処理開始時刻と、 1976 * このオブジェクト自身が持っている(セッションに登録した開始時刻そのもの)を 1977 * 比較し、異なる場合は、DBTableModel の登録を行いません。 1978 * これにより、検索処理の開始順にしか登録しないようなロジックを入れています。 1979 * 検索処理時間が掛かるSQLを実行した場合、先に検索した結果があとから登録される 1980 * ケースがあるためです。 1981 * また、判断処理を行うのは、scope が session の場合のみです。 1982 * 1983 * @og.rev 3.6.0.8 (2004/11/19) 新規追加 1984 * @og.rev 3.8.1.1 (2005/11/21) ExcelOut の整合性を取る為の仕掛け 1985 * @og.rev 4.3.0.0 (2008/07/04) fileUD 対応。 1986 * @og.rev 5.1.6.0 (2010/05/01) DBLastSqlの処理は、DBTableModelが新規作成された処理でのみ行う。 1987 * 1988 * @param tableId キー 1989 * @param table 登録するDBTableModelオブジェクト 1990 * 1991 * @return 正常に登録(true) / 一連でないため登録していない(false) 1992 * @see #startQueryTransaction( String ) 1993 */ 1994 protected boolean commitTableObject( final String tableId ,final DBTableModel table ) { 1995 // 登録しないケースをピックアップします。 1996 if( "session".equals( scope ) ) { 1997 String key = tableId+"_TRANSACTION"; 1998 Long endTime = (Long)getSessionAttribute( key ); 1999 removeSessionAttribute( key ); 2000 if( endTime == null || 2001 startTransaction == null || 2002 endTime.compareTo( startTransaction ) != 0 ) { 2003 String msg = "CommonTagSupport Query処理が割り込まれました。DBTableModel は登録しません。" 2004 + "[" + getUser().getUserID() + "]," 2005 + "[" + getGUIInfoAttri( "KEY" ) + "]" // 4.0.0 (2005/01/31) 2006 + "[" + startTransaction + "]" // 4.0.0 (2005/01/31) 2007 + "[" + endTime + "]"; // 4.0.0 (2005/01/31) 2008 System.out.println( msg ); 2009 return false; 2010 } 2011 // 3.8.1.1 (2005/11/21) ExcelOut の整合性を取る為の仕掛け 2012 if( table != null && HybsSystem.TBL_MDL_KEY.equals( tableId ) ) { 2013 String consisKey = table.getConsistencyKey(); 2014 setSessionAttribute( HybsSystem.TBL_MDL_CONKEY,consisKey ); 2015 } 2016 } 2017 2018 // 4.3.0.0 (2008/07/04) fileUD 対応 2019 // 5.1.6.0 (2010/05/01) DBLastSqlの処理の見直し 2020 if( useTrans && table != null ) { 2021 String guikey = getGUIInfoAttri( "KEY" ); 2022 DBLastSql lastSql = new DBLastSql( scope,guikey,table.isOverflow(),tableId ); 2023 setSessionAttribute( HybsSystem.DB_LAST_SQL_KEY,lastSql ); 2024 } 2025 2026 setObject( tableId,table ); 2027 return true; 2028 } 2029 2030 /** 2031 * 表示データの HybsSystem.ROW_SEL_KEY を元に、選ばれた 行番号の 2032 * 配列を返します。 2033 * 配列情報は、行番号でソートされて返されます。 2034 * なにも選ばれていない場合は、サイズ0の配列を返します。 2035 * 2036 * @og.rev 4.0.0.0 (2005/01/31) 新規追加 2037 * 2038 * @return (選ばれていない場合は、サイズ0の配列を返す) 2039 */ 2040 protected int[] getParameterRows() { 2041 if( rowNo != null ) { return rowNo; } 2042 2043 rowNo = (int[])getRequestAttribute( HybsSystem.ROW_SEL_KEY ); 2044 if( rowNo != null ) { return rowNo; } 2045 2046 String[] selected = getRequestValues( HybsSystem.ROW_SEL_KEY ) ; 2047 if( selected != null && selected.length != 0 ) { 2048 rowNo = new int[ selected.length ]; 2049 for( int i=0; i<selected.length; i++ ) { 2050 if( selected[i] != null && selected[i].length() > 0 ) { 2051 rowNo[i] = Integer.parseInt( selected[i] ); 2052 } 2053 } 2054 Arrays.sort( rowNo ); 2055 } 2056 else { 2057 rowNo = new int[0]; 2058 } 2059 2060 return rowNo; 2061 } 2062 2063 /** 2064 * 表示データの HybsSystem.ROW_SEL_KEY に対して、選ばれた 行番号の 2065 * 配列を設定します。 2066 * ここで設定した選択配列は、getParameterRows() メソッドで取得する場合、優先されます。 2067 * 2068 * @og.rev 4.0.0.0 (2005/01/31) 新規追加 2069 * 2070 * @param rowNo 行番号配列 2071 */ 2072 protected void setParameterRows( final int[] rowNo ) { 2073 setRequestAttribute( HybsSystem.ROW_SEL_KEY , rowNo ); 2074 } 2075 2076 /** 2077 * 指定のクッキーをセットします。 2078 * これは、従来,各Taglibパッケージで使用していました、ErrorMessage オブジェクトを、 2079 * HTMLテーブル形式で表示する為に、DBUtilクラスや、ViewFormクラスなど、複数のクラスを 2080 * 複雑に組み合わせて使用していましたが、一つの static メソッドにまとめたものです。 2081 * 2082 * @og.rev 3.7.0.3 (2005/03/01) 新規登録 2083 * 2084 * @param key クッキーのキー 2085 * @param value クッキーの設定値 2086 * @param maxage 最長存続期間を秒単位で設定(負の値は Cookie を保存しない、 0 なら Cookie を削除する) 2087 */ 2088 protected void setCookie( final String key,final String value,final int maxage ) { 2089 HttpServletResponse res = (HttpServletResponse)pageContext.getResponse(); 2090 Cookie ck = new Cookie( key, value ); 2091 ck.setMaxAge( maxage ); // 有効秒 2092 res.addCookie( ck ); 2093 } 2094 2095 /** 2096 * 指定のクッキーを取得します。 2097 * 見つからない場合は、null を返します。 2098 * 2099 * @og.rev 3.7.0.3 (2005/03/01) 新規登録 2100 * 2101 * @param key クッキーのキー 2102 * 2103 * @return クッキーの設定値 2104 */ 2105 protected String getCookie( final String key ) { 2106 HttpServletRequest req = (HttpServletRequest)pageContext.getRequest(); 2107 Cookie[] cks = req.getCookies(); 2108 2109 String val = null; 2110 for( int i=0; i<cks.length; i++ ) { 2111 Cookie ck = cks[i]; 2112 if( ck.getName().equals( key ) ) { 2113 val = ck.getValue(); 2114 break; 2115 } 2116 } 2117 return val ; 2118 } 2119 2120 /** 2121 * リクエスト情報の クォーティション(') 存在チェックを実施するかどうか[true/false]を設定します 2122 * (初期値:USE_SQL_INJECTION_CHECK[={@og.value org.opengion.hayabusa.common.SystemData#USE_SQL_INJECTION_CHECK}])。 2123 * 2124 * SQLインジェクション対策の一つとして、暫定的ではありますが、SQLのパラメータに 2125 * 渡す文字列にクォーティション(') を許さない設定にすれば、ある程度は防止できます。 2126 * 数字タイプの引数には、 or 5=5 などのクォーティションを使用しないコードを埋めても、 2127 * 数字チェックで検出可能です。文字タイプの場合は、必ず (')をはずして、 2128 * ' or 'A' like 'A のような形式になる為、(')チェックだけでも有効です。 2129 * (') が含まれていたエラーにする(true)/かノーチェックか(false)を指定します。 2130 * (初期値:システム定数のUSE_SQL_INJECTION_CHECK[={@og.value org.opengion.hayabusa.common.SystemData#USE_SQL_INJECTION_CHECK}])。 2131 * 2132 * @og.rev 4.0.0.0 (2005/08/31) 新規追加 2133 * 2134 * @param flag クォーティションチェック [true:する/:falseしない] 2135 * @see org.opengion.hayabusa.common.SystemData#USE_SQL_INJECTION_CHECK 2136 */ 2137 protected void useQuotCheck( final boolean flag ) { 2138 quotCheck = flag; 2139 } 2140 2141 /** 2142 * リクエスト情報の HTMLTag開始/終了文字(><) 存在チェックを実施するかどうか[true/false]を設定します 2143 * (初期値:USE_XSS_CHECK[={@og.value org.opengion.hayabusa.common.SystemData#USE_XSS_CHECK}])。 2144 * 2145 * クロスサイトスクリプティング(XSS)対策の一環としてless/greater than signについてのチェックを行います。 2146 * (><) が含まれていたエラーにする(true)/かノーチェックか(false)を指定します。 2147 * 現在の実装としてはリクエストパラメータのみチェックして、attributesに対しては行いません。 2148 * (初期値:システム定数のUSE_XSS_CHECK[={@og.value org.opengion.hayabusa.common.SystemData#USE_XSS_CHECK}])。 2149 * 2150 * @og.rev 5.0.0.2 (2009/09/15) 新規追加 2151 * 2152 * @param flag XSSチェック [true:する/false:しない] 2153 * @see org.opengion.hayabusa.common.SystemData#USE_XSS_CHECK 2154 */ 2155 protected void useXssCheck( final boolean flag ) { 2156 xssCheck = flag; 2157 } 2158 2159 /** 2160 * 日付関係の情報を簡易的に取り出す処理を行います。 2161 * 2162 * これは、{@DATE.XXXX AA BB CC} 引数処理をおこなうための、サポートメソッドです。 2163 * XXXX は結果のフォーマット、AA が基準時刻で省略した場合は、現在時刻が利用されます。 2164 * BB 引数は、日付についての加減算処理を行うためのコマンドです。 2165 * CC 引数は、BB引数のコマンドに付属するパラメータです。加減算処理の数値を指定できます。 2166 * AA,BB,CC 引数については、先頭に、@ を付ける事で、リクエスト変数が使用できます。 2167 * 2168 * 引数は、"XXXX AA BB" という状態で受け取ります。(DATE. ははずした形) 2169 * "XXXX" は、日付処理を行うキー文字列で予約語になっています。 2170 * ・YMD :8文字の4-2-2年月日データ(yyyyMMdd)を扱います。 2171 * ・Y2MD :6文字の2-2-2年月日データ(yyMMdd)を扱います。 2172 * ・YM :6文字の4-2年月データ(yyyyMM)を扱います。 2173 * ・HMS :6文字の2-2-2時分秒データ(HHmmss)を扱います。 2174 * ・YMDHMS :14文字の4-2-2-2-2-2年月日時分秒データ(yyyyMMddHHmmss)を扱います。 2175 * ・EEE :曜日をデフォルトロケール(EEE)で表示します。 2176 * 2177 * F付きは、フォーマットされた日付を返します。 2178 * ・YMDF :10文字の日付表現(yyyy/MM/dd)を扱います。 2179 * ・Y2MDF :8文字の日付表現(yy/MM/dd)を扱います。 2180 * ・YMF :7文字の日付表現(yyyy/MM)を扱います。 2181 * ・HMSF :8文字の時刻表現(HH:mm:ss)を扱います。 2182 * ・YMDHMSF:19文字の日付表現(yyyy/MM/dd HH:mm:ss)を扱います。 2183 * ・MDF :5文字の月日表現(MM/dd)を扱います。 2184 * ・MDEF :5文字+曜日の月日表現(MM/dd(EEE))を扱います。 2185 * ・MD2F :和暦の月日表現(MM月dd日)を扱います。(5.5.5.2 追加) 2186 * ・GYMDF :和暦の年月日表現(GGGGyyyy年MM月dd日)を扱います。 2187 * ・G2YMDF :和暦の日付表現(Gyyyy/MM/dd)を扱います。 2188 * ・GYMF :和暦の年月表現(GGGGyyyy年MM月)を扱います。 2189 * ・GYF :和暦の年表現(GGGGyyyy)を扱います。 2190 * 2191 * なお、上記以外のフォーマットを指定する場合は、XXXX部分に直接記述できます。(5.5.5.2 追加) 2192 * ただし、スペースで分解するため、フォーマットにスペースを含む場合は、ダブルコーテーション等で 2193 * くくる等の処理が必要です。基本的には、自由フォーマットは、エラーチェックがない為、使わないでください。 2194 * 2195 * 第二引数 AA は、基準となる日付を、yyyyMMdd形式で指定します。nullの場合は、現在時刻を使用します。 2196 * 指定できる日付は、yyyyMMdd形式を推奨しますが、'/' , '-' , ' ' , ':' を削除して使います。 2197 * 6桁の場合は、yyyyMM + 01 とし、8ケタの場合は、yyyyMMdd とし、14ケタ以上の場合は、前半14文字を 2198 * yyyyMMddHHmmss として処理します。それ以外の桁数の場合は、エラーになります。 2199 * たとえば、"2012/09/05 16:52:36" のようなフォーマットデータの場合、'/' , '-' , ' ' , ':' を削除して 2200 * "20120905165236" に変換後、日付オブジェクトに変換されます。 2201 * 2202 * AA には、数字で始まる(20050701など)実日付と@で始まるパラメータが使用できます。 2203 * @AA と記述することで、{@AA}で指定する場合と同様のリクエストパラメータが使用できます。 2204 * このパラメータの値の解析結果が、null の場合は、現在時刻が使用されます。 2205 * 数字以外の場合は、省略されたと判断して、コマンド(BB引数)として使用されます。 2206 * 2207 * BB 引数は、日付についての加減算処理を行います。 2208 * 省略すると、なにも加減算処理を行いません。 2209 * この引数もパラメータ(@BB)指定で、リクエストパラメータが使用できます。 2210 * 加減算処理のパラメータが使用できるのは、"H" , "D" , "M" の1文字パラメータの場合のみです。 2211 * それ以外のコマンドで、加減算処理する場合は、独立した CC 引数 を使用してください。 2212 * ・SD :当月の最初の日付にセットします。(当月1日)。CC引数は、-N:N月前、0:当月(=SD)、N:N月後、-1:BSD と同じ、1:ASD と同じ 2213 * ・ED :当月の最後の日付にセットします。(当月月末)。CC引数は、-N:N月前、0:当月(=ED)、N:N月後、-1:BED と同じ、1:AED と同じ 2214 * ・SW :日付処理の週初め(月曜日)にセットします。日付は当日より前に移動します。CC引数は、-N:N週前、0:今週(=SW)、N:N週後 2215 * ・EW :日付処理の週末(日曜日)にセットします。日付は当日より後ろに移動します。CC引数は、-N:N週前、0:今週(=EW)、N:N週後 2216 * ・H1 ~ HXXX :時を指定の分だけ進めます。H1なら1時間後、H24 なら24時間後(5.5.5.6 (2012/08/31) 追加) 2217 * ・D1 ~ DXXX :日を指定の分だけ進めます。D1なら翌日、D200 なら200日後 2218 * ・M1 ~ MXXX :月を指定の分だけ進めます。M1なら翌月、M6 なら半年後 2219 * ・BSD :(有閑)先月の最初の日付にセットします。(先月1日)(5.5.5.2 追加)。SD -1 と同等 2220 * ・BED :(有閑)先月の最後の日付にセットします。(先月月末)(5.5.5.2 追加)。ED -1 と同等 2221 * ・ASD :(有閑)翌月の最初の日付にセットします。(翌月1日)(5.5.5.2 追加)。SD 1 と同等 2222 * ・AED :(有閑)翌月の最後の日付にセットします。(翌月月末)(5.5.5.2 追加)。ED 1 と同等 2223 * 2224 * CC 引数は、特別な処理で、BB 引数に対して、加算、減算のための数字を指定できます。(5.7.4.1 (2014/03/14) 追加) 2225 * 従来は、BB 引数が、"H" , "D" , "M" の 1文字パラメータの場合のみ利用可能でした。 2226 * これは、"H15" と指定するのと、"H" "15" と指定するのと同じ意味になります。 2227 * 異なるのは、CC 引数も、(@CC)指定で、リクエストパラメータが使用できます。 2228 * 従来は、文字列として結合された状態でしか、BB 引数を渡せませんでしたが、この、CC 引数の 2229 * 追加で、日付の加減算を、パラメータ指定できるようになります。 2230 * 数字以外の文字が指定されたり、パラメータの解析結果が NULL の場合には、BB引数自体も無視されます。 2231 * 注意点は、各 BB 引数に応じて、数字の意味が異なるという事です。 2232 * 2233 * HXXX,DXXX,MXXX 形式に、CC 引数を付けた場合は、XXX にさらに加算されます。 2234 * prmB に、数字を使用した場合、(コマンドでない場合)にも、CC 引数は、加算されます。 2235 * 2236 * @og.rev 3.8.0.2 (2005/07/11) 新規追加 2237 * @og.rev 5.4.0.1 (2011/11/01) 日付処理の機能追加(BB 引数に、リクエストパラメータ対応) 2238 * @og.rev 5.5.0.2 (2012/03/09) 和暦対応 2239 * @og.rev 5.5.5.2 (2012/08/18) XXXXフォーマット追加、自由フォーマット対応、BB引数追加、/,-削除機能追加、SM,EM廃止 2240 * @og.rev 5.5.5.6 (2012/08/31) H1 ~ HXXX 追加。時間の加算を指定できる。 2241 * @og.rev 5.5.7.2 (2012/10/09) HybsDateUtil を利用するように修正します。 2242 * @og.rev 5.5.8.2 (2012/11/09) prmA の判定に、null と ゼロ文字列を判定する。 2243 * @og.rev 5.6.0.1 (2013/01/11) 5.5.7.2でyyyyMMddしか取っていないため、HHmmssを追加します 2244 * @og.rev 5.7.4.1 (2014/03/14) AA 引数の@解析後のコマンド判定方法を、8ケタ以下から先頭が数字以外に変更します。 2245 * @og.rev 5.7.4.1 (2014/03/14) CC 引数を、"H" , "D" , "M" 以外でも使用できるように拡張します。 2246 * 2247 * @param value パラメータ 2248 * 2249 * @return メッセージ情報 2250 * @see org.opengion.fukurou.util.HybsDateUtil#getDateFormat( String,String,String,int ) 2251 */ 2252 protected String getDateFormat( final String value ) { 2253 // {@DATE.XXXX AA BB CC} を分割 2254 String[] vals = StringUtil.csv2Array( value,' ' ); // ダブルクオート内は保持される。 2255 2256 String key = vals[0] ; 2257 2258 // 5.7.4.1 (2014/03/14) 初期化時に、vals を設定しておきます。 2259 String prmA = (vals.length >= 2) ? vals[1] : null ; 2260 String prmB = (vals.length >= 3) ? vals[2] : null ; 2261 String prmC = (vals.length >= 4) ? vals[vals.length-1] : null ; // 互換性。最後の値が、CC引数 2262 2263 if( prmA != null && prmA.startsWith( "@" ) ) { 2264 prmA = getRequestValue( prmA.substring(1) ); 2265 } 2266 2267 if( prmB != null && prmB.startsWith( "@" ) ) { 2268 prmB = getRequestValue( prmB.substring(1) ); 2269 } 2270 2271 if( prmC != null && prmC.startsWith( "@" ) ) { 2272 prmC = getRequestValue( prmC.substring(1) ); 2273 } 2274 2275 // 5.7.4.1 (2014/03/14) AA 引数の@解析後のコマンド判定方法を、8ケタ以下から先頭が数字以外に変更します。 2276 if( prmA != null && prmA.length() > 0 ) { 2277 char chA = prmA.charAt(0); 2278 if( chA < '0' || chA > '9' ) { // 先頭が、数字以外の場合は、コマンドなので、一つずつずらす。 2279 prmC = prmB; 2280 prmB = prmA; 2281 prmA = null; 2282 } 2283 } 2284 2285 // 5.7.4.1 (2014/03/14) CC 引数を、"H" , "D" , "M" 以外でも使用できるように拡張します。 2286 int intC = 0; 2287 if( prmC != null && prmC.length() > 0 ) { 2288 try { 2289 intC = Integer.parseInt( prmC ); 2290 } 2291 catch( NumberFormatException ex ) { 2292 String errMsg = "CC引数が数字ではありません。value=[" + value + "]" 2293 + ex.getMessage() ; 2294 System.err.println( errMsg ); 2295 } 2296 } 2297 2298 // prmA が null か、isEmpty() の場合は、現在時刻が使用される。 2299 return HybsDateUtil.getDateFormat( key,prmA,prmB,intC ); // 5.7.4.1 (2014/03/14) CC 引数を拡張します。 2300 } 2301 2302 /** 2303 * debug や エラー時に参考にする、簡易リファレンスへのリンクを作成します。 2304 * リンクを行うタグの名称は、getTagName() メソッドより取得します。 2305 * 2306 * @og.rev 4.0.0.0 (2005/01/31) 新規追加 2307 * @og.rev 4.2.1.0 (2008/04/11) URLを相対パスに変更 2308 * 2309 * @return 簡易リファレンスへのリンク 2310 * @see #getTagName() 2311 */ 2312 protected String getDocumentLink() { 2313 String name = getTagName(); 2314 2315 // try { 2316 // Field fld = getClass().getDeclaredField( "VERSION" ) ; 2317 // version = (String)fld.get( null ); 2318 // } 2319 // catch( Exception ex ) { 2320 // version = ex.toString(); 2321 // } 2322 2323 // org.opengion.hayabusa.taglib.AbcdTag というクラス名より、abcd を取り出す。 2324 StringBuilder buf = new StringBuilder( HybsSystem.BUFFER_SMALL ); 2325 buf.append( "<br /><a href=\"../common/documents.html#VAL_" ); 2326 buf.append( name ); 2327 buf.append( "\" target=\"_brank\" >簡易リファレンス[" ); 2328 buf.append( name ); 2329 buf.append( "] " ); 2330 // buf.append( version ); 2331 buf.append( "</a>" ).append( HybsSystem.BR ); 2332 2333 return buf.toString(); 2334 } 2335 2336 /** 2337 * タグの名称を、返します。 2338 * これは、debug や エラー時に参考にする、簡易リファレンスへのリンクを作成する場合に 2339 * 使用します。 2340 * 通常は、org.opengion.hayabusa.taglib.AbcdTag という自分自身のクラス名より、 2341 * abcd の部分を取り出し、返します。 2342 * クラス名とタグ名が、上記変換ルールと異なる場合は、このメソッドを 2343 * 使用して、直接 abcd の部分に相当する文字列を返すようにしてください。 2344 * 2345 * @og.rev 4.0.0.0 (2005/01/31) 新規追加 2346 * 2347 * @return タグの名称 2348 * @see #getDocumentLink() 2349 */ 2350 protected String getTagName() { 2351 String name = getClass().getName(); 2352 int adrs = name.lastIndexOf('.'); 2353 2354 // org.opengion.hayabusa.taglib.AbcdTag というクラス名より、abcd を取り出す。 2355 return name.substring( adrs+1,adrs+2 ).toLowerCase(Locale.JAPAN) 2356 + name.substring( adrs+2,name.length()-3 ) ; 2357 } 2358 2359 /** 2360 * リクエストに対して、画面遷移なしモードを有効にします[true/false]。 2361 * この情報は画面IDをキーにセッションに保存されるため、 2362 * 各タグで共有することができます。 2363 * 2364 * @og.rev 4.3.3.0 (2008/10/01) 新規作成 2365 * @og.rev 4.3.8.0 (2009/08/01) リクエストからセッションに変更(名称も変更) 2366 * @og.rev 5.1.3.0 (2010/02/01) noTransition、ajaxSubmitのコントロールは、requestで行う。 2367 * 2368 * @param flg 画面遷移なしモードを使用するか [true:有効/false:無効] 2369 */ 2370 protected void setNoTransitionRequest( final boolean flg ) { 2371 setRequestAttribute( HybsSystem.NO_TRANSITION_MODE_KEY, String.valueOf( flg )); 2372 } 2373 2374 /** 2375 * リクエストで画面遷移なしモードが有効になっているかを返します。 2376 * この情報はセッションから画面IDをキーに取得します。 2377 * セッションに情報が設定されていない(#setNoTransition()が呼ばれていない)場合は、 2378 * falseを返します。 2379 * 2380 * @og.rev 4.3.3.0 (2008/10/01) 新規作成 2381 * @og.rev 4.3.8.0 (2009/08/01) リクエストからセッションに変更 2382 * @og.rev 5.1.3.0 (2010/02/01) noTransition、ajaxSubmitのコントロールは、requestで行う。 2383 * 2384 * @return 画面遷移なしモードが有効 2385 */ 2386 protected boolean isNoTransitionRequest() { 2387 return nval( (String)getRequestAttribute( HybsSystem.NO_TRANSITION_MODE_KEY ), false ); 2388 } 2389 2390 /** 2391 * リクエストに対して、AjaxSubmitモードを使用するかどうか指定します[true/false]。 2392 * この情報は画面IDをキーにセッションに保存されるため、 2393 * 各タグで共有することができます。 2394 * 2395 * @og.rev 4.3.8.0 (2009/08/01) 新規作成 2396 * @og.rev 5.1.3.0 (2010/02/01) noTransition、ajaxSubmitのコントロールは、requestで行う。 2397 * 2398 * @param flg AjaxSubmitモードを使用するか [true:使用する/false:使用しない] 2399 */ 2400 protected void setAjaxSubmitRequest( final boolean flg ) { 2401 setRequestAttribute( HybsSystem.USE_AJAX_SUBMIT_KEY, String.valueOf( flg )); 2402 } 2403 2404 /** 2405 * リクエストでAjaxSubmitモードが有効になっているかを返します。 2406 * この情報はセッションから画面IDをキーに取得します。 2407 * セッションに情報が設定されていない(#setNoTransition()が呼ばれていない)場合は、 2408 * falseを返します。 2409 * 2410 * @og.rev 4.3.8.0 (2009/08/01) 新規作成 2411 * @og.rev 5.1.3.0 (2010/02/01) noTransition、ajaxSubmitのコントロールは、requestで行う。 2412 * 2413 * @return AjaxSubmitモードが有効 2414 */ 2415 protected boolean isAjaxSubmitRequest() { 2416 return nval( (String)getRequestAttribute( HybsSystem.USE_AJAX_SUBMIT_KEY ), false ); 2417 } 2418 2419 /** 2420 * シリアライズ用のカスタムシリアライズ書き込みメソッド 2421 * 2422 * @og.rev 4.0.0.0 (2006/09/31) 新規追加 2423 * @serialData 一部のオブジェクトは、シリアライズされません。 2424 * 2425 * @param strm ObjectOutputStreamオブジェクト 2426 */ 2427 private void writeObject( final ObjectOutputStream strm ) throws IOException { 2428 strm.defaultWriteObject(); 2429 } 2430 2431 /** 2432 * シリアライズ用のカスタムシリアライズ読み込みメソッド 2433 * 2434 * ここでは、transient 宣言された内部変数の内、初期化が必要なフィールドのみ設定します。 2435 * 2436 * @og.rev 4.0.0.0 (2006/09/31) 新規追加 2437 * @serialData 一部のオブジェクトは、シリアライズされません。 2438 * 2439 * @param strm ObjectInputStreamオブジェクト 2440 * @see #release2() 2441 */ 2442 private void readObject( final ObjectInputStream strm ) throws IOException , ClassNotFoundException { 2443 strm.defaultReadObject(); 2444 attri = new Attributes(); 2445 } 2446 2447 /** 2448 * アクセスログ取得の為,ApplicationInfoオブジェクトを返します。 2449 * 見つからない場合は、null が返ります。(暫定対応) 2450 * 2451 * @og.rev 3.8.7.0 (2006/12/15) 新規追加 2452 * 2453 * @return アクセスログ取得の為の管理オブジェクト 2454 */ 2455 protected ApplicationInfo getApplicationInfo() { 2456 String gamenId = getGUIInfoAttri( "KEY" ); 2457 String jspId = (String)getSessionAttribute( "JSPID" ); 2458 2459 return getUser().getApplicationInfo( gamenId,jspId ); 2460 } 2461 2462 /** 2463 * イベントカラムの実行に必要なカラム情報をマップに登録します。 2464 * 2465 * @og.rev 5.1.7.0 (2010/06/01) 動的プルダウン実装見直し 2466 * 2467 * @param col DBカラム 2468 */ 2469 protected void addEventColumn( final DBColumn col ) { 2470 addEventColumn( col.getName(), col.getEventColumn(), col.getEventURL() 2471 , col.getRenderer(), col.getEditor(), col.getRawRendParam(), col.getRawEditParam() ); 2472 } 2473 2474 /** 2475 * イベントカラムの実行に必要なカラム情報をマップに登録します。 2476 * 2477 * @og.rev 5.1.7.0 (2010/06/01) 動的プルダウン実装見直し 2478 * 2479 * @param name カラム名 2480 * @param evCol イベントカラム名 2481 * @param url イベントURL 2482 * @param renderer カラムのレンデラー 2483 * @param editor カラムのエディター 2484 * @param rendParam カラムの表示パラメーター 2485 * @param editParam カラムの編集パラメーター 2486 */ 2487 @SuppressWarnings(value={"unchecked"}) 2488 protected void addEventColumn( final String name, final String evCol, final String url, final String renderer, final String editor, final String rendParam, final String editParam ) { 2489 if( evCol == null || evCol.length() == 0 ){ return; } 2490 2491 String key = (String)getRequestAttribute( HybsSystem.USE_EVENT_COLUMN_KEY ); 2492 if( key == null || key.length() == 0 ) { 2493 key = HybsSystem.USE_EVENT_COLUMN_KEY + System.currentTimeMillis(); 2494 setRequestAttribute( HybsSystem.USE_EVENT_COLUMN_KEY, key ); 2495 } 2496 2497 Map<String, DBEventColumn> evColMap = (Map<String, DBEventColumn>)( getSessionAttribute( key ) ); 2498 if( evColMap == null ){ 2499 evColMap = new HashMap<String,DBEventColumn>(); 2500 } 2501 if( evColMap.get( name ) == null ) { 2502 evColMap.put( name, new DBEventColumn( name, evCol, url, renderer, editor, rendParam, editParam ) ); 2503 } 2504 setSessionAttribute( key, evColMap ); 2505 } 2506 2507 /** 2508 * 各データベースに対応するファンクション名を返します。 2509 * 2510 * @og.rev 4.3.7.0 (2009/06/01) 新規作成 2511 * @og.rev 5.1.4.0 (2010/03/01) データベース名 でなく、DBID 名で検索するようにします。 2512 * 2513 * @param key ファンクション名(定義文字) 2514 * 2515 * @return 実ファンクション名 2516 */ 2517 protected String getDBFunctionName( final String key ) { 2518 int idx = key.indexOf( ' ' ); 2519 String func = null; 2520 String dbid = null; 2521 if( idx >= 0 ) { 2522 func = key.substring( 0, idx ); 2523 dbid = key.substring( idx+1, key.length() ); 2524 if( dbid.charAt(0) == '@' ) { dbid = getRequestValue( dbid.substring( 1 ) ); } 2525 } 2526 else { 2527 func = key; 2528 } 2529 // 5.1.4.0 (2010/03/01) データベース名 でなく、DBID 名で検索する。 2530 return DBFunctionName.getFunctionName( func, dbid ); 2531 } 2532 2533 /** 2534 * データロールの設定に基づき、キー(カラム名)に対応する条件式を返します。 2535 * 2536 * @og.rev 4.4.0.0 (2009/08/02) 新規作成 2537 * 2538 * @param key カラム名 2539 * 2540 * @return 条件式 2541 */ 2542 protected String getDataCondition( final String key ) { 2543 return getUser().getDataCondition( key ); 2544 } 2545 2546 /** 2547 * 与えたIPアドレスからホスト名を取得して返します。 2548 * 取得できなかった場合は空文字を返します。 2549 * IPアドレスが解決できない場合や、セキュリティマネージャーで 2550 * 許可されていない場合はエラーを返します。 2551 * 2552 * @og.rev 5.6.6.2 (2013/07/19) 新規作成 2553 * 2554 * @param ip IPアドレス 2555 * 2556 * @return ホスト名(取得できない場合は空文字) 2557 */ 2558 protected String getHostName( final String ip ) { 2559 String hostname = ""; 2560 try{ 2561 hostname = InetAddress.getByName(ip).getHostName(); 2562 } 2563 catch(UnknownHostException ex){ 2564 String errMsg = "IPアドレスが解決できません。" 2565 + ex.getMessage(); 2566 throw new HybsSystemException( errMsg,ex ); 2567 } 2568 catch(SecurityException ex){ 2569 String errMsg = "この操作はセキュリティ上許可されていません。" 2570 + ex.getMessage(); 2571 throw new HybsSystemException( errMsg,ex ); 2572 } 2573 return hostname; 2574 } 2575 2576 /** 2577 * このオブジェクトの文字列表現を返します。 2578 * 基本的にデバッグ目的に使用します。 2579 * 2580 * @return このクラスの文字列表現 2581 */ 2582 @Override 2583 public String toString() { 2584 return org.opengion.fukurou.util.ToString.title( this.getClass().getName() ) 2585 .println( "Other..." ,getAttributes().getAttribute() ) 2586 .fixForm().toString() ; 2587 } 2588}