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     */
016    package org.opengion.hayabusa.taglib;
017    
018    import org.opengion.hayabusa.common.HybsSystem;
019    import org.opengion.hayabusa.common.HybsSystemException;
020    import org.opengion.hayabusa.db.DBTableModel;
021    import org.opengion.hayabusa.db.DBColumn;
022    import org.opengion.hayabusa.db.Query;
023    import org.opengion.hayabusa.db.QueryFactory;
024    import org.opengion.fukurou.util.XHTMLTag;
025    import org.opengion.fukurou.util.Attributes;
026    import org.opengion.fukurou.db.Transaction;
027    import org.opengion.fukurou.db.TransactionReal;
028    
029    import static org.opengion.fukurou.util.StringUtil.nval ;
030    
031    import java.io.ObjectOutputStream;
032    import java.io.ObjectInputStream;
033    import java.io.IOException;
034    
035    /**
036     * プルãƒ?‚¦ãƒ³ãƒ¡ãƒ‹ãƒ¥ãƒ¼ã®é¸æŠžé?目をSELECTæ–??çµæžœã‹ã‚‰ä½œæ?ã™ã‚‹ã‚¿ã‚°ã§ã™ã?
037     *
038     * 基本çš?«ã¯ã€?½‘ueryã‚¿ã‚°ã¨åŒã˜ä½¿ã?–¹ã‚’ã—ã¾ã™ã?
039     * ã“ã?オブジェクトã«ã€?queryId を与ãˆã‚‹ã“ã¨ã«ã‚ˆã‚Šã€queryId ã«å¯¾å¿œã—ã?Queryオブジェクãƒ?
040     * (ã®ã‚µãƒ–クラスã®ã‚ªãƒ–ジェクãƒ?ãŒä½œæ?ã•れã¾ã™ã?
041     * ã“ã“ã§æŒ?®šã™ã‚‹SELECTæ–??ã€ã?SELECT KEYã€LABEL1ã€LABEL2ã€?½¥?¥?¥ FROM TABLE ?¥?¥?¥ã€å½¢å¼?ã‚?
042     * ã—ã¦ã?‚‹å¿?¦ãŒã‚りã¾ã™ã?特別ãªã‚±ãƒ¼ã‚¹ã¨ã—ã¦ã€ã?SELECT KEY FROM TABLE ?¥?¥?¥ã€å½¢å¼ã?å ´åˆã?ã€?
043     * LABEL ã« KEY ã?使用ã•れã¾ã™ã?
044     * SystemData ã® USE_SQL_INJECTION_CHECK ã?true ã‹ã?quotCheck 属æ?ã?true ã®å ´åˆã?ã€?
045     * ?³?±?¬ã‚¤ãƒ³ã‚¸ã‚§ã‚¯ã‚·ãƒ§ãƒ³å¯¾ç­–用ã®ã‚¯ã‚©ãƒ¼ãƒ?‚£ã‚·ãƒ§ãƒ³ãƒã‚§ãƒ?‚¯ã‚’行ã„ã¾ã™ã?リクエスト引数ã«
046     * クォーãƒ?‚£ã‚·ãƒ§ãƒ³(')ãŒå«ã¾ã‚Œã‚‹ã¨ã€ã‚¨ãƒ©ãƒ¼ã«ãªã‚Šã¾ã™ã?
047     * åŒæ§˜ã«USE_XSS_CHECKãŒtrueã‹ã?xssCheck属æ?ãŒtrueã®å ´åˆã?ã€?
048     * クロスサイトススクリプティング(XSS)対策ã?ãŸã‚less/greater than signã®ãƒã‚§ãƒ?‚¯ã‚’行ã„ã¾ã™ã?
049     *
050     * ※ ã“ã?ã‚¿ã‚°ã¯ã€Transaction ã‚¿ã‚°ã®å¯¾è±¡ã§ã™ã?
051     *
052     * @og.formSample
053     * â—å½¢å¼ï¼?
054     *     <og:queryOption >
055     *          SELECTæ–?
056     *     </og:queryOption >
057     * â—body?šã‚ã‚?EVAL_BODY_BUFFERED:BODYを評価ã—ã?{@XXXX} ã‚’è§£æžã—ã¾ã?
058     *
059     * â—Tag定義??
060     *   <og:queryOption
061     *       value              ã€TAG】Optionã®åˆæœŸå€¤ã§é¸ã°ã‚Œã‚‹å€¤ã‚’指定ã—ã¾ã?
062     *       separator          ã€TAG】è¤?•°ã®ãƒ©ãƒ™ãƒ«ã‚’åˆæˆã™ã‚‹ã¨ãã«ä½¿ç”¨ã™ã‚‹é ?›®åŒºåˆ?‚Šæ–?­—ã‚’ã‚»ãƒ?ƒˆã—ã¾ã?åˆæœŸå€¤:スペã?ス)
063     *       defaultVal         ã€TAG】value値ãŒNULLã®å ´åˆã«ä½¿ç”¨ã•れるå?期å?を設定ã—ã¾ã?
064     *       language           ã€TAG】タグå†?ƒ¨ã§ä½¿ç”¨ã™ã‚‹è¨?ªžã‚³ãƒ¼ãƒ‰[ja/en/zh/…]を指定ã—ã¾ã?
065     *       quotCheck          ã€TAG】リクエスト情報㮠クォーãƒ?‚£ã‚·ãƒ§ãƒ³(') 存在ãƒã‚§ãƒ?‚¯ã‚’実施ã™ã‚‹ã‹ã©ã?‹[true/false]を設定ã—ã¾ã?(åˆæœŸå€¤:USE_SQL_INJECTION_CHECK[=true])
066     *       dbid               ã€TAGã€?通常ã¯ä½¿ã?¾ã›ã‚“)Queryオブジェクトを作æ?ã™ã‚‹æ™‚ã?DB接続IDを指定ã—ã¾ã?
067     *       addKey             ã€TAG】é?ç›®ãŒä¸?¤ã?‘ã®å ´åˆã??—ï¾ï¾žï¾™ï¾˜ï½¿?°?½ã«ã€ã‚­ãƒ¼æƒ??を追åŠ?™ã‚‹ã‹ã©ã?‹ã‚’指定ã—ã¾ã?åˆæœŸå€¤:false)
068     *       classUseNo         ã€TAG】オプションã«è¿½åŠ?™ã‚?class 属æ?㮠カラãƒ?•ªå·ã‚’指定ã—ã¾ã?
069     *       groupUseNo         ã€TAG】オプションã®ã‚°ãƒ«ãƒ¼ãƒ—化を行ã†ã‚«ãƒ©ãƒ?•ªå·ã‚’指定ã—ã¾ã?
070     *       titleUseNo         ã€TAG】オプションã«è¿½åŠ?™ã‚?title 属æ?㮠カラãƒ?•ªå·ã‚’指定ã—ã¾ã?
071     *       xssCheck           ã€TAG】リクエスト情報㮠HTMLTagé–‹å§?終äº?–‡å­?><) 存在ãƒã‚§ãƒ?‚¯ã‚’実施ã™ã‚‹ã‹ã©ã?‹[true/false]を設定ã—ã¾ã?(åˆæœŸå€¤:USE_XSS_CHECK[=true])
072     *       caseKey            ã€TAG】ã“ã®ã‚¿ã‚°è‡ªä½“を利用ã™ã‚‹ã‹ã©ã?‹ã®æ¡ä»¶ã‚­ãƒ¼ã‚’指定ã—ã¾ã?åˆæœŸå€¤:null)
073     *       caseVal            ã€TAG】ã“ã®ã‚¿ã‚°è‡ªä½“を利用ã™ã‚‹ã‹ã©ã?‹ã®æ¡ä»¶å€¤ã‚’指定ã—ã¾ã?åˆæœŸå€¤:null)
074     *       caseNN             ã€TAG】指定ã?値ãŒã?null/ゼロæ–?­—å? ã§ãªã??å?Not Null=NN)ã¯ã€ã“ã®ã‚¿ã‚°ã¯ä½¿ç”¨ã•れã¾ã?åˆæœŸå€¤:true)
075     *       caseNull           ã€TAG】指定ã?値ãŒã?null/ゼロæ–?­—å? ã®å ´åˆã?ã€ã“ã®ã‚¿ã‚°ã¯ä½¿ç”¨ã•れã¾ã?åˆæœŸå€¤:true)
076     *       debug              ã€TAG】デãƒãƒƒã‚°æƒ??ã‚’å?力ã™ã‚‹ã‹ã©ã?‹[true/false]を指定ã—ã¾ã?åˆæœŸå€¤:false)
077     *   >   ... Body ...
078     *   </og:queryOption>
079     *
080     * â—使用ä¾?
081     *     <og:select name="CDC" >
082     *         <og:queryOption>
083     *                 select NOSYN,NOSYN,NMSYN from DB01 ORDER BY 1
084     *         </og:queryOption>
085     *     </og:select>
086     *
087     *     <og:select name="CDC" >                é¸æŠžé?ç›®ã®ä¸?•ªä¸Šã«ç©ºç™½ã‚’ã‚»ãƒ?ƒˆã—ãŸã?¨ãoptionã‚¿ã‚°ã‚’çµ?ˆã›ã‚‹ã“ã¨ã‚‚å¯èƒ½ã§ã™ã?
088     *         <og:option lbl="" />               åˆæœŸå€¤ã‚’設定ã—ãŸã„ã¨ãã?value属æ?を使ã?¾ã™ã?
089     *         <og:queryOption value="61200" separator=":" >
090     *                 select CDBK,CDBK,NMBK from DB02 ORDER BY 1
091     *         </og:queryOption>
092     *     </og:select>
093     *
094     * @og.group é¸æŠžãƒ‡ãƒ¼ã‚¿åˆ¶å¾¡
095     *
096     * @version  4.0
097     * @author   Kazuhiko Hasegawa
098     * @since    JDK5.0,
099     */
100    public class QueryOptionTag extends CommonTagSupport {
101            //* ã“ã?プログラãƒ??VERSIONæ–?­—å?を設定ã—ã¾ã™ã?       {@value} */
102            private static final String VERSION = "5.7.1.0 (2013/12/06)" ;
103    
104            private static final long serialVersionUID = 571020131206L ;
105    
106            private transient DBTableModel  table           = null;
107            private String  selValue        = null;
108            private String  defaultVal      = null;
109            // 4.0.0.0 (2007/10/10) dbid ã®åˆæœŸå€¤ã‚’ã?"DEFAULT" ã‹ã‚‰ null ã«å¤‰æ›´
110    //      private String  dbid            = "DEFAULT";
111            private String  dbid            = null;
112            private String  sql                     = null;
113            private String  separator       = " ";          // é ?›®åŒºåˆ?‚Šæ–?­?
114            private boolean quotCheck       = HybsSystem.sysBool( "USE_SQL_INJECTION_CHECK" );      // 4.0.0 (2005/08/31)
115            private int             classUseNo      = -1;   // 3.8.5.2 (2006/06/09) オプションã«è¿½åŠ?™ã‚‹ã‚¯ãƒ©ã‚¹å±žæ?
116            private int             groupUseNo      = -1;   // 3.8.5.2 (2006/06/09) キーブレイク時ã«è¿½åŠ?™ã‚‹ã‚°ãƒ«ãƒ¼ãƒ—æ–‡å­?
117            private boolean addKey          = false;                // 4.0.0 (2006/11/15) é ?›®ä¸?¤ã®ã¨ãã«?—ï¾ï¾žï¾™ï¾˜ï½¿?°?½è¡¨ç¤ºæ™‚ã«ã‚­ãƒ¼ã‚‚付加ã™ã‚‹ã€?
118            private int             titleUseNo              = -1;   // 4.3.8.0 (2009/08/01) オプションã®title属æ?
119            private boolean xssCheck        = HybsSystem.sysBool( "USE_XSS_CHECK" );        // 5.0.0.2 (2009/09/15)
120            private String  rawSql          = null; // 5.1.7.0 (2010/06/01) 動的プルãƒ?‚¦ãƒ³å®Ÿè£?¦‹ç›´ã?
121    
122            /**
123             * Taglibã®é–‹å§‹ã‚¿ã‚°ãŒè¦‹ã¤ã‹ã£ãŸã¨ãã«å‡¦ç?™ã‚?doStartTag() ã‚?オーãƒã?ライドã—ã¾ã™ã?
124             *
125             * @og.rev 5.2.2.0 (2010/11/01) caseKey ã€caseVal 属æ?対å¿?
126             *
127             * @return      後続å?ç??æŒ?¤º( EVAL_BODY_BUFFERED )
128             */
129            @Override
130            public int doStartTag() {
131                    // 5.2.2.0 (2010/11/01) caseKey ã€caseVal 属æ?対å¿?
132                    if( useTag() ) {
133                            return( EVAL_BODY_BUFFERED );   // Body を評価ã™ã‚‹ã€? extends BodyTagSupport æ™?
134                    }
135                    return ( SKIP_BODY );                           // Body を評価ã—ãªã?
136            }
137    
138            /**
139             * Taglibã®ã‚¿ã‚°æœ¬ä½“を処ç?™ã‚?doAfterBody() ã‚?オーãƒã?ライドã—ã¾ã™ã?
140             *
141             * @og.rev 3.1.1.0 (2003/03/28) ボディã®å†?®¹ã‚’å–å¾—ã™ã‚‹å?ç?‚’ã€CommonTagSupport ã§è¡Œã†ã€?
142             * @og.rev 3.6.0.8 (2004/11/19) エラー発生時ã«ç¢ºå®Ÿã«ãƒªãƒªãƒ¼ã‚¹ã•れるよã?« try finally 追åŠ?
143             * @og.rev 3.7.1.0 (2005/04/26) DBTableModel ãŒã™ã§ã«ã‚»ãƒ?ƒˆã•れã¦ã?‚‹å ´åˆã?ã€SQL処ç?¸è¦ã?
144             * @og.rev 4.0.0.0 (2005/01/31) lang â‡?ResourceManager ã¸å¤‰æ›´
145             * @og.rev 4.0.0.0 (2005/08/31) useQuotCheck() ã«ã‚ˆã‚‹?³?±?¬ã‚¤ãƒ³ã‚¸ã‚§ã‚¯ã‚·ãƒ§ãƒ³å¯¾ç­?
146             * @og.rev 3.8.6.3 (2006/11/30) SQL æ–??å‰å¾Œã?スペã?スをå–り除ãã¾ã™ã?
147             * @og.rev 3.8.7.0 (2006/12/15) アクセスログå–å¾—ã?為,ApplicationInfoオブジェクトを設å®?
148             * @og.rev 4.3.6.0 (2009/04/01) EventColumn対�
149             * @og.rev 5.0.0.5 (2009/08/28) XSS対�
150             * @og.rev 5.1.7.0 (2010/06/01) 動的プルãƒ?‚¦ãƒ³å®Ÿè£?¦‹ç›´ã?
151             * @og.rev 5.1.9.0 (2010/08/01) TransactionTag 対応ã?上ä½ã« TransactionTag ãŒã‚れã?ã€ãã“ã‹ã‚‰Connection をもらã†ã€?
152             * @og.rev 5.3.7.0 (2011/07/01) TransactionReal ã®å¼•数変更
153             * @og.rev 5.3.8.0 (2011/08/01) Transaction発生ç®?‰€ã§close()
154             *
155             * @return      後続å?ç??æŒ?¤º(SKIP_BODY)
156             */
157            @Override
158            public int doAfterBody() {
159                    // 3.7.1.0 (2005/04/26) DBTableModel ãŒã™ã§ã«ã‚»ãƒ?ƒˆã•れã¦ã?‚‹å ´åˆã?ã€SQL処ç?¸è¦ã?
160                    if( table != null ) { return(SKIP_BODY); }
161    
162                    // 4.0.0 (2005/08/31) useQuotCheck() ã«ã‚ˆã‚‹?³?±?¬ã‚¤ãƒ³ã‚¸ã‚§ã‚¯ã‚·ãƒ§ãƒ³å¯¾ç­?
163                    useQuotCheck( quotCheck );
164                    // 5.0.0.2 (2009/09/15) XSS対�
165                    useXssCheck( xssCheck );
166    
167                    sql = getBodyString().trim();
168    //              String rawsql = getBodyRawString().trim(); // 4.3.6.0 生ã?SQLã‚’ä¿æŒ
169                    rawSql = getBodyRawString().trim();
170    
171                    // 4.3.6.0 (2009/04/01) ã‚»ãƒ?‚·ãƒ§ãƒ³ã¸ã®SQLæ–?™»éŒ²
172                    // 5.1.7.0 (2010/06/01) 動的プルãƒ?‚¦ãƒ³å®Ÿè£?¦‹ç›´ã?
173    //              String[] selectVals = getEventColumn(); // 親タグã‹ã‚‰ã‚¤ãƒ™ãƒ³ãƒˆã‚«ãƒ©ãƒ?¨­å®šã‚’å–ã‚‹
174    //              if( selectVals[0] != null && selectVals[0].length() > 0 ){
175    //                      addEventColumnSQL( selectVals[1], rawsql );
176    //              }
177    
178                    Query query = QueryFactory.newInstance();               // 4.0.0 (2005/01/31)
179                    Transaction tran = null;
180                    try {
181                            // 5.1.9.0 (2010/08/01) TransactionTag 対�
182    //                      final Transaction tran ;
183                            TransactionTag tranTag = (TransactionTag)findAncestorWithClass( this,TransactionTag.class );
184                            if( tranTag == null ) {
185    //                              tran = new TransactionReal( dbid,getApplicationInfo() );
186                                    tran = new TransactionReal( getApplicationInfo() );             // 5.3.7.0 (2011/07/01) 引数変更
187                            }
188                            else {
189                                    tran = tranTag.getTransaction();
190                            }
191                            query.setTransaction( dbid,tran );      // 5.1.9.0 (2010/08/01) TransactionTag 対�
192    
193    //                      query.setConnectionID( dbid );
194                            query.setResourceManager( getResource() );      // 4.0.0 (2005/01/31)
195    
196                            query.setStatement( sql );
197    //                      query.setApplicationInfo( getApplicationInfo() );       // 3.8.7.0 (2006/12/15)
198                            query.execute();
199    
200                            table = query.getDBTableModel();
201    
202                            // 4.0.0 (2005/11/30) æ¤œç´¢çµæžœã®ä»¶æ•°ã‚’ã?"DB.COUNT" キーã§ãƒªã‚¯ã‚¨ã‚¹ãƒˆã«ã‚»ãƒ?ƒˆã™ã‚‹ã€?
203                    }
204                    finally {
205    //                      if( query != null ) { query.close(); }
206                            QueryFactory.close( query );
207                            if( tran != null ) { tran.close(); }            // 5.3.8.0 (2011/08/01) Transaction発生ç®?‰€ã§close()
208                    }
209                    return(SKIP_BODY);
210            }
211    
212            /**
213             * Taglibã®çµ‚äº?‚¿ã‚°ãŒè¦‹ã¤ã‹ã£ãŸã¨ãã«å‡¦ç?™ã‚?doEndTag() ã‚?オーãƒã?ライドã—ã¾ã™ã?
214             *
215             * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応ã?release2() ã‚?doEndTag()ã§å‘¼ã¶ã€?
216             * @og.rev 3.3.2.0 (2003/07/07) defaultVal 属æ?ã®è¿½åŠ??
217             * @og.rev 3.5.4.0 (2003/11/25) selVal 属æ?を追åŠ??
218             * @og.rev 5.0.2.0 (2009/11/01) è¤?•°ãƒ‘ラメーターã®é¸æŠžã«å¯¾å¿?
219             * @og.rev 5.1.7.0 (2010/06/01) 動的プルãƒ?‚¦ãƒ³å®Ÿè£?¦‹ç›´ã?
220             * @og.rev 5.2.2.0 (2010/11/01) caseKey ã€caseVal 属æ?対å¿?
221             * @og.rev 5.7.1.0 (2013/12/06) SelectTag â‡?OptionAncestorIF ã«å¤‰æ›´ã—ã¦ã€DatalistTag ã«ã‚‚対応ã?
222             *
223             * @return      後続å?ç??æŒ?¤º
224             */
225            @Override
226            public int doEndTag() {
227                    debugPrint();           // 4.0.0 (2005/02/28)
228                    // 5.2.2.0 (2010/11/01) caseKey ã€caseVal 属æ?対å¿?
229                    if( useTag() ) {
230    //                      SelectTag select = (SelectTag)findAncestorWithClass( this,SelectTag.class );
231                            OptionAncestorIF select = (OptionAncestorIF)findAncestorWithClass( this,OptionAncestorIF.class );
232                            if( select == null ) {
233    //                              String errMsg = "ã“ã?ã‚¿ã‚°ã¯ã€SelectTag ã®BODY ã«è¨˜è¿°ã™ã‚‹å¿?¦ãŒã‚りã¾ã™ã?";
234                                    String errMsg = "<b>" + getTagName() + "ã‚¿ã‚°ã¯ã€SelectTag ã¾ãŸã?ã€DatalistTag ã®BODY ã«è¨˜è¿°ã™ã‚‹å¿?¦ãŒã‚りã¾ã™ã?</b>";
235                                    throw new HybsSystemException( errMsg );
236                            }
237                            String selVal = nval( select.getValue(),defaultVal );   // 3.5.4.0 (2003/11/25)
238            //              selValue = nval( selValue,selVal );                                             // 3.5.4.0 (2003/11/25)
239                            selValue = "|" + nval( selValue,selVal ) + "|";                 // 5.0.2.0 (2009/11/01)
240                            makeLabel( select );
241    
242                            // 5.1.7.0 (2010/06/01) 動的プルãƒ?‚¦ãƒ³å®Ÿè£?¦‹ç›´ã?
243                            select.setRawParam( rawSql );
244                    }
245                    return(EVAL_PAGE);
246            }
247    
248            /**
249             * タグリブオブジェクトをリリースã—ã¾ã™ã?
250             * キャãƒ?‚·ãƒ¥ã•れã¦å†åˆ©ç”¨ã•れるã?ã§ã€ãƒ•ィールドã?åˆæœŸè¨­å®šã‚’行ã„ã¾ã™ã?
251             *
252             * @og.rev 2.0.0.4 (2002/09/27) カスタãƒ?‚¿ã‚°ã® release() メソãƒ?ƒ‰ã‚’ã?追åŠ?
253             * @og.rev 3.0.1.0 (2003/03/03) セパレーターを指定ã§ãる様ã«å¤‰æ›´ã€?
254             * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応ã?release2() ã‚?doEndTag()ã§å‘¼ã¶ã€?
255             * @og.rev 3.3.2.0 (2003/07/07) defaultVal 属æ?ã®è¿½åŠ??
256             * @og.rev 3.8.5.2 (2006/06/09) classUseNo , groupUseNo 属æ?ã®è¿½åŠ??
257             * @og.rev 4.0.0.0 (2005/08/31) quotCheck , addKey 属æ?ã®è¿½åŠ?
258             * @og.rev 4.0.0.0 (2007/10/10) dbid ã®åˆæœŸå€¤ã‚’ã?"DEFAULT" ã‹ã‚‰ null ã«å¤‰æ›´
259             * @og.rev 5.1.7.0 (2010/06/01) 動的プルãƒ?‚¦ãƒ³å®Ÿè£?¦‹ç›´ã?
260             *
261             */
262            @Override
263            protected void release2() {
264                    super.release2();
265                    table           = null;
266                    selValue        = null;
267                    defaultVal      = null;
268    //              dbid            = "DEFAULT";
269                    dbid            = null;
270                    sql                     = null;
271                    separator       = " ";
272                    classUseNo      = -1;   // 3.8.5.2 (2006/06/09) オプションã«è¿½åŠ?™ã‚‹ã‚¯ãƒ©ã‚¹å±žæ?
273                    groupUseNo      = -1;   // 3.8.5.2 (2006/06/09) キーブレイク時ã«è¿½åŠ?™ã‚‹ã‚°ãƒ«ãƒ¼ãƒ—æ–‡å­?
274                    quotCheck       = HybsSystem.sysBool( "USE_SQL_INJECTION_CHECK" );      // 4.0.0 (2005/08/31)
275                    addKey          = false;                // 4.0.0 (2006/11/15) é ?›®ä¸?¤ã®ã¨ãã«?—ï¾ï¾žï¾™ï¾˜ï½¿?°?½è¡¨ç¤ºæ™‚ã«ã‚­ãƒ¼ã‚‚付加ã™ã‚‹ã€?
276                    titleUseNo              = -1;
277                    xssCheck        = HybsSystem.sysBool( "USE_XSS_CHECK" );        // 5.0.0.2 (2009/09/15)
278                    rawSql          = null; // 5.1.7.0 (2010/06/01) 動的プルãƒ?‚¦ãƒ³å®Ÿè£?¦‹ç›´ã?
279            }
280    
281            /**
282             * DBTableModelã‚’ã‚»ãƒ?ƒˆã—ã¾ã™ã?
283             *
284             * サブクラスよりã€DBTableModelã‚’ã‚»ãƒ?ƒˆã™ã‚‹ã®ã«ä½¿ã?¾ã™ã?
285             *
286             * @og.rev 3.7.1.0 (2005/04/26) æ–°è¦è¿½åŠ?
287             *
288             * @param       table   DBTableModelオブジェク�
289             */
290            protected void setTableModel( final DBTableModel table ) {
291                    this.table = table ;
292            }
293    
294            /**
295             * オプションを作æ?ã—ã¾ã™ã?
296             *
297             * DBTableModel ã®?‘番目ã®å€¤ã‚?"value" ã«ã€ãれ以é™ã‚’æ–?­—å?ã‚’é?çµã•ã›ã¦
298             * BODY属æ? ã«ç™»éŒ²ã™ã‚‹Optionを作æ?ã—ã¾ã™ã?
299             *
300             * @og.rev 3.0.1.0 (2003/03/03) 『SELECT KEY FROM TABLE ?¥?¥?¥ã€å½¢å¼ã?å ´åˆã?ã€LABEL ã« KEY を使用ã€?
301             * @og.rev 3.8.0.9 (2005/10/17) è¤?•°é¸æŠžå¯èƒ½æ™‚ã«å…¨é¸æŠžã‚’設定ã™ã‚‹ã?
302             * @og.rev 3.8.5.2 (2006/06/09) classUseNo 属æ?㨠groupUseNo 属æ?を追åŠ?
303             * @og.rev 3.8.9.2 (2007/07/28) グループã¨ã€ã‚¯ãƒ©ã‚¹ã®è¨­å®šæ–¹æ³•ã?ãƒã‚°ä¿®æ­£
304             * @og.rev 4.3.8.0 (2009/08/01) titleUseNo属æ?追åŠ?
305             * @og.rev 5.0.2.0 (2009/11/01) è¤?•°ãƒ‘ラメーターã®é¸æŠžã«å¯¾å¿?
306             * @og.rev 5.7.1.0 (2013/12/06) SelectTag â‡?OptionAncestorIF ã«å¤‰æ›´ã—ã¦ã€DatalistTag ã«ã‚‚対応ã?
307             *
308             * @param   select SelectTagオブジェク�
309             */
310    //      private void makeLabel( final SelectTag select ) {
311            private void makeLabel( final OptionAncestorIF select ) {
312                    boolean multipleAll = select.isMultipleAll();   // 3.8.0.9 (2005/10/17)
313                    int rowCnt = table.getRowCount();               // 3.5.5.7 (2004/05/10)
314    
315                    String bkGroupKey = "";
316                    String grpLabel ;
317                    for( int row=0; row<rowCnt; row++ ) {
318                            // 3.8.5.2 (2006/06/09) groupUseNo 属æ?
319                            if( groupUseNo >= 0 ) {
320                                    String groupKey = table.getValue( row,groupUseNo );
321                                    grpLabel = getRendererValue( row,groupUseNo );
322                                    if( !bkGroupKey.equals( groupKey ) ) {          // キーブレイク
323                                            // 3.8.9.2 (2007/07/28) グループã¨ã€ã‚¯ãƒ©ã‚¹ã®è¨­å®šæ–¹æ³•ã?ãƒã‚°ä¿®æ­£
324    //                                      bkGroupKey = groupKey;
325    //                                      if( row != 0 ) { select.addOption( "</optgroup>" ); }
326    //                                      select.addOption( "<optgroup label=\"" + grpLabel + "\">" );
327    
328                                            if( ! "".equals( bkGroupKey ) ) {
329                                                    select.addOption( "</optgroup>" );
330                                            }
331                                            if( ! "".equals( groupKey ) ) {
332                                                    select.addOption( "<optgroup label=\"" + grpLabel + "\">" );
333                                            }
334                                            bkGroupKey = groupKey;
335                                    }
336                            }
337    
338                            Attributes attri = new Attributes();
339                            String value = table.getValue( row,0 );
340                            attri.set( "value", value );
341    
342                            // 5.0.2.0 (2009/11/01)
343    //                      if( ( selValue != null && selValue.equals( value ) ) || multipleAll ) {
344                            if( ( selValue != null && selValue.length() > 0 && selValue.indexOf( "|" + value + "|" ) >= 0 ) || multipleAll ) {
345                                    attri.set( "selected", "selected" );
346                            }
347    
348                            // 3.8.5.2 (2006/06/09) classUseNo 属æ?
349                            if( classUseNo >= 0 ) {
350                                    attri.add( "class", table.getValue( row,classUseNo ) );
351                            }
352    
353                            StringBuilder buf = new StringBuilder( HybsSystem.BUFFER_MIDDLE );
354                            boolean titleFlg = false; // 4.3.8.0 (2009/08/01) title属æ?を付ã‘ã‚‹ã‹ã©ã?‹
355                            if( table.getColumnCount() == 1 ) {
356                                    // é ?›®ãŒä¸?¤ã® queryOption ã§ã¯ã€ãƒ©ãƒ™ãƒ«ãƒªã‚½ãƒ¼ã‚¹ãŒä½¿ç”¨ã•れã¾ã™ã?
357                                    if( addKey ) { buf.append( value ).append( ":" ); }
358                                    buf.append( getResource().getLabel( value ) );
359    
360                                    // 4.3.8.0 (2009/08/01) titleUseNo 属æ? ã‚»ãƒ?ƒˆã•れã¦ã?‚‹å ´åˆã‹ã¤ãƒ©ãƒ™ãƒ«ã¨ç•°ãªã‚‹å?åˆã?title属æ?ã«è¿½åŠ?
361                                    if( titleUseNo >= 0 && !getResource().getLabel( value ).equals( table.getValue( row,titleUseNo ) )) {
362                                            titleFlg = true;
363                                    }
364                            }
365                            else {
366            //                      if( groupUseNo >= 0 ) {
367            //                              buf.append( grpLabel );
368            //                              buf.append( separator );
369            //                      }
370                                    String label = getRendererValue( row,1 );
371                                    buf.append( label );
372            //                      attri.set( "label", label );
373                                    for( int clm=2; clm<table.getColumnCount(); clm++ ) {
374                                            // 4.3.8.0 (2009/08/01) titleUseNo追�
375                                            // if( clm == groupUseNo || clm == classUseNo ) { continue; }
376                                            if( clm == groupUseNo || clm == classUseNo || clm==titleUseNo) { continue; }
377                                            buf.append( separator );
378                                            buf.append( getRendererValue( row,clm ) );
379                                    }
380    
381                                    // 4.3.8.0 (2009/08/01) titleUseNo 属æ? ã‚»ãƒ?ƒˆã•れã¦ã?‚‹å ´åˆã‹ã¤ãƒ©ãƒ™ãƒ«ã¨ç•°ãªã‚‹å?åˆã?title属æ?ã«è¿½åŠ?
382                                    if( titleUseNo >= 0 && !label.equals( table.getValue( row,titleUseNo ) )) {
383                                            titleFlg = true;
384                                    }
385                            }
386    
387                            // 4.3.7.2 (2009/06/22) タイトル属æ?ã‚»ãƒ?ƒˆ
388                            if( titleFlg ){
389                                    attri.add( "title", table.getValue( row,titleUseNo ) );
390                            }
391    
392                            attri.set( "body", buf.toString() );
393                            select.addOption( XHTMLTag.option( attri ) );
394                    }
395    //              if( groupUseNo >= 0 && "".equals( bkGroupKey ) ) {
396                    if( groupUseNo >= 0 && ! "".equals( bkGroupKey ) ) { // 3.8.9.2 (2007/07/28)
397                            select.addOption( "</optgroup>" );
398                    }
399            }
400    
401            /**
402             * ã€TAG】Optionã®åˆæœŸå€¤ã§é¸ã°ã‚Œã‚‹å€¤ã‚’指定ã—ã¾ã™ã?
403             *
404             * @og.tag Optionã®åˆæœŸå€¤ã§é¸ã°ã‚Œã‚‹å€¤ã‚’指定ã—ã¾ã™ã?
405             *
406             * @param   val Optionã®åˆæœŸå€¤ã§é¸ã°ã‚Œã‚‹å€¤
407             */
408            public void setValue( final String val ) {
409                    selValue = getRequestParameter( val );
410            }
411    
412            /**
413             * ã€TAG】value値ãŒNULLã®å ´åˆã«ä½¿ç”¨ã•れるå?期å?を設定ã—ã¾ã™ã?
414             *
415             * @og.tag
416             * value値ãŒNULLã®å ´åˆã«ã€ã“ã®åˆæœŸå€¤ã‚’ã‚»ãƒ?ƒˆã—ã¾ã™ã?
417             *
418             * @og.rev 3.3.2.0 (2003/07/07) defaultVal 属æ?ã®è¿½åŠ??(æ–°è¦ä½œæ?)
419             *
420             * @param       val åˆæœŸå€¤
421             */
422            public void setDefaultVal( final String val ) {
423                    defaultVal = getRequestParameter( val );
424            }
425    
426            /**
427             * ã€TAG】è¤?•°ã®ãƒ©ãƒ™ãƒ«ã‚’åˆæˆã™ã‚‹ã¨ãã«ä½¿ç”¨ã™ã‚‹é ?›®åŒºåˆ?‚Šæ–?­—ã‚’ã‚»ãƒ?ƒˆã—ã¾ã?åˆæœŸå€¤:スペã?ス)ã€?
428             *
429             * @og.tag
430             * åˆæœŸå€¤ã¯ã€ã‚¹ãƒšã?スã§ã™ã?
431             *
432             * @og.rev 3.0.1.0 (2003/03/03) セパレーターを指定ã§ãる様ã«å¤‰æ›´ã€?
433             *
434             * @param   sep é ?›®åŒºåˆ?‚Šæ–?­?
435             */
436            public void setSeparator( final String sep ) {
437                    separator = nval( getRequestParameter( sep ),separator );
438            }
439    
440            /**
441             * ã€TAG】オプションã«è¿½åŠ?™ã‚?class 属æ?㮠カラãƒ?•ªå·ã‚’指定ã—ã¾ã™ã?
442             *
443             * @og.tag
444             * オプションã¯ã€ãƒ‡ãƒ¼ã‚¿ãƒ™ã?スを検索ã—ã¦ä½œæ?ã•れã¾ã™ãŒã€ãã®SQLæ–??カラãƒ?ƒ…å ±ã‚?
445             * 使用ã—㦠オプション㫠class 属æ?を追åŠ?—ã¾ã™ã?
446             * å?‚ªãƒ—ションã«è‰²ã‚’ã¤ã‘ã‚‹å ´åˆã?ã€ã“ã® class 属æ?ã«å¯¾å¿œã™ã‚?CSS ファイルを用æ„ã—ã¾ã™ã?
447             * ã“ã“ã§ã¯ã€class 属æ?ã«ä½¿ç”¨ã™ã‚‹ SQLæ–?? カラãƒ?•ªå·( å…ˆé?ã?0 ) を指定ã—ã¾ã™ã?
448             * 通常ã€ã‚«ãƒ©ãƒ?•ªå·=0 㯠キーæƒ??ã€?1 ã¯ãƒ©ãƒ™ãƒ«æƒ?? ã§ã™ã?2 ã?3 を指定ã—ã¾ã™ã?
449             * åˆæœŸå€¤ã¯ã€ä½¿ç”¨ã—ãªã?-1)ã§ã™ã?
450             *
451             * @og.rev 3.8.5.2 (2006/06/09) æ–°è¦è¿½åŠ?
452             *
453             * @param   no オプションã«è¿½åŠ?™ã‚‹ã‚¯ãƒ©ã‚¹å±žæ?
454             */
455            public void setClassUseNo( final String no ) {
456                    classUseNo = nval( getRequestParameter( no ),classUseNo );
457                    if( classUseNo == 0 || classUseNo == 1 ) {
458                            String errMsg = "通常ã€ã‚«ãƒ©ãƒ?•ªå·=0 㯠キーæƒ??ã€?1 ã¯ãƒ©ãƒ™ãƒ«æƒ?? ã§ã™ã?2 ã?3 を指定ã—ã¦ä¸‹ã•ã??";
459                            throw new HybsSystemException( errMsg );
460                    }
461            }
462    
463            /**
464             * ã€TAG】オプションã®ã‚°ãƒ«ãƒ¼ãƒ—化を行ã†ã‚«ãƒ©ãƒ?•ªå·ã‚’指定ã—ã¾ã™ã?
465             *
466             * @og.tag
467             * オプションã¯ã€ãƒ‡ãƒ¼ã‚¿ãƒ™ã?スを検索ã—ã¦ä½œæ?ã•れã¾ã™ãŒã€ãã®SQLæ–??カラãƒ?ƒ…å ±ã‚?
468             * 使用ã—㦠オプションをグループ化ã—ã¾ã™ã?グループ化㯠optgroupè¦ç´?‚’ブレイク時ã«
469             * 出力ã™ã‚‹äº‹ã§å¯¾å¿œã—ã¾ã™ã?
470             * ã“ã“ã§ã¯ã€ã‚°ãƒ«ãƒ¼ãƒ—化ã«ä½¿ç”¨ã™ã‚‹ SQLæ–?? カラãƒ?•ªå·( å…ˆé?ã?0 ) を指定ã—ã¾ã™ã?
471             * 通常ã€ã‚«ãƒ©ãƒ?•ªå·=0 㯠キーæƒ??ã€?1 ã¯ãƒ©ãƒ™ãƒ«æƒ?? ã§ã™ã?2 ã?3 を指定ã—ã¾ã™ã?
472             * åˆæœŸå€¤ã¯ã€ä½¿ç”¨ã—ãªã?-1)ã§ã™ã?
473             *
474             * @og.rev 3.8.5.2 (2006/06/09) æ–°è¦è¿½åŠ?
475             *
476             * @param   no キーブレイク時ã«è¿½åŠ?™ã‚‹ã‚°ãƒ«ãƒ¼ãƒ—æ–‡å­?
477             */
478            public void setGroupUseNo( final String no ) {
479                    groupUseNo = nval( getRequestParameter( no ),groupUseNo );
480                    if( groupUseNo == 0 || groupUseNo == 1 ) {
481                            String errMsg = "通常ã€ã‚«ãƒ©ãƒ?•ªå·=0 㯠キーæƒ??ã€?1 ã¯ãƒ©ãƒ™ãƒ«æƒ?? ã§ã™ã?2 ã?3 を指定ã—ã¦ä¸‹ã•ã??";
482                            throw new HybsSystemException( errMsg );
483                    }
484            }
485    
486            /**
487             * ã€TAG】リクエスト情報㮠クォーãƒ?‚£ã‚·ãƒ§ãƒ³(') 存在ãƒã‚§ãƒ?‚¯ã‚’実施ã™ã‚‹ã‹ã©ã?‹[true/false]を設定ã—ã¾ã?
488             *              (åˆæœŸå€¤:USE_SQL_INJECTION_CHECK[={@og.value org.opengion.hayabusa.common.SystemData#USE_SQL_INJECTION_CHECK}])ã€?
489             *
490             * @og.tag
491             * ?³?±?¬ã‚¤ãƒ³ã‚¸ã‚§ã‚¯ã‚·ãƒ§ãƒ³å¯¾ç­–ã?ä¸?¤ã¨ã—ã¦ã€æš«å®šçš„ã§ã¯ã‚りã¾ã™ãŒã€SQLã®ãƒ‘ラメータã«
492             * æ¸¡ã™æ–‡å­—å?ã«ã‚¯ã‚©ãƒ¼ãƒ?‚£ã‚·ãƒ§ãƒ³(') を許ã•ãªã?¨­å®šã«ã™ã‚Œã°ã€ã‚る程度ã¯é˜²æ­¢ã§ãã¾ã™ã?
493             * 数字タイプã?引数ã«ã¯ã€?or 5=5 ãªã©ã®ã‚¯ã‚©ãƒ¼ãƒ?‚£ã‚·ãƒ§ãƒ³ã‚’使用ã—ãªã?‚³ãƒ¼ãƒ‰ã‚’埋ã‚ã¦ã‚‚ã?
494             * æ•°å­—ãƒã‚§ãƒ?‚¯ã§æ¤œå?å¯èƒ½ã§ã™ã?æ–?­—タイプã?å ´åˆã?ã€å¿?š (')ã‚’ã?ãšã—ã¦ã€?
495             * ' or 'A' like 'A ã®ã‚ˆã†ãªå½¢å¼ã«ãªã‚‹ç‚ºã€?')ãƒã‚§ãƒ?‚¯ã?‘ã§ã‚‚有効ã§ã™ã?
496             * (') ãŒå«ã¾ã‚Œã¦ã?Ÿã‚¨ãƒ©ãƒ¼ã«ã™ã‚‹(true)?ã‹ãƒŽã?ãƒã‚§ãƒ?‚¯ã?false)を指定ã—ã¾ã™ã?
497             * (åˆæœŸå€¤:シスãƒ?ƒ å®šæ•°ã®USE_SQL_INJECTION_CHECK[={@og.value org.opengion.hayabusa.common.SystemData#USE_SQL_INJECTION_CHECK}])ã€?
498             *
499             * @og.rev 4.0.0.0 (2005/08/31) æ–°è¦è¿½åŠ?
500             *
501             * @param   flag クォーãƒ?‚£ã‚·ãƒ§ãƒ³ãƒã‚§ãƒ?‚¯ [true:ã™ã‚‹/ãれ以å¤?ã—ãªã„]
502             * @see         org.opengion.hayabusa.common.SystemData#USE_SQL_INJECTION_CHECK
503             */
504            public void setQuotCheck( final String flag ) {
505                    quotCheck = nval( getRequestParameter( flag ),quotCheck );
506            }
507    
508            /**
509             * ã€TAGã€?通常ã¯ä½¿ã?¾ã›ã‚“)Queryオブジェクトを作æ?ã™ã‚‹æ™‚ã?DB接続IDを指定ã—ã¾ã™ã?
510             *
511             * @og.tag
512             * Queryオブジェクトを作æ?ã™ã‚‹æ™‚ã?DB接続IDを指定ã—ã¾ã™ã?
513             * ã“れã¯ã€ã‚·ã‚¹ãƒ?ƒ ãƒªã‚½ãƒ¼ã‚¹ã§ã€DEFAULT_DB_URL ç­‰ã§æŒ?®šã—ã¦ã?‚‹ ãƒ??タベã?ス接続å?
514             * æƒ??ã«ã€XX_DB_URL を定義ã™ã‚‹ã“ã¨ã§ã€?dbid="XX" ã¨ã™ã‚‹ã¨ã€ã“㮠接続å?を使用ã—ã¦
515             * ãƒ??タベã?スã«ã‚¢ã‚¯ã‚»ã‚¹ã§ãã¾ã™ã?
516             *
517             * @param       id ãƒ??タベã?ス接続ID
518             */
519            public void setDbid( final String id ) {
520                    dbid = nval( getRequestParameter( id ),dbid );
521            }
522    
523            /**
524             * ã€TAG】é?ç›®ãŒä¸?¤ã?‘ã®å ´åˆã??—ï¾ï¾žï¾™ï¾˜ï½¿?°?½ã«ã€ã‚­ãƒ¼æƒ??を追åŠ?™ã‚‹ã‹ã©ã?‹ã‚’指定ã—ã¾ã?åˆæœŸå€¤:false)ã€?
525             *
526             * @og.tag
527             * Queryオブジェクトã?é ?›®ãŒä¸?¤ã®å ´åˆã??—ï¾ï¾žï¾™éƒ¨ã«ã¯ã€?¾—ï¾ï¾žï¾™ï¾˜ï½¿?°?½ã‚’使用ã—ã¾ã™ã?
528             * ã“ã?時ã??—ï¾ï¾žï¾™ç„¡ã—ã?å ´åˆã?ã€ã‚­ãƒ¼ãŒè¡¨ç¤ºã•れã¾ã™ãŒã€?¾—ï¾ï¾žï¾™ã‚りã?å ´åˆã?ã€ã‚­ãƒ¼ã¯è¡¨ç¤ºã•れã?
529             * ?—ï¾ï¾žï¾™ã?ã¿è¡¨ç¤ºã•れã¾ã™ã?
530             * 都åˆã«ã‚ˆã£ã¦ã¯ã€ã‚­ãƒ¼ã‚‚表示ã—ãŸã??åˆãŒã‚りã¾ã™ã?ã§ã€ãã®æ§˜ãªã‚±ãƒ¼ã‚¹ã§ã¯ã€?
531             * addKey = "true を設定ã™ã‚‹äº‹ã§ã€ã‚­ãƒ¼:?—ï¾ï¾žï¾?ã®ã‚»ãƒ?ƒˆã‚’ï¾—ï¾ï¾žï¾™ã¨ã—ã¦æ‰±ã?¾ã™ã?
532             * åˆæœŸå€¤ã¯false(キーã¯ä»˜åŠ ã—ãªã?ã§ã™ã?
533             *
534             * @param       id ãƒ??タベã?ス接続ID
535             */
536            public void setAddKey( final String id ) {
537                    addKey = nval( getRequestParameter( id ),addKey );
538            }
539    
540            /**
541             * ã€TAG】リクエスト情報㮠HTMLTagé–‹å§?終äº?–‡å­?&gt;&lt;) 存在ãƒã‚§ãƒ?‚¯ã‚’実施ã™ã‚‹ã‹ã©ã?‹[true/false]を設定ã—ã¾ã?
542             *              (åˆæœŸå€¤:USE_XSS_CHECK[={@og.value org.opengion.hayabusa.common.SystemData#USE_XSS_CHECK}])ã€?
543             *
544             * @og.tag
545             * クロスサイトスクリプティング(XSS)対策ã?ä¸?’°ã¨ã—ã¦less/greater than signã«ã¤ã?¦ã®ãƒã‚§ãƒ?‚¯ã‚’行ã„ã¾ã™ã?
546             * (&gt;&lt;) ãŒå«ã¾ã‚Œã¦ã?Ÿã‚¨ãƒ©ãƒ¼ã«ã™ã‚‹(true)?ã‹ãƒŽã?ãƒã‚§ãƒ?‚¯ã?false)を指定ã—ã¾ã™ã?
547             * (åˆæœŸå€¤:シスãƒ?ƒ å®šæ•°ã®USE_XSS_CHECK[={@og.value org.opengion.hayabusa.common.SystemData#USE_XSS_CHECK}])ã€?
548             *
549             * @og.rev 5.0.0.2 (2009/09/15) æ–°è¦è¿½åŠ?
550             *
551             * @param       flag    XSSãƒã‚§ãƒ?‚¯ [true:ã™ã‚‹/false:ã—ãªã„]
552             * @see         org.opengion.hayabusa.common.SystemData#USE_XSS_CHECK
553             */
554            public void setXssCheck( final String flag ) {
555                    xssCheck = nval( getRequestParameter( flag ),xssCheck );
556            }
557    
558            /**
559             * row行,columåˆ?ã®ãƒ??ã‚¿ã®å€¤ã‚’è¿”ã—ã¾ã™ã?
560             *
561             * ã“れã¯ã€ãƒ‡ãƒ¼ã‚¿ã®å€¤ãã?ã‚‚ã?ã§ã¯ãªãã?ãã?値ã®ãƒ©ãƒ™ãƒ«æ–?­—ã‚’è¿”ã—ã¾ã™ã?
562             *
563             * @param   row         行番å·
564             * @param   column      カラãƒ?•ªå·
565             *
566             * @return  row行,columåˆ?ã®ãƒ??ã‚¿ã®å€¤
567             */
568            private String getRendererValue( final int row,final int column ) {
569                    String val = table.getValue( row,column );
570                    DBColumn clm = table.getDBColumn( column );
571                    return clm.getRendererValue( val );
572            }
573    
574            /**
575             * ã€TAG】オプションã«è¿½åŠ?™ã‚?title 属æ?㮠カラãƒ?•ªå·ã‚’指定ã—ã¾ã™ã?
576             *
577             * @og.tag
578             * オプションã¯ã€ãƒ‡ãƒ¼ã‚¿ãƒ™ã?スを検索ã—ã¦ä½œæ?ã•れã¾ã™ãŒã€ãã®SQLæ–??カラãƒ?ƒ…å ±ã‚?
579             * 使用ã—㦠オプション㫠title 属æ?を追åŠ?—ã¾ã™ã?
580             * title属æ?ã¯ãƒžã‚¦ã‚¹ã‚ªãƒ¼ãƒã?時ã«ãƒ??ルãƒãƒƒãƒ—ã¨ã—ã¦è¡¨ç¤ºã•れるãŸã‚ã?
581             * プルãƒ?‚¦ãƒ³ã®æ¨ªå¹?‚’短ãã—ãŸã„å ´åˆã«æœ‰åйã§ã™ã?
582             * 通常ã€ã‚«ãƒ©ãƒ?•ªå·=0 㯠キーæƒ??ã€?1 ã¯ãƒ©ãƒ™ãƒ«æƒ?? ã§ã™ã?2 ã?3 を指定ã—ã¾ã™ã?
583             * åˆæœŸå€¤ã¯ã€ä½¿ç”¨ã—ãªã?-1)ã§ã™ã?
584             *
585             * @og.rev 4.3.8.0 (2009/08/01) æ–°è¦è¿½åŠ?
586             *
587             * @param   no オプションã«è¿½åŠ?™ã‚‹title属æ?
588             */
589            public void setTitleUseNo( final String no ) {
590                    titleUseNo = nval( getRequestParameter( no ),titleUseNo );
591                    if( titleUseNo == 0 || titleUseNo == 1 ) {
592                            String errMsg = "通常ã€ã‚«ãƒ©ãƒ?•ªå·=0 㯠キーæƒ??ã€?1 ã¯ãƒ©ãƒ™ãƒ«æƒ?? ã§ã™ã?2 ã?3 を指定ã—ã¦ä¸‹ã•ã??";
593                            throw new HybsSystemException( errMsg );
594                    }
595            }
596    
597            /**
598             * シリアライズ用ã®ã‚«ã‚¹ã‚¿ãƒ?‚·ãƒªã‚¢ãƒ©ã‚¤ã‚ºæ›¸ãè¾¼ã¿ãƒ¡ã‚½ãƒ?ƒ‰
599             *
600             * @og.rev 4.0.0.0 (2006/09/31) æ–°è¦è¿½åŠ?
601             * @serialData ä¸?ƒ¨ã®ã‚ªãƒ–ジェクトã?ã€ã‚·ãƒªã‚¢ãƒ©ã‚¤ã‚ºã•れã¾ã›ã‚“ã€?
602             *
603             * @param       strm    ObjectOutputStreamオブジェク�
604             * @throws IOException  入出力エラーãŒç™ºç”Ÿã—ãŸå?å?
605             */
606            private void writeObject( final ObjectOutputStream strm ) throws IOException {
607                    strm.defaultWriteObject();
608            }
609    
610            /**
611             * シリアライズ用ã®ã‚«ã‚¹ã‚¿ãƒ?‚·ãƒªã‚¢ãƒ©ã‚¤ã‚ºèª­ã¿è¾¼ã¿ãƒ¡ã‚½ãƒ?ƒ‰
612             *
613             * ã“ã“ã§ã¯ã€transient 宣è¨?•れãŸå†?ƒ¨å¤‰æ•°ã®å†??åˆæœŸåŒ–ãŒå¿?¦ãªãƒ•ィールドã?ã¿è¨­å®šã—ã¾ã™ã?
614             *
615             * @og.rev 4.0.0.0 (2006/09/31) æ–°è¦è¿½åŠ?
616             * @serialData ä¸?ƒ¨ã®ã‚ªãƒ–ジェクトã?ã€ã‚·ãƒªã‚¢ãƒ©ã‚¤ã‚ºã•れã¾ã›ã‚“ã€?
617             *
618             * @param       strm    ObjectInputStreamオブジェク�
619             * @see #release2()
620             * @throws IOException  シリアライズã«é–¢ã™ã‚‹å…¥å‡ºåŠ›ã‚¨ãƒ©ãƒ¼ãŒç™ºç”Ÿã—ãŸå?å?
621             * @throws ClassNotFoundException       クラスを見ã¤ã‘ã‚‹ã“ã¨ãŒã§ããªã‹ã£ãŸå?å?
622             */
623            private void readObject( final ObjectInputStream strm ) throws IOException , ClassNotFoundException {
624                    strm.defaultReadObject();
625            }
626    
627    //      /**
628    //       * 親ã®og:selectã‚¿ã‚°ã®nameã¨eventColumn設定を返ã—ã¾ã™ã?
629    //       *
630    //       * @og.rev 4.3.6.0 (2009/04/01)
631    //       *
632    //       */
633    //      private String[] getEventColumn(){
634    //              SelectTag seltag = (SelectTag)findAncestorWithClass(this,SelectTag.class);
635    //              String[] selectVal = new String[2];
636    //              selectVal[0] = seltag.getEventColumn();
637    //              selectVal[1] = seltag.get("name");
638    //              return selectVal;
639    //      }
640    
641            /**
642             * ã“ã?オブジェクトã?æ–?­—å?表ç¾ã‚’è¿”ã—ã¾ã™ã?
643             * 基本çš?«ãƒ?ƒãƒ?‚°ç›®çš?«ä½¿ç”¨ã—ã¾ã™ã?
644             *
645             * @return ã“ã?ã‚¯ãƒ©ã‚¹ã®æ–?­—å?表ç¾
646             */
647            @Override
648            public String toString() {
649                    return org.opengion.fukurou.util.ToString.title( this.getClass().getName() )
650                                    .println( "VERSION"             ,VERSION        )
651                                    .println( "selValue"    ,selValue       )
652                                    .println( "defaultVal"  ,defaultVal     )
653                                    .println( "dbid"                ,dbid           )
654                                    .println( "sql"                 ,sql            )
655                                    .println( "separator"   ,separator      )
656                                    .println( "quotCheck"   ,quotCheck      )
657                                    .println( "Other..."    ,getAttributes().getAttribute() )
658                                    .fixForm().toString() ;
659            }
660    }