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 static org.opengion.fukurou.util.StringUtil.nval;
019
020 import java.util.Arrays;
021 import java.util.Enumeration;
022 import java.util.Locale;
023 import java.util.Set;
024 import java.util.TreeSet;
025
026 import org.opengion.fukurou.util.ErrorMessage;
027 import org.opengion.fukurou.util.StringUtil;
028 import org.opengion.hayabusa.common.HybsSystem;
029 import org.opengion.hayabusa.common.HybsSystemException;
030 import org.opengion.hayabusa.db.DBColumn;
031 import org.opengion.hayabusa.db.DBTableModel;
032
033 /**
034 * 登録ãƒ??ã‚¿ã®ç‰©ç?ƒã‚§ãƒ?‚¯(æ•´åˆæ?ãƒã‚§ãƒ?‚¯ã€nullãƒã‚§ãƒ?‚¯)を行ã†ã‚¿ã‚°ã§ã™ã?
035 *
036 * コマンドã«å¯¾å¿œã—ãŸãƒã‚§ãƒ?‚¯æ–¹å¼ã§ã€æŒ‡å®šã?カラãƒ?‚’ãƒã‚§ãƒ?‚¯ã—ã¾ã™ã?
037 * command="NEW" ã®å ´åˆã?ã€columns 引数ã«CSVå½¢å¼ã§æŒ?®šã—ãŸã‚«ãƒ©ãƒ?より
038 * ãƒªã‚¯ã‚¨ã‚¹ãƒˆæƒ…å ±ã‚’å–å¾—ã—ã¦ã€å?ã‚’ãƒã‚§ãƒ?‚¯ã—ã¾ã™ã?
039 * 引数ãƒã‚§ãƒ?‚¯ã§ã¯ã€?%" ã‚?"_" ãªã©ã®ã‚ã„ã¾ã?¤œç´¢æ™‚ã«æŒ?®šã™ã‚‹è¨˜å·ã‚?
040 * å«ã‚?¨ã‚¨ãƒ©ãƒ¼ã«ãªã‚‹ã‚«ãƒ©ãƒ??ãƒã‚§ãƒ?‚¯å¯¾è±¡ã‹ã‚‰ã¯ãšã™å¿?¦ãŒã‚る為ã€?
041 * ãƒã‚§ãƒ?‚¯ã™ã¹ãカラãƒ?‚’æŒ?®šã™ã‚‹å¿?¦ãŒã‚りã¾ã™ã?
042 * command="ENTRY" ã®å ´åˆã?ã€columns 引数ã«ç„¡é–¢ä¿‚ã«ã€å?ã¦ã®ãƒªã‚¯ã‚¨ã‚¹ãƒˆã•れãŸã‚«ãƒ©ãƒ?
043 * ã®å€¤ã‚’ãƒã‚§ãƒ?‚¯ã—ã¾ã™ã?ã“れã¯ã€å?ã®æ¤œç´¢æ™‚ã?å ´åˆã¨ç•°ãªã‚Šã?ENTRYã§ã¯
044 * ãƒ??タベã?スã«å€¤ã‚’è¨å®šã™ã‚‹ç‚ºã€ç„¡æ¡ä»¶ã«ãƒã‚§ãƒ?‚¯ã™ã‚‹å¿?¦ãŒã‚りã¾ã™ã?
045 * nullCheck ã¯ã€command ã«ç„¡é–¢ä¿‚ã«æŒ?®šã?カラãƒ?Œ null (ã‚¼ãƒæ–?—å?)ã‹ã©ã?‹ã‚?
046 * 判定ã—ã¾ã™ã?
047 * maxRowCount ã¯ã€ä¸?¦§æ¤œç´¢æ™‚ã?ãƒã‚§ãƒ?‚¯ã•れãŸä»¶æ•°ãŒã?æŒ?®šã?値をè¶?ˆãŸå?åˆã«
048 * エラーã«ãªã‚Šã¾ã™ã?minRowCount ã¯ã€åŒæ§˜ã«ã€æœ€å°é¸æŠžä»¶æ•°(è¨å®šå?ã‚’å«ã‚?ã®æŒ?®šã§ã™ã?
049 * ã“ã?ã‚¿ã‚°ã¯ã€ã‚¨ãƒ©ãƒ¼æ™‚ã«ã¯ã€ãれ以é™ã?JSPç”»é¢ã‚’評価ã—ã¾ã›ã‚“ã€?ODY 部ã«è¨˜è¿°ã•れã?
050 * 値ã¯ã€ã‚¨ãƒ©ãƒ¼æ™‚ã?ã¿è¡¨ç¤ºã•ã‚Œã€æ£å¸¸æ™‚ã«ã¯ã€ãªã«ã‚‚表示ã•れã¾ã›ã‚“。ã“れã?ã€ã‚¨ãƒ©ãƒ¼æ™‚ã?
051 * メãƒ?‚»ãƒ¼ã‚¸ã‚??ユーザーã«ã‚¨ãƒ©ãƒ¼æ™‚ã?アクションを行ã£ã¦ã‚‚らã??åˆã?処ç?例ãˆã°ã€?
052 * ç”»é¢ã‚’戻る為ã®ãƒœã‚¿ãƒ³ãªã©)を表示ã•ã›ã¾ã™ã?
053 * useColumnLabel ã‚?true ã«ã‚»ãƒ?ƒˆã™ã‚‹ã¨ã€ã‚¨ãƒ©ãƒ¼æ™‚ã?カラãƒ?(ラベル)ã‚’ã?カラãƒ?‚ªãƒ–ジェクトã‹ã‚?
054 * å–å¾—ã™ã‚‹ã‚ˆã?«ãªã‚Šã¾ã™ã?動的カラãƒ?®Ÿè¡Œæ™‚ã‚??DBTableModelã«å¯¾ã—ã¦ã€ColumnEditorç‰ã§
055 * ãƒ©ãƒ™ãƒ«ã‚’æ›¸ãæ›ãˆãŸå ´åˆã«ã€æœ‰åйã§ã™ã?false ã®å ´åˆã?ã€åŸºæœ¬çš?«ã¯ãƒ©ãƒ™ãƒ«ãƒªã‚½ãƒ¼ã‚¹ã‹ã‚‰ã®
056 * å–å¾—ã«ãªã‚Šã¾ã™ãŒã€ã‚±ãƒ¼ã‚¹ã«ã‚ˆã£ã¦ã¯ã€ã‚«ãƒ©ãƒ?‚ªãƒ–ジェクトã‹ã‚‰å–å¾—ã—ã¦ã?‚‹å ´åˆã‚‚ã‚りã¾ã™ã?
057 * ã“ã?属æ?ã¯ã€äº’æ›æ€§ã‚’é‡è¦–ã—ã€å?期å?ãŒã?false ã«ãªã£ã¦ã?¾ã™ã?
058 *
059 * command="MODIFY" , "DELETE" 時ã«ã¯ã€å¼·åˆ¶çš?«ã€minRowCount="1" ã§å‡¦ç?—ã¾ã™ã?
060 *
061 * @og.formSample
062 * â—å½¢å¼ï¼?lt;og:columnCheck command = "…" />
063 * â—å½¢å¼ï¼?lt;og:columnCheck command = "…" >エラー時ã?ã¿å‡¦ç?</og:columnCheck>
064 * â—body?šãªã?ã‚り(EVAL_BODY_BUFFERED:BODYを評価ã—ã?{@XXXX} ã‚’è§£æžã—ã¾ã?
065 *
066 * â—Tag定義??
067 * <og:columnCheck
068 * command ã€TAG】コマンド[NEW/RENEW/ENTRY]ã‚’ã‚»ãƒ?ƒˆã—ã¾ã?åˆæœŸå€¤:NEW)
069 * columns ã€TAG】ãƒã‚§ãƒ?‚¯ã™ã¹ãカラãƒ??をカンマ区åˆ?‚Š(CSVå½¢å¼?ã§æŒ?®šã—ã¾ã?
070 * nullCheck ã€TAG】NULL ãƒã‚§ãƒ?‚¯ã™ã¹ãカラãƒ??をカンマ区åˆ?CSVå½¢å¼?ã‚Šã§æŒ?®šã—ã¾ã?
071 * mustAnyCheck ã€TAGã€‘é¸æŠžå¿??カラãƒ?æŒ?®šã?カラãƒ??å†?œ€ä½Žã?ã¨ã¤ãŒNULLã§ãªã?ã‚?AA|BB|CC,XX|YY|ZZ" å½¢å¼ã§æŒ?®šã—ã¾ã?
072 * checkType ã€TAGã€?ãƒã‚§ãƒ?‚¯å¯¾è±¡ã®ãƒ??ã‚¿[AUTO/NEW/ENTRY]を指定ã—ã¾ã?åˆæœŸå€¤:AUTO)
073 * maxRowCount ã€TAG】ENTRY時ã«ãƒã‚§ãƒ?‚¯ã§é¸æŠžã•れãŸè¡Œæ•°ã®æœ?¤§å€¤ã‚’è¨å®šã—ã¾ã?
074 * minRowCount ã€TAG】ENTRY時ã«ãƒã‚§ãƒ?‚¯ã§é¸æŠžã•れãŸè¡Œæ•°ã®æœ?°å?ã‚’è¨å®šã—ã¾ã?
075 * tableId ã€TAGã€?通常ã¯ä½¿ã?¾ã›ã‚“) sessionã«ç™»éŒ²ã•れã¦ã?‚‹ DBTableModel ã‚’å–りå?ã™ã‚ーを指定ã—ã¾ã?
076 * matchKeys ã€TAG】æ£è¦è¡¨ç¾ã§ã®ãƒžãƒƒãƒãƒ³ã‚°ã‚’行ã†ã‚«ãƒ©ãƒ??をカンマ区åˆ?‚Š(CSVå½¢å¼?ã§æŒ?®šã—ã¾ã?
077 * matchVals ã€TAG】æ£è¦è¡¨ç¾ã§ã®ãƒžãƒƒãƒãƒ³ã‚°ã‚’行ã†ã‚«ãƒ©ãƒ??ã«å¯¾ã™ã‚‹å€¤(æ£è¦è¡¨ç¾)をカンマ区åˆ?‚Š(CSVå½¢å¼?ã§æŒ?®šã—ã¾ã?
078 * realTime ã€TAGã€?通常使ã?¾ã›ã‚“)リアルタイãƒ?ƒã‚§ãƒ?‚¯ã‚’行ã†å ´åˆã«æœ‰åйã«ã—ã¾ã?
079 * useStrict ã€TAG】NEWã®å ´åˆã«ã€å޳å¯?«ãƒã‚§ãƒ?‚¯ã™ã‚‹ã‹ã©ã?‹[true/false]を指定ã—ã¾ã?åˆæœŸå€¤:false)
080 * useColumnLabel ã€TAG】カラãƒ?ƒ©ãƒ™ãƒ«ã‚’使用ã™ã‚‹ã‹ã©ã?‹[true/false]を指定ã—ã¾ã?åˆæœŸå€¤:false)
081 * checkNames ã€TAGã€‘ãƒªã‚¯ã‚¨ã‚¹ãƒˆå¤‰æ•°ã®æ£è¦åŒ–を行ã†ã‚«ãƒ©ãƒ?‚’CSVå½¢å¼ã§è¤?•°æŒ?®šã—ã¾ã?
082 * debug ã€TAG】デãƒãƒƒã‚°æƒ??ã‚’å?力ã™ã‚‹ã‹ã©ã?‹[true/false]を指定ã—ã¾ã?åˆæœŸå€¤:false)
083 * > ... Body ...
084 * </og:columnCheck>
085 *
086 * â—使用ä¾?
087 * <og:columnCheck
088 * command = "{@command}"
089 * columns = "AAA,BBB,CCC" DB定義(DBColumnリソース)ã§å®šç¾©ã—ãŸé ?›®(æ¡æ•°,タイプç?ã§ãƒã‚§ãƒ?‚¯ã—ã¾ã™ã?
090 * maxRowCount = "1" ãƒã‚§ãƒ?‚¯ã§é¸ã°ã‚ŒãŸ æœ?¤§é¸æŠžä»¶æ•°(è¨å®šå?ã‚’å«ã‚?を指定ã?
091 * minRowCount = "1" ãƒã‚§ãƒ?‚¯ã§é¸ã°ã‚ŒãŸ æœ?°é¸æŠžä»¶æ•°(è¨å®šå?ã‚’å«ã‚?を指定ã?
092 * nullCheck = "AAA,CCC" NULLãƒã‚§ãƒ?‚¯ã‚’実行ã—ã¾ã™ã?
093 * />
094 *
095 * [エラー時ã«ã€BODY部ã«è¨˜è¿°ã•れãŸå?容をå?力ã™ã‚‹ã?æ£å¸¸æ™‚ã«ã¯ã€ã“ã®BODY部ã®è¨˜è¿°ã¯å‡ºåŠ›ã•れã¾ã›ã‚“ã€?
096 * <og:columnCheck
097 * command = "{@command}"
098 * columns = "AAA,BBB,CCC" DB定義(DBColumnリソース)ã§å®šç¾©ã—ãŸé ?›®(æ¡æ•°,タイプç?ã§ãƒã‚§ãƒ?‚¯ã—ã¾ã™ã?
099 * nullCheck = "AAA,CCC" NULLãƒã‚§ãƒ?‚¯ã‚’実行ã—ã¾ã™ã?
100 * >
101 * <form method="POST" action="forward.jsp" target="RESULT">
102 * <og:input type="button" onClick="history.back()" msg="MSG0049" accesskey="R" td="false" />
103 * </form>
104 * </og:columnCheck>
105 *
106 * mustAnyCheck 属æ?ã«ã€?¸æŠžå¿??カラãƒ?‚’æŒ?®šã—ã¾ã™ã?
107 * 例:mustAnyCheck="AA|BB|CC"
108 * AA,BB,CC ã®ã‚«ãƒ©ãƒ?§é¸æŠžå¿??(ã™ã¹ã¦ãŒnullãªã‚‰ã‚¨ãƒ©ãƒ¼)
109 * 例:mustAnyCheck="AA|BB|CC,XX|YY|ZZ"
110 * AA,BB,CC ã®ã‚»ãƒ?ƒˆã¨ã€XX,YY,ZZã®ã‚»ãƒ?ƒˆã§ãれãžã‚Œé¸æŠžå¿??ã€?
111 * 例:mustAnyCheck="AA|XX,AA|YY,AA|ZZ"
112 * AA ã«å€¤ãŒã‚れã?ã™ã¹ã¦æˆç«‹ã?ãã†ã§ãªã??åˆã?ã€XX 㨠YY 㨠ZZ ãŒã™ã¹ã¦å¿??ã€?
113 * 例:mustAnyCheck="AA|BB,BB|CC,AA|CC"
114 * AA,BB,CC ã®å†??ã©ã‚Œã‹?’ã¤ãŒå¿??ã€?AãŒæ?ç«‹ã™ã‚Œã?BBã‹CCãŒå¿??ã€‚åŒæ§˜ã«ã€?
115 * BBãŒæ?ç«‹ã™ã‚Œã?ã€AAã‹CCãŒå¿??ã€?
116 *
117 * 例:query.jsp
118 * <og:column name="AA" mustAny="true" />
119 * <og:column name="BB" mustAny="true" />
120 * <og:column name="XX" mustAny="XYZ" />
121 * <og:column name="YY" mustAny="XYZ" />
122 * result.jsp
123 * <og:columnCheck mustAnyCheck="AA|BB,XX|YY" />
124 * custom/custom.css
125 * .XYZ { background-color: Green; }
126 *
127 * ä¾?動的カラãƒ?§ã€entry.jsp ã§ã®ãƒã‚§ãƒ?‚¯ã‚’行ã†å ´åˆã?
128 * entry.jsp
129 * <og:columnCheck command="NEW" columns="*" useColumnLabel="true" />
130 *
131 * useColumnLabel ã§ã€å‹•çš?«ä½œæ?ã•れãŸã‚«ãƒ©ãƒ?SAVE=TRUEã§ã‚ャãƒ?‚·ãƒ¥æ¸ˆã¿)を使ã£ã¦
132 * ãƒã‚§ãƒ?‚¯ã—ã¾ã™ã?command="NEW" ãªã®ã§ã€å¯¾è±¡ã‚«ãƒ©ãƒ?‚’æŒ?®šã™ã‚‹ã?ã«ã€?*" ã§ã™ã¹ã¦ã‚’é¸æŠžã—ã¾ã™ã?
133 *
134 * @og.group ç”»é¢ç™»éŒ²
135 *
136 * @version 4.0
137 * @author Kazuhiko Hasegawa
138 * @since JDK5.0,
139 */
140 public class ColumnCheckTag extends CommonTagSupport {
141 //* ã“ã?プãƒã‚°ãƒ©ãƒ??VERSIONæ–?—å?ã‚’è¨å®šã—ã¾ã™ã? {@value} */
142 private static final String VERSION = "5.6.9.4 (2013/10/31)" ;
143
144 private static final long serialVersionUID = 569420131031L ;
145
146 /** command å¼•æ•°ã«æ¸¡ã™äº‹ã?出æ¥ã‚?コマンãƒ? æ–°è¦?{@value} */
147 public static final String CMD_NEW = "NEW" ;
148 /** command å¼•æ•°ã«æ¸¡ã™äº‹ã?出æ¥ã‚?コマンãƒ? 冿¤œç´¢ {@value} */
149 public static final String CMD_RENEW = "RENEW" ;
150 /** command å¼•æ•°ã«æ¸¡ã™äº‹ã?出æ¥ã‚?コマンãƒ? エントリー {@value} */
151 public static final String CMD_ENTRY = "ENTRY" ;
152 /** command å¼•æ•°ã«æ¸¡ã™äº‹ã?出æ¥ã‚?コマンãƒ?リスãƒ? */
153
154 // 4.3.1.1 (2008/08/23) transient 追�
155 private transient DBTableModel table = null; // 4.1.2.1 (2008/03/13)
156
157 private String tableId = HybsSystem.TBL_MDL_KEY; // 3.5.4.3 (2004/01/05)
158 private String command = CMD_NEW; // ç„¡æŒ?®šæ™‚ã¯ã€ãƒã‚§ãƒ?‚¯ã‚’行ã†ã€?
159 private String[] columns = null;
160 private String[] nullCheck = null;
161 private String[] mustAnyCheck= null; // 3.8.0.9 (2005/10/17)
162 private int maxRowCount = -1 ; // åˆæœŸå€¤ã¨ã—ã¦?Œç„¡åˆ¶é™ã‚’æŒ?®?
163 private int minRowCount = -1 ; // åˆæœŸå€¤ã¨ã—ã¦?Œç„¡åˆ¶é™ã‚’æŒ?®?
164 private String checkType = "AUTO";
165 private String bodyString = null; // 3.5.4.2 (2003/12/15)
166 private String[] matchKeys = null; // 4.0.0 (2005/11/30)
167 private String[] matchVals = null; // 4.0.0 (2005/11/30)
168 // private boolean isViewSimple= false; // 4.3.3.0 (2008/10/01)
169 private boolean isRealTime = false; // 4.3.7.0 (2009/06/01)
170 private boolean isStrict = false; // 5.2.2.0 (2010/11/01) NEWã®å ´åˆã«ã€å޳å¯?«ãƒã‚§ãƒ?‚¯ã™ã‚‹ãƒ•ラグを追åŠ?
171
172 private boolean isColumnLabel= false; // 5.4.3.4 (2012/01/12) true ã®å ´åˆã«ã€ã‚«ãƒ©ãƒ?ƒ©ãƒ™ãƒ«ã‚’使用ã—ã¾ã™ã?
173 // private boolean isTblClmLbl = false; // 5.4.3.4 (2012/01/12) true ã®å ´åˆã«ã€DBTableModelã®ã‚«ãƒ©ãƒ?‹ã‚‰ãƒ©ãƒ™ãƒ«ã‚’å–å¾—ã—ã¾ã™ã?
174
175 private String checkNames = null; // 5.4.3.8 (2012/01/24)
176
177 /**
178 * Taglibã®é–‹å§‹ã‚¿ã‚°ãŒè¦‹ã¤ã‹ã£ãŸã¨ãã«å‡¦ç?™ã‚?doStartTag() ã‚?オーãƒã?ライドã—ã¾ã™ã?
179 *
180 * @og.rev 3.5.4.2 (2003/12/15) エラー時ã«ã€BODY部ã«è¨˜è¿°ã•れãŸå?容をå?力ã™ã‚‹ã?
181 * @og.rev 5.0.0.2 (2009/09/15) xss対応âçãƒã‚§ãƒ?‚¯ã™ã‚‹
182 *
183 * @return 後続å?ç??æŒ?¤º( EVAL_BODY_BUFFERED )
184 */
185 @Override
186 public int doStartTag() {
187 // 5.0.0.2 (2009/09/15) XSSãƒã‚§ãƒ?‚¯ã—ãªã?çã™ã‚‹
188 // useXssCheck( false );
189 return ( EVAL_BODY_BUFFERED ); // Body を評価ã™ã‚‹
190 }
191
192 /**
193 * Taglibã®ã‚¿ã‚°æœ¬ä½“を処ç?™ã‚?doAfterBody() ã‚?オーãƒã?ライドã—ã¾ã™ã?
194 *
195 * @og.rev 3.5.4.2 (2003/12/15) エラー時ã«ã€BODY部ã«è¨˜è¿°ã•れãŸå?容をå?力ã™ã‚‹ã?
196 *
197 * @return 後続å?ç??æŒ?¤º(SKIP_BODY)
198 */
199 @Override
200 public int doAfterBody() {
201 bodyString = getBodyString();
202
203 return ( SKIP_BODY );
204 }
205
206 /**
207 * Taglibã®çµ‚äº?‚¿ã‚°ãŒè¦‹ã¤ã‹ã£ãŸã¨ãã«å‡¦ç?™ã‚?doEndTag() ã‚?オーãƒã?ライドã—ã¾ã™ã?
208 *
209 * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応ã?release2() ã‚?doEndTag()ã§å‘¼ã¶ã€?
210 * @og.rev 3.4.0.3 (2003/09/10) command="NEW" ã§ã‚¨ãƒ©ãƒ¼ç™ºç”Ÿæ™‚ã«ã¯ã€DBTableModel をクリアã™ã‚‹ã€?
211 * @og.rev 3.5.4.2 (2003/12/15) HTMLTableViewForm クラスå変更(â‡?ViewForm_HTMLTable)
212 * @og.rev 3.5.4.2 (2003/12/15) エラー時ã«ã€BODY部ã«è¨˜è¿°ã•れãŸå?容をå?力ã™ã‚‹ã?
213 * @og.rev 3.5.4.3 (2004/01/05) tableId 属æ?を追åŠ??
214 * @og.rev 3.5.4.4 (2004/01/16) ã‚¨ãƒ©ãƒ¼çµæžœã‚’表示ã™ã‚‹ãƒ??ブル形å¼ã?フォーãƒ?¿®æ£
215 * @og.rev 3.5.5.2 (2004/04/02) TaglibUtil.makeHTMLErrorTable メソãƒ?ƒ‰ã‚’利用
216 * @og.rev 4.1.2.1 (2008/03/13) table 属æ?を追åŠ??
217 * @og.rev 4.3.3.0 (2008/10/01) viewSimple属æ?追åŠ?
218 * @og.rev 4.3.7.0 (2009/06/01) viewSimple属æ?å称変更 â‡?isRealTime
219 * @og.rev 5.6.8.3 (2013/09/27) checkTypeãŒAutoã®å ´åˆã?ã‚»ãƒ?ƒˆã‚’ã“ã“ã§è¡Œã„ã€tableModelãƒã‚§ãƒ?‚¯ã‚’checkTypeã§è¡Œã†ã€?
220 *
221 * @return 後続å?ç??æŒ?¤º
222 */
223 @Override
224 public int doEndTag() {
225 debugPrint(); // 4.0.0 (2005/02/28)
226 int rtnCode = EVAL_PAGE;
227
228 // 4.1.2.1 (2008/03/13)
229 table = (DBTableModel)getObject( tableId );
230
231 // 5.6.8.3 (2013/09/27) ãƒã‚§ãƒ?‚¯ã‚¿ã‚¤ãƒ—ã?autoã‚’å?れるä½ç½®å¤‰æ›´
232 if( "AUTO".equals( checkType ) ) { checkType = command; }
233
234 // 3.4.0.3 (2003/09/10) コマンドãŒã€NEW,RENEW 以外ã?å ´åˆã?ã€DBTableModel ã¯å¿??ã€?
235 if(
236 // !CMD_NEW.equals( command ) &&
237 // !CMD_RENEW.equals( command ) &&
238 !CMD_NEW.equals( checkType ) && // 5.6.8.3 (2013/09/27) commandã‹ã‚‰å¤‰æ›´
239 !CMD_RENEW.equals( checkType ) &&
240 // getObject( tableId ) == null ) { // 3.5.4.3 (2004/01/05)
241 table == null ) { // 4.1.2.1 (2008/03/13)
242 String errMsg = "æ¤œç´¢çµæžœã®ã‚ªãƒ–ジェクトãŒå˜åœ¨ã—ã¾ã›ã‚“ã€?
243 + " checkType=[" + checkType + "]" ;
244 jspPrint( errMsg );
245 rtnCode = SKIP_PAGE ;
246 }
247 else {
248 // 3.5.5.2 (2004/04/02) TaglibUtil.makeHTMLErrorTable メソãƒ?ƒ‰ã‚’利用
249 ErrorMessage errMsg = makeErrorDBTable();
250 if( errMsg.getKekka() >= ErrorMessage.NG ) {
251 if( bodyString != null ) { jspPrint( bodyString ); } // 3.5.4.2 (2003/12/15)
252
253 // 4.3.3.0 (2008/10/01)
254 // jspPrint( TaglibUtil.makeHTMLErrorTable( errMsg,getResource() ) );
255 // 4.3.7.0 (2009/06/01)
256 if( isRealTime ) { jspPrint( TaglibUtil.makeHTMLSimpleErrorList( errMsg,getResource() ) ); }
257 else { jspPrint( TaglibUtil.makeHTMLErrorTable( errMsg, getResource() ) ); }
258
259 if( CMD_NEW.equals( command ) ) {
260 removeObject( tableId );
261 }
262 rtnCode = SKIP_PAGE ;
263 }
264 else if( errMsg.getKekka() == ErrorMessage.WARNING ) {
265 // 4.3.3.0 (2008/10/01)
266 // jspPrint( TaglibUtil.makeHTMLErrorTable( errMsg,getResource() ) );
267 // 4.3.7.0 (2009/06/01)
268 if( isRealTime ) { jspPrint( TaglibUtil.makeHTMLSimpleErrorList( errMsg,getResource() ) ); }
269 else { jspPrint( TaglibUtil.makeHTMLErrorTable( errMsg, getResource() ) ); } }
270 }
271
272 return( rtnCode );
273 }
274
275 /**
276 * タグリブオブジェクトをリリースã—ã¾ã™ã?
277 *
278 * ã‚ャãƒ?‚·ãƒ¥ã•れã¦å†åˆ©ç”¨ã•れるã?ã§ã€ãƒ•ィールドã?åˆæœŸè¨å®šã‚’行ã„ã¾ã™ã?
279 *
280 * @og.rev 2.0.0.4 (2002/09/27) カスタãƒ?‚¿ã‚°ã® release() メソãƒ?ƒ‰ã‚’ã?追åŠ?
281 * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応ã?release2() ã‚?doEndTag()ã§å‘¼ã¶ã€?
282 * @og.rev 3.5.4.2 (2003/12/15) エラー時ã«ã€BODY部ã«è¨˜è¿°ã•れãŸå?容をå?力ã™ã‚‹ã?
283 * @og.rev 3.5.4.3 (2004/01/05) tableId 属æ?を追åŠ??
284 * @og.rev 3.8.0.9 (2005/10/17) mustAnyCheck 属æ?を追åŠ??
285 * @og.rev 4.1.2.1 (2008/03/13) table 属æ?を追åŠ??
286 * @og.rev 4.3.3.0 (2008/10/01) viewSimple属æ?追åŠ?
287 * @og.rev 4.3.7.0 (2009/06/01) viewSimple属æ?å称変更 â‡?isRealTime
288 * @og.rev 5.2.2.0 (2010/11/01) NEWã®å ´åˆã«ã€å޳å¯?«ãƒã‚§ãƒ?‚¯ã™ã‚‹ãƒ•ラグを追åŠ?
289 * @og.rev 5.4.3.4 (2012/01/12) isColumnLabelを追�
290 *
291 */
292 @Override
293 protected void release2() {
294 super.release2();
295 command = CMD_NEW; // ç„¡æŒ?®šæ™‚ã¯ã€ãƒã‚§ãƒ?‚¯ã‚’行ã†ã€?
296 columns = null;
297 nullCheck = null;
298 maxRowCount = -1 ; // åˆæœŸå€¤ã¨ã—ã¦?Œç„¡åˆ¶é™ã‚’æŒ?®?
299 minRowCount = -1 ; // åˆæœŸå€¤ã¨ã—ã¦?Œç„¡åˆ¶é™ã‚’æŒ?®?
300 checkType = "AUTO";
301 bodyString = null ; // 3.5.4.2 (2003/12/15)
302 tableId = HybsSystem.TBL_MDL_KEY; // 3.5.4.3 (2004/01/05)
303 mustAnyCheck= null; // 3.8.0.9 (2005/10/17)
304 matchKeys = null; // 4.0.0 (2005/11/30)
305 matchVals = null; // 4.0.0 (2005/11/30)
306 table = null; // 4.1.2.1 (2008/03/13)
307 // isViewSimple= false; // 4.3.3.0 (2008/10/01)
308 isRealTime = false; // 4.3.7.0 (2009/06/01)
309 isStrict = false; // 5.2.2.0 (2010/11/01) NEWã®å ´åˆã«ã€å޳å¯?«ãƒã‚§ãƒ?‚¯ã™ã‚‹ãƒ•ラグを追åŠ?
310 isColumnLabel= false; // 5.4.3.4 (2012/01/12) true ã®å ´åˆã«ã€ã‚«ãƒ©ãƒ?ƒ©ãƒ™ãƒ«ã‚’使用ã—ã¾ã™ã?
311 // isTblClmLbl = false; // 5.4.3.4 (2012/01/12) true ã®å ´åˆã«ã€DBTableModelã®ã‚«ãƒ©ãƒ?‹ã‚‰ãƒ©ãƒ™ãƒ«ã‚’å–å¾—ã—ã¾ã™ã?
312 checkNames = null; // 5.4.3.8 (2012/01/24)
313 }
314
315 /**
316 * DBColumn オブジェクトを作æ?ã—ã¦ã€DBColumn#valueCheck( String )ã§
317 * ãƒã‚§ãƒ?‚¯ã‚’行ã†ã€‚ãã®çµæžœã®ã€ErrorMessage オブジェクトを DBTableModel ã«
318 * å–り込んã§ã€ã‚¨ãƒ©ãƒ¼ã®å ´åˆã?ã€ãã®è¡¨ç¤ºã‚’行ã†ã€?
319 * 表示方法ã?ã€ãã®ã¾ã¾ ViewForm オブジェクトを作æ?ã—ã¦ã€è¡¨ç¤ºã‚’行ã†ã€?
320 *
321 * @og.rev 3.5.5.2 (2004/04/02) リターン値をã?DBTableModel ã‹ã‚‰ ErrorMessage ã«å¤‰æ›´
322 * @og.rev 4.0.0.0 (2005/01/31) リターン値㮠ErrorMessage ã¯ã€å¿?šå˜åœ¨ã™ã‚‹ã€?
323 * @og.rev 4.1.2.1 (2008/03/13) command="MODIFY" , "DELETE" 時ã«ã¯ã€å¼·åˆ¶çš?«ã€minRowCount="1" ã§å‡¦ç?—ã¾ã™ã?
324 * @og.rev 5.6.8.3 (2013/09/27) checkTypeã®Auto時è¨å®šä½ç½®ã‚’doEndTagã§ã™ã‚‹ã‚ˆã†ã«å¤‰æ›´
325 *
326 * @return エラーメãƒ?‚»ãƒ¼ã‚¸ã®ãƒ??ブルモãƒ?ƒ«
327 */
328 private ErrorMessage makeErrorDBTable() {
329 ErrorMessage errMsg = new ErrorMessage();
330
331 //if( "AUTO".equals( checkType ) ) { checkType = command; } // 5.6.8.3 (2013/09/27) move
332 if( CMD_ENTRY.equals( checkType ) ) {
333 errMsg.setTitle( "Request Column Error!" );
334 errMsg = makeEntryErrorMessage( errMsg );
335 errMsg = makeMaxRowCountErrorMessage( errMsg );
336 errMsg = makeMinRowCountErrorMessage( errMsg );
337 }
338 else if( CMD_NEW.equals( checkType ) ) {
339 errMsg.setTitle( "Entry Column Error!" );
340 errMsg = makeErrorMessage( errMsg );
341 errMsg = makeMaxRowCountErrorMessage( errMsg );
342 errMsg = makeMinRowCountErrorMessage( errMsg );
343 }
344 else if( minRowCount >= 0 || maxRowCount >= 0) { // -1 ã¯åˆ¶é™ç„¡ã?
345 errMsg.setTitle( "Row Count Error Limited Error!" );
346 errMsg = makeMaxRowCountErrorMessage( errMsg );
347 errMsg = makeMinRowCountErrorMessage( errMsg );
348 }
349 // 4.1.2.1 (2008/03/13) command="MODIFY" , "DELETE" 時ã«ã¯ã€å¼·åˆ¶çš?«ã€minRowCount="1" ã§å‡¦ç?—ã¾ã™ã?
350 else if( "MODIFY,DELETE".indexOf( checkType ) >= 0 && minRowCount < 0 ) {
351 minRowCount = 1;
352 errMsg = makeMinRowCountErrorMessage( errMsg );
353 }
354 return errMsg;
355 }
356
357 /**
358 * ErrorMessageã‚’ã‚»ãƒ?ƒˆã—ã¾ã™ã?
359 * 引数ã®ã‚«ãƒ©ãƒ?é…å?ã‚ˆã‚Šãƒªã‚¯ã‚¨ã‚¹ãƒˆæƒ…å ±ã‚’å–å¾—ã—ã¦ã€å?ã‚’ãƒã‚§ãƒ?‚¯ã—ã¾ã™ã?
360 * DBColumn#valueCheck( String ) ã®çµæžœã®ErrorMessageã‚’ã™ã¹ã¦ append
361 * ã—ã¦ã?ã¾ã™ã?
362 *
363 * @og.rev 3.8.0.9 (2005/10/17) é¸æŠžå¿?? mustAnyCheck ã®ãƒã‚§ãƒ?‚¯è¿½åŠ?
364 * @og.rev 3.8.1.0 (2005/10/24) ãƒªã‚¯ã‚¨ã‚¹ãƒˆæƒ…å ±ã®æ£è¦åŒ–変æ›(DBColumn#valueSet(String))䏿¢
365 * @og.rev 3.8.5.3 (2006/06/30) リクエスト㫠% , _ ãŒå«ã¾ã‚ŒãŸã¨ãã?ã€å‰Šé™¤ã—ã¾ã™ã?
366 * @og.rev 4.1.2.1 (2008/03/13) must , mustAny ã®è‡ªå‹•å–得追åŠ?
367 * @og.rev 5.0.0.2 (2009/09/15) 個別ã«xssãƒã‚§ãƒ?‚¯ã‚’false
368 * @og.rev 5.1.9.0 (2010/08/01) åŒã˜åå‰ã®é ?›®ã¯ã€?ã¤ã«ã¾ã¨ã‚ã‚‹(ラジオボタンç?
369 * @og.rev 5.2.0.0 (2010/09/01) リアルタイãƒ?ƒã‚§ãƒ?‚¯ã®å ´åˆã?ã€must,mustAnyã®è‡ªå‹•ãƒã‚§ãƒ?‚¯ã¯è¡Œã‚ãªã?
370 * @og.rev 5.2.2.0 (2010/11/01) DBColumn#valueCheck ã§ã€ç”˜ã?ƒã‚§ãƒ?‚¯ã‚’行ã†ã‚ˆã†ã«ã€å¼•æ•°ã« isStrict を追åŠ?
371 * @og.rev 5.4.3.4 (2012/01/12) getLabel( String )ã‚’ã?リソースã‹ã‚‰ã«çµ±ä¸?™ã‚‹ã¨ã¨ã‚‚ã«ã€isColumnLabel 対応を行ã†ã€?
372 * @og.rev 5.4.3.8 (2012/01/28) checkNames対�
373 *
374 * @param errMsg ErrorMessageオブジェク�
375 *
376 * @return カラãƒ?‚ー ??値 ã®ã‚¨ãƒ©ãƒ¼ãƒ¡ãƒ?‚»ãƒ¼ã‚¸ã‚ªãƒ–ジェクãƒ?
377 */
378 private ErrorMessage makeErrorMessage( final ErrorMessage errMsg ) {
379
380 // 4.1.2.1 (2008/03/13) must , mustAny ã®è‡ªå‹•å–得追åŠ?
381 // request ã‹ã‚‰å–å?ã?注æ„:mustAny 以外ã?自由形å¼ã?å€¤ã¯æ‰?¾—ã—ã¦ã?¾ã›ã‚“ã€?
382 // 5.2.0.0 (2010/09/01) リアルタイãƒ?ƒã‚§ãƒ?‚¯ã®å ´åˆã?ã€must,mustAnyã®è‡ªå‹•ãƒã‚§ãƒ?‚¯ã¯è¡Œã‚ãªã?
383 // (基本çš?«ãƒ‘ラメーターをé?らãªã?™ã‚Šè?å‹•ãƒã‚§ãƒ?‚¯ã¯å‹•ã‹ãªã?Œã€RequestCacheã«ã‚ˆã‚Šå‹•ãã“ã¨ãŒã‚ã‚?
384 if( !isRealTime ) {
385 if( nullCheck == null ) {
386 nullCheck = getRequestValues( HybsSystem.MUST_KEY + "must" );
387 // 5.1.9.0 (2010/08/01) åŒã˜åå‰ã®é ?›®ã¯ã€?ã¤ã«ã¾ã¨ã‚ã‚‹(ラジオボタンç?
388 // if( nullCheck != null ) { Arrays.sort( nullCheck ); }
389 if( nullCheck != null ) {
390 Set<String> ss = new TreeSet<String>();
391 ss.addAll( Arrays.asList( nullCheck ) );
392 // nullCheck = ss.toArray( new String[0] );
393 nullCheck = ss.toArray( new String[ss.size()] ); // 5.1.9.0 (2010/08/01) K.H
394 }
395 }
396 if( mustAnyCheck == null ) {
397 String[] mustAnyReq = getRequestValues( HybsSystem.MUST_KEY + "mustAny" );
398 if( mustAnyReq != null && mustAnyReq.length > 0 ) {
399 mustAnyCheck = new String[] { StringUtil.array2line( mustAnyReq,"|" ) };
400 }
401 }
402 }
403
404 if( nullCheck != null && nullCheck.length != 0 ) {
405 for( int i=0; i<nullCheck.length; i++ ) {
406 String clmKey = nullCheck[i]; // 5.4.3.4 (2012/01/12)
407 // String val = getRequestValue( nullCheck[i] );
408 // String val = getRequestValue( nullCheck[i], false ); // 5.0.0.2 (2009/09/15)
409 String val = getRequestValue( clmKey, false ); // 5.0.0.2 (2009/09/15)
410 if( val == null || val.length() == 0 ) {
411 // 5.4.3.4 (2012/01/12) isColumnLabel 追�
412 // String label = getLabel( nullCheck[i] ); // 4.0.0 (2005/01/31)
413 String label = (isColumnLabel) ? getDBColumn( clmKey ).getLabel() : getResource().getLabel( clmKey );
414 // ERR0012 : æŒ?®šã?ãƒ??ã‚¿ãŒã‚»ãƒ?ƒˆã•れã¦ã?¾ã›ã‚“ã€?NULLエラー)。key={0}
415 errMsg.addMessage( 0,ErrorMessage.NG,"ERR0012",label );
416 }
417 }
418 }
419 // 3.8.0.9 (2005/10/17) é¸æŠžå¿?? mustAnyCheck ã®ãƒã‚§ãƒ?‚¯è¿½åŠ?
420 if( mustAnyCheck != null && mustAnyCheck.length != 0 ) {
421 for( int i=0; i<mustAnyCheck.length; i++ ) {
422 boolean flag = false;
423 String[] mustSub = StringUtil.csv2Array( mustAnyCheck[i],'|' );
424 for( int j=0; j<mustSub.length; j++ ) {
425 // String val = getRequestValue( mustSub[j] );
426 String val = getRequestValue( mustSub[j], false ); // 5.0.0.2 (2009/09/15)
427 if( val != null && val.length() > 0 ) {
428 flag = true; break; // ã²ã¨ã¤ã§ã‚‚nullã§ãªã‘れã°ã€OK
429 }
430 }
431 if( ! flag ) {
432 StringBuilder buf = new StringBuilder();
433 for( int j=0; j<mustSub.length; j++ ) {
434 String clmKey = mustSub[j]; // 5.4.3.4 (2012/01/12)
435 // 5.4.3.4 (2012/01/12) isColumnLabel 追�
436 // buf.append( getResource().getLabel( mustSub[j] ) ).append( "," );
437 String label = (isColumnLabel) ? getDBColumn( clmKey ).getLabel() : getResource().getLabel( clmKey );
438 buf.append( label ).append( "," );
439 }
440 // ERR0036 : é¸æŠžå¿??エラー。以下ã?ãƒ??ã‚¿ã®å†?©ã‚Œã‹ã¯å…¥åŠ›ã—ã¦ãã ã•ã„。key={0}
441 errMsg.addMessage( 0,ErrorMessage.NG,"ERR0036",buf.toString() );
442 }
443 }
444 }
445 if( columns != null && columns.length != 0 ) {
446 for( int i=0; i<columns.length; i++ ) {
447 // 3.8.1.0 (2005/10/24) ãƒªã‚¯ã‚¨ã‚¹ãƒˆæƒ…å ±ã®æ£è¦åŒ–変æ›(DBColumn#valueSet(String))䏿¢
448 // String clmVal = getRequestValue( columns[i] );
449 String clmVal = getRequestValue( columns[i], false ); // 5.0.0.2 (2009/09/15)
450 if( clmVal != null && clmVal.length() > 0 ) {
451 clmVal = StringUtil.replace( clmVal,"%","" ); // 3.8.5.3 (2006/06/30)
452 clmVal = StringUtil.replace( clmVal,"_","" ); // 3.8.5.3 (2006/06/30)
453 DBColumn dbColumn = getDBColumn( columns[i] );
454 // 5.4.3.8 (2012/01/24) checkNames対�
455 if( ( "," + checkNames + "," ).indexOf( "," + columns[i] + "," ) >= 0 ) {
456 String val = dbColumn.valueSet( clmVal );
457 if( val != null ) { clmVal = val; }
458 }
459 // 5.2.2.0 (2010/11/01) DBColumn#valueCheck ã§ã€ç”˜ã?ƒã‚§ãƒ?‚¯ã‚’行ã†ã‚ˆã†ã«ã€å¼•æ•°ã« isStrict を追åŠ?
460 // errMsg.append( dbColumn.valueCheck( clmVal ) );
461 errMsg.append( dbColumn.valueCheck( clmVal,isStrict ) );
462 }
463 }
464 }
465 // 4.0.0 (2005/11/30) æ£è¦è¡¨ç¾ãƒã‚§ãƒ?‚¯ã®è¿½åŠ?
466 if( matchKeys != null && matchKeys.length != 0 ) {
467 for( int i=0; i<matchKeys.length; i++ ) {
468 String clmKey = matchKeys[i]; // 5.4.3.4 (2012/01/12)
469 // String val = getRequestValue( matchKeys[i] );
470 // String val = getRequestValue( matchKeys[i], false ); // 5.0.0.2 (2009/09/15)
471 String val = getRequestValue( clmKey, false ); // 5.0.0.2 (2009/09/15)
472 if( val != null && ! val.matches( matchVals[i] ) ) {
473 // 5.4.3.4 (2012/01/12) isColumnLabel 追�
474 // String label = getLabel( matchKeys[i] );
475 String label = (isColumnLabel) ? getDBColumn( clmKey ).getLabel() : getResource().getLabel( clmKey );
476 // ERR0037 : ãƒ??ã‚¿æ•´åˆæ?エラー。指定ã?ã‚ãƒ¼ã¯æ•´åˆæ?ãƒã‚§ãƒ?‚¯ã®çµæžœãƒžãƒƒãƒã—ã¾ã›ã‚“ã§ã—ãŸã€‚key={0} val={1} regex={2}
477 errMsg.addMessage( 0,ErrorMessage.NG,"ERR0037",label,val,matchVals[i] );
478 }
479 }
480 }
481
482 return errMsg;
483 }
484
485 /**
486 * エントリーãƒ??ã‚¿ã®ErrorMessageã‚’ã‚»ãƒ?ƒˆã—ã¾ã™ã?
487 * 引数ã®ã‚«ãƒ©ãƒ?é…å?よりエントリーãƒ??ã‚¿å½¢å¼ã?ãƒªã‚¯ã‚¨ã‚¹ãƒˆæƒ…å ±ã‚’å–å¾—ã—ã¦ã€?
488 * 値をãƒã‚§ãƒ?‚¯ã—ã¾ã™ã?
489 * DBColumn#valueCheck( String ) ã®çµæžœã®ErrorMessageã‚’ã™ã¹ã¦ append
490 * ã—ã¦ã?ã¾ã™ã?
491 *
492 * @og.rev 3.1.0.0 (2003/03/20) åå‰ã¨è¡Œç•ªå·ã®åŒºåˆ?‚Šè¨˜å·ã‚?"^" ã‹ã‚‰ "__" ã«å¤‰æ›´ã€?
493 * @og.rev 3.5.5.0 (2004/03/12) åå‰ã¨è¡Œç•ªå·ã®åŒºåˆ?‚Šè¨˜å·("__")ã‚’ã?HybsSystem.JOINT_STRING ã«å¤‰æ›´ã€?
494 * @og.rev 3.8.0.9 (2005/10/17) é¸æŠžå¿?? mustAnyCheck ã®ãƒã‚§ãƒ?‚¯è¿½åŠ?
495 * @og.rev 4.1.2.1 (2008/03/13) must , mustAny ã®è‡ªå‹•å–得追åŠ?
496 * @og.rev 4.3.6.4 (2009/05/01) 削除時ã«å¿?šmustAnyãƒã‚§ãƒ?‚¯ã‚¨ãƒ©ãƒ¼ã«ãªã‚‹ãƒã‚°ã‚’ä¿®æ£(書込ã¿å¯èƒ½è¡Œã?ã¿ã‚’å?ç?™ã‚?
497 * @og.rev 4.3.7.0 (2009/06/01) リアルタイãƒ?ƒã‚§ãƒ?‚¯ã®å ´åˆã?ã€must,mustAnyã®è‡ªå‹•ãƒã‚§ãƒ?‚¯ã¯è¡Œã‚ãªã?
498 * @og.rev 5.0.0.2 (2009/09/15) xssãƒã‚§ãƒ?‚¯
499 * @og.rev 5.4.3.4 (2012/01/12) getLabel( String )ã‚’ã?リソースã‹ã‚‰ã«çµ±ä¸?™ã‚‹ã¨ã¨ã‚‚ã«ã€isColumnLabel 対応を行ã†ã€?
500 *
501 * @param errMsg ErrorMessageオブジェク�
502 *
503 * @return カラãƒ?‚ー ??値 ã®ã‚¨ãƒ©ãƒ¼ãƒ¡ãƒ?‚»ãƒ¼ã‚¸ã‚ªãƒ–ジェクãƒ?
504 */
505 private ErrorMessage makeEntryErrorMessage( final ErrorMessage errMsg ) {
506 int[] rowNo = getParameterRows();
507 if( rowNo.length == 0 ) { return errMsg; }
508
509 // 4.1.2.1 (2008/03/13) must , mustAny ã®è‡ªå‹•å–得追åŠ?
510 // table ã‹ã‚‰å–å?ã?(ソート済ã¿)
511 // 4.3.7.0 (2009/06/01) リアルタイãƒ?ƒã‚§ãƒ?‚¯ã®å ´åˆã?ã€must,mustAnyã®è‡ªå‹•ãƒã‚§ãƒ?‚¯ã¯è¡Œã‚ãªã?
512 if( !isRealTime ) {
513 if( nullCheck == null ) { nullCheck = table.getMustArray(); }
514 if( mustAnyCheck == null ) { mustAnyCheck = table.getMustAnyArray(); }
515 }
516
517 // 3.8.0.9 (2005/10/17) é¸æŠžå¿?? mustAnyCheck ã®ãƒã‚§ãƒ?‚¯è¿½åŠ?
518 boolean[][] rowAnyOne = null;
519 // 4.3.6.4 (2009/05/01)
520 boolean[] rowForCheck = null;
521 if( mustAnyCheck != null && mustAnyCheck.length != 0 ) {
522 rowAnyOne = new boolean[rowNo.length][mustAnyCheck.length];
523 rowForCheck = new boolean[rowNo.length];
524 // for( int i=0; i<rowNo.length; i++ ) {
525 // Arrays.fill( rowAnyOne[i],false );
526 // }
527 }
528
529 DBColumn dbColumn = null; // 5.4.3.4 (2012/01/12) isColumnLabel 対�
530 Enumeration<?> enume = getParameterNames(); // 4.3.3.6 (2008/11/15) Genericsè¦å‘Šå¯¾å¿?
531 while( enume.hasMoreElements() ) {
532 String key = (String)(enume.nextElement());
533 int idx = key.lastIndexOf(HybsSystem.JOINT_STRING);
534
535 if( idx > 0 ) {
536 String column = key.substring(0,idx);
537 int row = Integer.parseInt( key.substring(idx + 2) );
538 // String val = getRequestValue( key );
539 String val = getRequestValue( key, false ); // 5.0.0.2 (2009/09/15)
540
541 int i = Arrays.binarySearch( rowNo,row );
542 if( i >= 0 ) {
543 // 5.4.3.4 (2012/01/12) isColumnLabel 対�
544 // DBColumn dbColumn = getDBColumn( column );
545 dbColumn = null;
546 if( isColumnLabel && table != null ) {
547 int clmNo = table.getColumnNo( column,false ); // エラーをå?ã•ãªã??
548 if( clmNo >= 0 ) {
549 dbColumn = table.getDBColumn( clmNo );
550 }
551 }
552 if( dbColumn == null ) {
553 dbColumn = getDBColumn( column );
554 }
555
556 String val2 = dbColumn.valueSet( val );
557 errMsg.append( row+1,dbColumn.valueCheck( val2 ) );
558 if( nullCheck != null && nullCheck.length != 0 ) {
559 int j = Arrays.binarySearch( nullCheck,column );
560 if( j>=0 && ( val2 == null || val2.length() == 0 )) {
561 // ERR0012 : æŒ?®šã?ãƒ??ã‚¿ãŒã‚»ãƒ?ƒˆã•れã¦ã?¾ã›ã‚“ã€?NULLエラー)。key={0}
562 errMsg.addMessage( row+1,ErrorMessage.NG,"ERR0012",dbColumn.getLabel() );
563 }
564 }
565 // 3.8.0.9 (2005/10/17) é¸æŠžå¿?? mustAnyCheck ã®ãƒã‚§ãƒ?‚¯è¿½åŠ?
566 if( rowAnyOne != null ) {
567 for( int j=0; j<mustAnyCheck.length; j++ ) {
568 if( !rowAnyOne[i][j] &&
569 mustAnyCheck[j].indexOf( column ) >= 0 &&
570 val2 != null && val2.length() > 0 ) {
571 rowAnyOne[i][j] = true; // ã©ã‚Œã‹ãŒå˜åœ¨
572 }
573 }
574 // 4.3.6.4 (2009/05/01)
575 rowForCheck[i] = true;
576 }
577
578 // 4.0.0 (2005/11/30) æ£è¦è¡¨ç¾ãƒã‚§ãƒ?‚¯ã®è¿½åŠ?
579 if( matchKeys != null && matchKeys.length != 0 ) {
580 for( int j=0; j<matchKeys.length; j++ ) {
581 if( column.equals( matchKeys[j] ) ) {
582 if( val2 != null && ! val2.matches( matchVals[j] ) ) {
583 // äº’æ›æ€§ã¯ãªããªã£ã¦ã?‚‹ãŒã?æ£è¦è¡¨ç¾ãƒã‚§ãƒ?‚¯ã¯ä½™ã‚Šä½¿ã£ã¦ã?ªã??ã§ã€çµ±ä¸?—ã¦ãŠãã€?
584 // 5.4.3.4 (2012/01/12) isColumnLabel 対�
585 dbColumn = null;
586 if( isColumnLabel && table != null ) {
587 int clmNo = table.getColumnNo( column,false ); // エラーをå?ã•ãªã??
588 if( clmNo >= 0 ) {
589 dbColumn = table.getDBColumn( clmNo );
590 }
591 }
592 if( dbColumn == null ) {
593 dbColumn = getDBColumn( column );
594 }
595 // String label = getLabel( column );
596
597 // ERR0037 : ãƒ??ã‚¿æ•´åˆæ?エラー。指定ã?ã‚ãƒ¼ã¯æ•´åˆæ?ãƒã‚§ãƒ?‚¯ã®çµæžœãƒžãƒƒãƒã—ã¾ã›ã‚“ã§ã—ãŸã€‚key={0} val={1} regex={2}
598 // errMsg.addMessage( 0,ErrorMessage.NG,"ERR0037",label,val2,matchVals[i] );
599 errMsg.addMessage( row+1,ErrorMessage.NG,"ERR0037",dbColumn.getLabel(),val2,matchVals[i] );
600 }
601 break;
602 }
603 }
604 }
605 }
606 }
607 }
608
609 // 3.8.0.9 (2005/10/17) é¸æŠžå¿?? mustAnyCheck ã®ãƒã‚§ãƒ?‚¯è¿½åŠ?
610 if( rowAnyOne != null ) {
611 for( int row=0; row<rowAnyOne.length; row++ ) {
612 // 4.3.6.4 (2009/05/01) 書込ã¿å¯èƒ½è¡Œã?ã¿ã‚’å?ç?™ã‚?
613 if ( rowForCheck[row] ) {
614 for ( int i = 0; i < mustAnyCheck.length; i++ ) {
615 if ( !rowAnyOne[row][i] ) {
616 String[] mustSub = StringUtil.csv2Array( mustAnyCheck[i], '|' );
617
618 StringBuilder buf = new StringBuilder();
619 buf.append( "row=[" ).append( rowNo[row]+1 ).append( "] " );
620 for ( int j = 0; j < mustSub.length; j++ ) {
621 // ã“ã“ã®å‡¦ç? ã‘ã?ä»–ã¨ç•°ãªã‚‹ã?ã¯ã€äº’æ›æ€§é‡è¦–ã?ãŸã‚ã€?é¸æŠžå¿??ã¯åˆ©ç”¨é »åº¦ãŒé«˜ã„ã®ã§ã€?
622 // 5.4.3.4 (2012/01/12) isColumnLabel 対�
623 String label = null ;
624 if( isColumnLabel && table != null ) {
625 int clmNo = table.getColumnNo( mustSub[j],false ); // エラーをå?ã•ãªã??
626 if( clmNo >= 0 ) {
627 dbColumn = table.getDBColumn( clmNo );
628 }
629 if( dbColumn == null ) {
630 dbColumn = getDBColumn( mustSub[j] );
631 }
632 label = dbColumn.getLabel();
633 }
634 else {
635 label = getResource().getLabel( mustSub[j] ); // äº’æ›æ€§ã®ãŸã‚ã®å‡¦ç½®ã€?
636 }
637 // buf.append( getResource().getLabel( mustSub[j] ) ).append( "|" );
638 buf.append( label ).append( "|" );
639 }
640 // ERR0036 : é¸æŠžå¿??エラー。以下ã?ãƒ??ã‚¿ã®å†?©ã‚Œã‹ã¯å…¥åŠ›ã—ã¦ãã ã•ã„。key={0}
641 // errMsg.addMessage( 0, ErrorMessage.NG, "ERR0036", buf.toString() );
642 errMsg.addMessage( rowNo[row]+1, ErrorMessage.NG, "ERR0036", buf.toString() );
643 }
644 }
645 }
646 }
647 }
648
649 return errMsg;
650 }
651
652 /**
653 * ErrorMessageã‚’ã‚»ãƒ?ƒˆã—ã¾ã™ã?
654 * リクエストã•れãŸä»¶æ•°ã®æœ?¤§å€¤ã«åˆ¶é™ã‚’åŠ?ˆã¾ã™ã?
655 * ?‘ä»¶ã?‘ã«ã—ãŸã??åˆã??Œé?常ã¯Viewã§ãƒã‚§ãƒ?‚¯ãƒœãƒƒã‚¯ã‚¹ã‚’使用ã›ãšã«
656 * ラジオボタンを使用ã—ã¦ãã ã•ã„ã€?
657 *
658 * @param errMsg ErrorMessageオブジェク�
659 *
660 * @return カラãƒ?‚ー ??値 ã®ã‚¨ãƒ©ãƒ¼ãƒ¡ãƒ?‚»ãƒ¼ã‚¸ã‚ªãƒ–ジェクãƒ?
661 */
662 private ErrorMessage makeMaxRowCountErrorMessage( final ErrorMessage errMsg ) {
663 if( maxRowCount < 0 ) { return errMsg; } // 無制�
664
665 // 件数制é™ã?ãƒã‚§ãƒ?‚¯
666 int[] rowNo = getParameterRows();
667 int rowCount = rowNo.length ;
668 if( rowCount > maxRowCount ) {
669 // ERR0017 : é¸æŠžã‚¨ãƒ©ãƒ¼ã€‚é¸æŠžè¡Œæ•°({0} ä»¶)ãŒã?æœ?¤§åˆ¶é™å?({1} ä»¶)以上é¸ã°ã‚Œã¾ã—ãŸã€?
670 String arg0 = String.valueOf( rowCount );
671 String arg1 = String.valueOf( maxRowCount );
672 errMsg.addMessage( 0,ErrorMessage.NG,"ERR0017",arg0,arg1 );
673 }
674
675 return errMsg;
676 }
677
678 /**
679 * ErrorMessageã‚’ã‚»ãƒ?ƒˆã—ã¾ã™ã?
680 * リクエストã•れãŸä»¶æ•°ã®æœ?°å?ã«åˆ¶é™ã‚’åŠ?ˆã¾ã™ã?
681 * ?‘ä»¶ã?‘ã«ã—ãŸã??åˆã??Œé?常ã¯Viewã§ãƒã‚§ãƒ?‚¯ãƒœãƒƒã‚¯ã‚¹ã‚’使用ã›ãšã«
682 * ラジオボタンを使用ã—ã¦ãã ã•ã„ã€?
683 *
684 * @param errMsg ErrorMessageオブジェク�
685 *
686 * @return カラãƒ?‚ー ??値 ã®ã‚¨ãƒ©ãƒ¼ãƒ¡ãƒ?‚»ãƒ¼ã‚¸ã‚ªãƒ–ジェクãƒ?
687 */
688 private ErrorMessage makeMinRowCountErrorMessage( final ErrorMessage errMsg ) {
689 if( minRowCount < 0 ) { return errMsg; } // 無制�
690
691 // 件数制é™ã?ãƒã‚§ãƒ?‚¯
692 int[] rowNo = getParameterRows();
693 int rowCount = rowNo.length ;
694 if( rowCount < minRowCount ) {
695 // ERR0018 : é¸æŠžã‚¨ãƒ©ãƒ¼ã€‚é¸æŠžè¡Œæ•°({0} ä»¶)ãŒã?æœ?°åˆ¶é™å?({1} ä»¶)以下é¸ã°ã‚Œã¾ã—ãŸã€?
696 String arg0 = String.valueOf( rowCount );
697 String arg1 = String.valueOf( minRowCount );
698 errMsg.addMessage( 0,ErrorMessage.NG,"ERR0018",arg0,arg1 );
699 }
700
701 return errMsg;
702 }
703
704 /**
705 * ã€TAG】ãƒã‚§ãƒ?‚¯ã™ã¹ãカラãƒ??をカンマ区åˆ?‚Š(CSVå½¢å¼?ã§æŒ?®šã—ã¾ã™ã?
706 *
707 * @og.tag columns="AAA,BBB,CCC,DDD"
708 * åˆ?§£æ–¹æ³•ã?ã€??常ã®ãƒ‘ラメータå–得後ã«ã€CSVåˆ?§£ã—ã¾ã™ã?
709 * "*" を指定ã™ã‚‹ã¨ã€command="NEW" ã®ã¨ãã?判定ã«ã™ã¹ã¦ã®ãƒªã‚¯ã‚¨ã‚¹ãƒˆæ–‡å—å?ã‚?
710 * ãƒã‚§ãƒ?‚¯å¯¾è±¡ã¨ã—ã¾ã™ã?通常ã¯ã€å¿?¦å?ã?‘æŒ?®šã—ã¾ã™ãŒã€å‹•çš?‚«ãƒ©ãƒ?ªã©ã®
711 * å ´åˆã?ã€ã‚«ãƒ©ãƒ?ã‚’äºˆã‚æŒ?®šã§ããªã?Ÿã‚ã?"*" ã§æŒ?®šã§ãるよã†ã«ã—ã¾ã™ã?
712 * ãã?å ´åˆã?"h_" , "hX_" , maxRowCount , command , pageSize , pagePlus ,
713 * GAMENID , BACK_JSPID , BACK_GAMENID ã®äºˆç´?ªžã?ã€å¯¾è±¡ã‹ã‚‰é™¤ãã¾ã™ã?
714 *
715 * @og.rev 3.5.6.2 (2004/07/05) å…ˆã«é…å?ã«åˆ?§£ã—ã¦ã‹ã‚‰ãƒªã‚¯ã‚¨ã‚¹ãƒˆå¤‰æ•°ã®å€¤ã‚’å–å¾?
716 * @og.rev 3.8.8.5 (2007/03/09) 通常ã®ãƒ‘ラメータå–得後ã«ã€CSVåˆ?§£ã«æˆ»ã—ã¾ã™ã?
717 * @og.rev 5.4.3.4 (2012/01/12) command="NEW" ã®ã¨ãã?動的カラãƒ?¯¾å¿? "*" ã§ã™ã¹ã¦ã®ãƒªã‚¯ã‚¨ã‚¹ãƒ?
718 *
719 * @param clms カラ�?(CSV形�
720 */
721 public void setColumns( final String clms ) {
722 columns = StringUtil.csv2Array( getRequestParameter( clms ) );
723 if( columns.length == 0 ) { columns = null; }
724
725 // 5.4.3.4 (2012/01/12) command="NEW" ã®ã¨ãã?動的カラãƒ?¯¾å¿? "*" ã§ã™ã¹ã¦ã®ãƒªã‚¯ã‚¨ã‚¹ãƒ?
726 if( columns != null && "*".equals( columns[0] ) ) {
727 Set<String> clmSet = new TreeSet<String>(); // リクエストã?ãƒãƒ©ãƒãƒ©ãªã®ã§ã€ã¨ã‚Šã‚ãˆãšã‚½ãƒ¼ãƒˆã—ã¦ãã¾ã™ã?
728
729 Enumeration<?> enume = getParameterNames(); // Genericsè¦å‘Šå¯¾å¿?
730 while( enume.hasMoreElements() ) {
731 String clm = (String)(enume.nextElement());
732 // 予ç´?ªžä»¥å¤–を登録ã—ã¾ã™ã?
733 if( clm != null && !clm.isEmpty() && !clm.startsWith( "h_" ) && !clm.startsWith( "hX_" ) ) {
734 clmSet.add( clm );
735 }
736 }
737 // 予ç´?ªžã‚’削除ã—ã¾ã™ã?
738 clmSet.remove( "maxRowCount" );
739 clmSet.remove( "command" );
740 clmSet.remove( "pageSize" );
741 clmSet.remove( "pagePlus" );
742 clmSet.remove( "GAMENID" );
743 clmSet.remove( "BACK_JSPID" );
744 clmSet.remove( "BACK_GAMENID" );
745
746 columns = clmSet.toArray( new String[clmSet.size()] );
747 }
748 }
749
750 /**
751 * ã€TAG】NULL ãƒã‚§ãƒ?‚¯ã™ã¹ãカラãƒ??をカンマ区åˆ?CSVå½¢å¼?ã‚Šã§æŒ?®šã—ã¾ã™ã?
752 *
753 * @og.tag
754 * (must 属æ?ã®ã‚»ãƒ?ƒˆã«ã‚ˆã‚Šã€è?å‹•å?ç?•れã¾ã?
755 * nullCheck="AAA,BBB,CCC,DDD"
756 * åˆ?§£æ–¹æ³•ã?ã€??常ã®ãƒ‘ラメータå–得後ã«ã€CSVåˆ?§£ã—ã¾ã™ã?
757 *
758 * @og.rev 3.5.6.2 (2004/07/05) å…ˆã«é…å?ã«åˆ?§£ã—ã¦ã‹ã‚‰ãƒªã‚¯ã‚¨ã‚¹ãƒˆå¤‰æ•°ã®å€¤ã‚’å–å¾?
759 * @og.rev 3.8.8.5 (2007/03/09) 通常ã®ãƒ‘ラメータå–得後ã«ã€CSVåˆ?§£ã«æˆ»ã—ã¾ã™ã?
760 *
761 * @param clms カラ�?(CSV形�
762 */
763 public void setNullCheck( final String clms ) {
764 nullCheck = StringUtil.csv2Array( getRequestParameter( clms ) );
765 if( nullCheck.length == 0 ) { nullCheck = null; }
766 else {
767 Arrays.sort( nullCheck );
768 }
769 }
770
771 /**
772 * ã€TAGã€‘é¸æŠžå¿??カラãƒ?æŒ?®šã?カラãƒ??å†?œ€ä½Žã?ã¨ã¤ãŒNULLã§ãªã?ã‚?AA|BB|CC,XX|YY|ZZ" å½¢å¼ã§æŒ?®šã—ã¾ã™ã?
773 *
774 * @og.tag
775 * (mustAny 属æ?ã®ã‚»ãƒ?ƒˆã«ã‚ˆã‚Šã€è?å‹•å?ç?•れã¾ã?
776 * è¤?•°ã®ã‚«ãƒ©ãƒ?±žæ?ã®å€¤ã®ã?¡ã€ã©ã‚Œã‹ã?null ã§ãªã??åˆã?æ£å¸¸ã¨ã—ã?
777 * ã™ã¹ã¦ã?null ã®å ´åˆã‚’è¦å‘Šã—ã¾ã™ã?
778 *
779 * 例:mustAnyCheck="AA|BB|CC"
780 * AA,BB,CC ã®ã‚«ãƒ©ãƒ?§é¸æŠžå¿??(ã™ã¹ã¦ãŒnullãªã‚‰ã‚¨ãƒ©ãƒ¼)
781 * 例:mustAnyCheck="AA|BB|CC,XX|YY|ZZ"
782 * AA,BB,CC ã®ã‚»ãƒ?ƒˆã¨ã€XX,YY,ZZã®ã‚»ãƒ?ƒˆã§ãれãžã‚Œé¸æŠžå¿??ã€?
783 * 例:mustAnyCheck="AA|XX,AA|YY,AA|ZZ"
784 * AA ã«å€¤ãŒã‚れã?ã™ã¹ã¦æˆç«‹ã?ãã†ã§ãªã??åˆã?ã€XX 㨠YY 㨠ZZ ãŒã™ã¹ã¦å¿??ã€?
785 * 例:mustAnyCheck="AA|BB,BB|CC,AA|CC"
786 * AA,BB,CC ã®å†??ã©ã‚Œã‹?’ã¤ãŒå¿??ã€?AãŒæ?ç«‹ã™ã‚Œã?BBã‹CCãŒå¿??ã€‚åŒæ§˜ã«ã€?
787 * BBãŒæ?ç«‹ã™ã‚Œã?ã€AAã‹CCãŒå¿??ã€?
788 *
789 * é¸æŠžå¿??ã¯ã€must ã¨åŒæ§˜ã«ã€è‰²ã¥ã‘を行ã†(query.jsp)ç”»é¢ã§ã¯ã€mustAny 属æ?ã‚?
790 * ã‚»ãƒ?ƒˆã—ã¾ã™ã?ãƒã‚§ãƒ?‚¯ã‚’行ã†(result.jsp)ç”»é¢ã§ã¯ã€columnCheck ã‚¿ã‚°ã®
791 * mustAnyCheck 属æ?ã«ã€?¸æŠžå¿??カラãƒ?‚’æŒ?®šã—ã¾ã™ã?(上記å‚ç…§)
792 * column ã‚¿ã‚°ç‰ã? mustAny 属æ?ã«ã€mustAny="true" ã¨ã‚»ãƒ?ƒˆã™ã‚‹ã¨ã€ç”Ÿæˆã•れる
793 * HTMLã¯ã€class="mustAny" ãŒå?力ã•れã¾ã™ã?エンジン標準ã§ã¯ã€default.css ã«
794 * .mustAny ãŒå®šç¾©ã•れã¦ã?¾ã™ã?( background-color: #CCFFFF; )
795 * ãªãŠã?mustAny 属æ?ã«ã€true 以外ã?値をセãƒ?ƒˆã—ãŸå ´å?mustAny="XYZ")ã¯ã€?
796 * 生æ?ã•れるHTMLã«ã€class="XYZ" ãŒå?力ã•れã¾ã™ã?ã“れã¯ã€è¤?•°ã®ã‚°ãƒ«ãƒ¼ãƒ—é–“ã§
797 * 色を変ãˆã¦ã€?¸æŠžå¿??を指定ã™ã‚‹å?åˆã«ä½¿ç”¨ã—ã¾ã™ã?色ã¯ã€custom/custom.css
798 * ã§æŒ?®šã—ã¾ã™ã?
799 * åˆ?§£æ–¹æ³•ã?ã€??常ã®ãƒ‘ラメータå–得後ã«ã€CSVåˆ?§£ã—ã¾ã™ã?
800 *
801 * @og.rev 3.8.0.9 (2005/10/17) æ–°è¦è¿½åŠ?
802 * @og.rev 3.8.8.5 (2007/03/09) 通常ã®ãƒ‘ラメータå–得後ã«ã€CSVåˆ?§£ã«æˆ»ã—ã¾ã™ã?
803 *
804 * @param clms é¸æŠžå¿??カラãƒ?
805 */
806 public void setMustAnyCheck( final String clms ) {
807 mustAnyCheck = StringUtil.csv2Array( getRequestParameter( clms ) );
808 if( mustAnyCheck.length == 0 ) { mustAnyCheck = null; }
809 else {
810 Arrays.sort( mustAnyCheck );
811 }
812 }
813
814 /**
815 * ã€TAG】コマンド[NEW/RENEW/ENTRY]ã‚’ã‚»ãƒ?ƒˆã—ã¾ã?åˆæœŸå€¤:NEW)ã€?
816 *
817 * @og.tag
818 * コマンドã?,HTMLã‹ã‚‰(get/post)æŒ?®šã•れã¾ã™ã?ã§,CMD_xxx ã§è¨å®šã•れる
819 * フィールド定数値ã®ã?¥ã‚Œã‹ã‚’ã?æŒ?®šã§ãã¾ã™ã?
820 * 何もè¨å®šã•れãªã??ã¾ãŸã?ã€null ã®å ´åˆã?ã€?NEW" ãŒå?期å?ã«ã‚»ãƒ?ƒˆã•れã¾ã™ã?
821 *
822 * @param cmd コマンãƒ?public static final 宣è¨?•れã¦ã?‚‹æ–?—å?)
823 * @see <a href="../../../../constant-values.html#org.opengion.hayabusa.taglib.ColumnCheckTag.CMD_NEW">コマンド定数</a>
824 */
825 public void setCommand( final String cmd ) {
826 String cmd2 = getRequestParameter( cmd );
827 if( cmd2 != null && cmd2.length() > 0 ) { command = cmd2.toUpperCase(Locale.JAPAN); }
828 }
829
830 /**
831 * ã€TAGã€?ãƒã‚§ãƒ?‚¯å¯¾è±¡ã®ãƒ??ã‚¿[AUTO/NEW/ENTRY]を指定ã—ã¾ã?åˆæœŸå€¤:AUTO)ã€?
832 *
833 * @og.tag
834 * 通常ã®ãƒªã‚¯ã‚¨ã‚¹ãƒˆãƒ‡ãƒ¼ã‚¿ã¯ã€ã‚ーãã?ã‚‚ã?ã§ã™ãŒ,エントリãƒ??ã‚¿ã¯è¡¨å½¢å¼ã?
835 * ãƒ??ã‚¿ã‚’ä¸?‹¬ã§ç™»éŒ²ã™ã‚‹ç‚ºã€?ã‚ー??__" ??行番å·)å½¢å¼ã‚’ã€ãƒãƒ©ã™å¿?¦ãŒã‚りã¾ã™ã?
836 *
837 * ENTRY ã¯ã€DBTableModelã®ãƒªã‚¯ã‚¨ã‚¹ãƒˆæƒ…å ±ã‚’ãƒã‚§ãƒ?‚¯ã—ã¾ã™ã?
838 * ã“れã¯ã€å?ãƒ??ã‚¿ãŒå¯¾è±¡ã«ãªã‚Šã¾ã™ã?(columns/nullCheck 属æ?ã¯ç„¡åй)
839 * AUTO ã¯ã€command ãŒã?上è¨?NEW ã?ENTRY ã‹ã‚’判æ–ã—ã¦å‡¦ç?‚’振りå?ã‘ã¾ã™ã?
840 * åˆæœŸå€¤ã¯ã€AUTO ã§ã™ã?
841 *
842 * @param flag ãƒã‚§ãƒ?‚¯å¯¾è±¡ã®ãƒ??ã‚¿(AUTO,NEW,ENTRY)
843 */
844 public void setCheckType( final String flag ) {
845 String ct = getRequestParameter( flag );
846 if( ct != null && ct.length() > 0 ) { checkType = ct ; }
847 }
848
849 /**
850 * ã€TAG】ãƒã‚§ãƒ?‚¯ã§é¸æŠžã•れãŸè¡Œæ•°ã®æœ?¤§å€¤ã‚’è¨å®šã—ã¾ã™ã?
851 *
852 * @og.tag
853 * æœ?¤§é¸æŠžä»¶æ•°ã‚’è¶?ˆãŸå?åˆã?,エラーメãƒ?‚»ãƒ¼ã‚¸ã‚’è¿”ã—ã¾ã™ã?
854 * 例ãˆã°ã€?¼‘ä»¶ã®ã¿ã‚’æ£å¸¸ã¨ã™ã‚‹å ´åˆã?ã€maxRowCount="1" ã¨ã—ã¾ã™ã?
855 *
856 * @param count 制é™ã‚’ã‹ã‘ãŸã„行数(ã“ã?ä»¶æ•°ã¨åŒã˜å ´åˆã?æ£å¸¸ )
857 */
858 public void setMaxRowCount( final String count ) {
859 maxRowCount = nval( getRequestParameter( count ),maxRowCount );
860 }
861
862 /**
863 * ã€TAG】ãƒã‚§ãƒ?‚¯ã§é¸æŠžã•れãŸè¡Œæ•°ã®æœ?°å?ã‚’è¨å®šã—ã¾ã™ã?
864 *
865 * @og.tag
866 * æœ?°é¸æŠžä»¶æ•°ã‚’è¶?ˆãªã??åˆã?ã€ã‚¨ãƒ©ãƒ¼ãƒ¡ãƒ?‚»ãƒ¼ã‚¸ã‚’è¿”ã—ã¾ã™ã?
867 * 例ãˆã°ã€?¼‘ä»¶ã®ã¿ã‚’æ£å¸¸ã¨ã™ã‚‹å ´åˆã?ã€minRowCount="1" ã¨ã—ã¾ã™ã?
868 *
869 * @param count 制é™ã‚’ã‹ã‘ãŸã„行数(ã“ã?ä»¶æ•°ã¨åŒã˜å ´åˆã?æ£å¸¸ )
870 */
871 public void setMinRowCount( final String count ) {
872 minRowCount = nval( getRequestParameter( count ), minRowCount );
873 }
874
875 /**
876 * ã€TAGã€?通常ã¯ä½¿ã?¾ã›ã‚“)çµæžœã®DBTableModelã‚’ã?sessionã«ç™»éŒ²ã™ã‚‹ã¨ãã?ã‚ーを指定ã—ã¾ã?
877 * (åˆæœŸå€¤:HybsSystem#TBL_MDL_KEY[={@og.value org.opengion.hayabusa.common.HybsSystem#TBL_MDL_KEY}])ã€?
878 *
879 * @og.tag
880 * æ¤œç´¢çµæžœã‚ˆã‚Šã€DBTableModelオブジェクトを作æ?ã—ã¾ã™ã?ã“れをã?下æµã?viewã‚¿ã‚°ç‰ã«
881 * 渡ã™å?åˆã«ã€??常ã¯ã€session を利用ã—ã¾ã™ã?ãã?å ´åˆã?登録ã‚ーã§ã™ã?
882 * query ã‚¿ã‚°ã‚’åŒæ™‚ã«å®Ÿè¡Œã—ã¦ã€çµæžœã‚’求ã‚ã‚‹å?åˆã?åŒä¸?ƒ¡ãƒ¢ãƒªã«é…ç½®ã•れる為ã€?
883 * ã“ã? tableId 属æ?を利用ã—ã¦ã€ãƒ¡ãƒ¢ãƒªç©ºé–“ã‚’åˆ?‘ã¾ã™ã?
884 * (åˆæœŸå€¤:HybsSystem#TBL_MDL_KEY[={@og.value org.opengion.hayabusa.common.HybsSystem#TBL_MDL_KEY}])ã€?
885 *
886 * @param id sessionã«ç™»éŒ²ã™ã‚‹æ™‚ã? ID
887 */
888 public void setTableId( final String id ) {
889 tableId = nval( getRequestParameter( id ),tableId );
890 }
891
892 /**
893 * ã€TAG】æ£è¦è¡¨ç¾ã§ã®ãƒžãƒƒãƒãƒ³ã‚°ã‚’行ã†ã‚«ãƒ©ãƒ??をカンマ区åˆ?‚Š(CSVå½¢å¼?ã§æŒ?®šã—ã¾ã™ã?
894 *
895 * @og.tag matchKeys="AAA,BBB,CCC,DDD"
896 * matchKeys属æ?ã¨matchVals属æ?ã®å€‹æ•°ã¯ã€åŒã˜ã§ãªã‘れã°ãªã‚Šã¾ã›ã‚“ã€?
897 * å…ˆã«é…å?ã«åˆ?§£ã—ã¦ã‹ã‚‰ãƒªã‚¯ã‚¨ã‚¹ãƒˆå¤‰æ•°ã®å€¤ã‚’å–å¾—ã™ã‚‹ã‚ˆã?«ã—ã¾ã™ã?
898 * ã“ã†ã™ã‚‹äº‹ã§ã€ãƒªã‚¯ã‚¨ã‚¹ãƒˆã«ã‚«ãƒ³ãƒžåŒºåˆ?‚Šã®å€¤ã‚’è¨å®šã§ãるよã†ã«ãªã‚Šã¾ã™ã?
899 *
900 * @og.rev 4.0.0.0 (2005/11/30) æ–°è¦ä½œæ?
901 *
902 * @param keys カラ�?(CSV形�
903 * @see #setMatchVals( String )
904 */
905 public void setMatchKeys( final String keys ) {
906 matchKeys = getCSVParameter( keys );
907
908 if( matchVals != null && matchKeys.length != matchVals.length ) {
909 String errMsg = "matchKeys属æ?ã¨matchVals属æ?ã®å€‹æ•°ãŒåˆã?¾ã›ã‚“ã€?
910 + HybsSystem.CR
911 + " matchKeys=[" + matchKeys.length + "]:KEYS="
912 + StringUtil.array2csv( matchKeys ) + HybsSystem.CR
913 + " matchVals=[" + matchVals.length + "]:VLAS="
914 + StringUtil.array2csv( matchVals ) + HybsSystem.CR ;
915 throw new HybsSystemException( errMsg );
916 }
917 }
918
919 /**
920 * ã€TAG】æ£è¦è¡¨ç¾ã§ã®ãƒžãƒƒãƒãƒ³ã‚°ã‚’行ã†ã‚«ãƒ©ãƒ??ã«å¯¾ã™ã‚‹å€¤(æ£è¦è¡¨ç¾)をカンマ区åˆ?‚Š(CSVå½¢å¼?ã§æŒ?®šã—ã¾ã™ã?
921 *
922 * @og.tag matchVals="AAA,BBB,CCC,DDD"
923 * matchKeys属æ?ã¨matchVals属æ?ã®å€‹æ•°ã¯ã€åŒã˜ã§ãªã‘れã°ãªã‚Šã¾ã›ã‚“ã€?
924 * å…ˆã«é…å?ã«åˆ?§£ã—ã¦ã‹ã‚‰ãƒªã‚¯ã‚¨ã‚¹ãƒˆå¤‰æ•°ã®å€¤ã‚’å–å¾—ã™ã‚‹ã‚ˆã?«ã—ã¾ã™ã?
925 * ã“ã†ã™ã‚‹äº‹ã§ã€ãƒªã‚¯ã‚¨ã‚¹ãƒˆã«ã‚«ãƒ³ãƒžåŒºåˆ?‚Šã®å€¤ã‚’è¨å®šã§ãるよã†ã«ãªã‚Šã¾ã™ã?
926 *
927 * @og.rev 4.0.0.0 (2005/11/30) æ–°è¦ä½œæ?
928 *
929 * @param vals カラãƒ??ã«å¯¾ã™ã‚‹å€¤(æ£è¦è¡¨ç¾)(CSVå½¢å¼?
930 * @see #setMatchKeys( String )
931 */
932 public void setMatchVals( final String vals ) {
933 matchVals = getCSVParameter( vals );
934
935 if( matchKeys != null && matchKeys.length != matchVals.length ) {
936 String errMsg = "matchKeys属æ?ã¨matchVals属æ?ã®å€‹æ•°ãŒåˆã?¾ã›ã‚“ã€?
937 + HybsSystem.CR
938 + " matchKeys=[" + matchKeys.length + "]:KEYS="
939 + StringUtil.array2csv( matchKeys ) + HybsSystem.CR
940 + " matchVals=[" + matchVals.length + "]:VLAS="
941 + StringUtil.array2csv( matchVals ) + HybsSystem.CR ;
942 throw new HybsSystemException( errMsg );
943 }
944 }
945
946 /**
947 * ã€TAGã€?通常使ã?¾ã›ã‚“)リアルタイãƒ?ƒã‚§ãƒ?‚¯ã‚’行ã†å ´åˆã«æœ‰åйã«ã—ã¾ã™ã?
948 *
949 * @og.tag
950 * リアルタイãƒ?ƒã‚§ãƒ?‚¯ã‚’行ã†å ´åˆã«æœ‰åйã«ã™ã‚‹å±žæ?ã§ã™ã?
951 * trueãŒæŒ‡å®šã•れãŸå ´åˆã?通常ã®ãƒã‚§ãƒ?‚¯ã¨æ¯”è¼?—ã€ä»¥ä¸‹ã?差異ãŒã‚りã¾ã™ã?
952 * â‘?‚¨ãƒ©ãƒ¼çµæžœã‚’簡易フォーマットã§å‡ºåŠ›ã—ã¾ã™ã?
953 * (ViewFormType="HTMLSimpleErrorList"ã§è¡¨ç¤ºã•れã¾ã™ã?)
954 * ã“ã?簡易フォーマットã§å‡ºåŠ›ã—ãŸå?åˆã?ã€ãƒ©ãƒ™ãƒ«(çŸ)ã®å®šç¾©ã§å‡ºåŠ›ã•れã?
955 * カラãƒ?ã‚?ƒ‡ãƒ¼ã‚¿ç‰ã?出力ã•れã¾ã›ã‚“ã€?
956 * â‘¡must,mustAny属æ?ã®ãƒã‚§ãƒ?‚¯ã‚’行ã„ã¾ã›ã‚“ã€?
957 * å¿??åŠã?é¸æŠžå¿??ã¯ã€è¦–覚的ã«åˆ¤åˆ¥ã§ãã‚‹ãŸã‚ã€ãƒªã‚¢ãƒ«ã‚¿ã‚¤ãƒ?ƒã‚§ãƒ?‚¯ã®
958 * 対象外ã¨ã—ã¾ã™ã?
959 *
960 * @og.rev 4.3.3.0 (2008/10/01) æ–°è¦ä½œæ?
961 * @og.rev 4.3.7.0 (2009/06/01) viewSimple属æ?å称変更 â‡?isRealTime
962 *
963 * @param flg 簡易表示を行ã†ã‹ã©ã?‹
964 */
965 public void setRealTime( final String flg ) {
966 isRealTime = nval( getRequestParameter( flg ),isRealTime );
967 }
968
969 /**
970 * ã€TAG】NEWã®å ´åˆã«ã€å޳å¯?«ãƒã‚§ãƒ?‚¯ã™ã‚‹ã‹ã©ã?‹[true/false]を指定ã—ã¾ã?åˆæœŸå€¤:false)ã€?
971 *
972 * @og.tag
973 * ãƒ??ã‚¿ã‚’ãƒã‚§ãƒ?‚¯ã™ã‚‹ã«å½“ãŸã‚Šã?ã‚ã„ã¾ã?¤œç´¢ãªã©ã§å޳å¯?«ãƒã‚§ãƒ?‚¯ã™ã‚‹ã¨
974 * エラーã«ãªã‚‹ã‚±ãƒ¼ã‚¹ãŒã‚ã‚‹ãŸã‚ã?command="NEW" ã®ãƒã‚§ãƒ?‚¯æ™‚ã«ã¯ã€ç”˜ã?›®ã®
975 * ãƒã‚§ãƒ?‚¯ã‚’行ã£ã¦ã?¾ã™ã?DBColumn#valueCheck( String , false )
976 * command="ENTRY" ã®ãƒã‚§ãƒ?‚¯ã¯ã€å޳å¯?ªãƒã‚§ãƒ?‚¯ã§ã™ã?
977 * ã“ã?フラグã¯ã€æ¤œç´¢æ™‚ã§ã‚‚ã?厳å¯?ªãƒã‚§ãƒ?‚¯ã‚’行ã„ãŸã„å ´åˆã«ã€true ã‚’ã‚»ãƒ?ƒˆã—ã¾ã™ã?
978 *
979 * @og.rev 5.2.2.0 (2010/11/01) æ–°è¦ä½œæ?
980 *
981 * @param flg 厳å¯?«ãƒã‚§ãƒ?‚¯ã™ã‚‹ã‹ã©ã?‹ [true:厳å¯?false:甘ã„]
982 */
983 public void setUseStrict( final String flg ) {
984 isStrict = nval( getRequestParameter( flg ),isStrict );
985 }
986
987 /**
988 * ã€TAG】カラãƒ?ƒ©ãƒ™ãƒ«ã‚’使用ã™ã‚‹ã‹ã©ã?‹[true/false]を指定ã—ã¾ã?åˆæœŸå€¤:false)ã€?
989 *
990 * @og.tag
991 * カラãƒ?ƒ©ãƒ™ãƒ«ã¯ãƒ©ãƒ™ãƒ«ãƒãƒ¼ãƒ??を利用ã›ãšã«ã‚¢ãƒ—リケーションå´ã§
992 * 追åŠ?—ãŸãƒ©ãƒ™ãƒ«ã‚’ResourceManagerã«ã‚ャãƒ?‚·ãƒ¥ã—ã¦ã?‚‹æ‰?‹ã‚‰å–りå?ã?
993 * ã‹ã©ã?‹ã‚’指定ã—ã¾ã™ã?
994 * カラãƒ?ƒ©ãƒ™ãƒ«ã«å˜åœ¨ã—ãªã??åˆã?ã€??常ã®ãƒ©ãƒ™ãƒ«ã‹ã‚‰æ¤œç´¢ã—ã¾ã™ã?
995 *
996 * @og.rev 5.4.3.4 (2012/01/12) æ–°è¦ä½œæ?
997 *
998 * @param flg カラãƒ?ƒ©ãƒ™ãƒ«ã‚’使用ã™ã‚‹ã‹ã©ã?‹ true:ã™ã‚‹/false:ã—ãªã„]
999 */
1000 public void setUseColumnLabel( final String flg ) {
1001 isColumnLabel = nval( getRequestParameter( flg ),isColumnLabel );
1002 }
1003
1004 /**
1005 * ã€TAG】ラベルをDBTableModel ã®ã‚«ãƒ©ãƒ?‹ã‚‰å–å¾—ã™ã‚‹ã‹ã©ã?‹ã‚’指定ã—ã¾ã?åˆæœŸå€¤:false)ã€?
1006 *
1007 * @og.tag
1008 * エラー時ã?ラベルã¯é€šå¸¸ã¯ãƒ©ãƒ™ãƒ«ãƒªã‚½ãƒ¼ã‚¹ã‹ã‚‰å–å¾—ã—ã¦ã?¾ã™ãŒã€?
1009 * ColumnEditorç‰ã§ã€ãƒ©ãƒ™ãƒ«ã‚’æ›¸ãæ›ãˆãŸå ´åˆã?ç”»é¢ã«è¡¨ç¤ºã•れã¦ã?‚‹åç§°ã¨
1010 * エラー時ã«è¡¨ç¤ºã•れるåç§°ãŒç•°ãªã‚‹ã“ã¨ãŒã‚りã¾ã—ãŸã€?
1011 * ãã“ã§ã€command=ENTRY 時ã«ã€ãƒ©ãƒ™ãƒ«ã‚’ã?DBTableModel ã®ã‚«ãƒ©ãƒ?‹ã‚‰å–å¾?
1012 * ã™ã‚‹ã‚ˆã†ã«è¨å®šã§ãるよã†ã«ã—ã¾ã—ãŸã€?
1013 * DBTableModel ã«è©²å½“ã™ã‚‹ã‚«ãƒ©ãƒ?Œå˜åœ¨ã—ãªã??åˆã?ラベルリソースã‹ã‚‰å–å¾—ã—ã¾ã™ã?
1014 * 通常ã¯ã€ã“ã®æ–¹æ³•ãŒä¸»ã§ã™ãŒã€?ŽåŽ»ã®äº’æ›æ€§ã‚’è?æ…®ã—ã?åˆæœŸå€¤ã¯ã€false ã«
1015 * ã—ã¦ã?¾ã™ã?
1016 *
1017 * @og.rev 5.4.3.4 (2012/01/12) æ–°è¦ä½œæ?
1018 *
1019 * @param flg カラãƒ?ƒ©ãƒ™ãƒ«ã‚’使用ã™ã‚‹ã‹ã©ã?‹(true:ã™ã‚‹/false:ã—ãªã?
1020 */
1021 // public void setUseTblClmLbl( final String flg ) {
1022 // isTblClmLbl = nval( getRequestParameter( flg ),isTblClmLbl );
1023 // }
1024
1025 /**
1026 * ã€TAGã€‘ãƒªã‚¯ã‚¨ã‚¹ãƒˆå¤‰æ•°ã®æ£è¦åŒ–を行ã†ã‚«ãƒ©ãƒ?‚’CSVå½¢å¼ã§è¤?•°æŒ?®šã—ã¾ã™ã?
1027 *
1028 * @og.tag
1029 * カラãƒ?ƒã‚§ãƒ?‚¯ã§æ£è¦åŒ–ãŒè¡Œã‚れã¦ã?ªã??ラグインã«å¯¾ã—ã¦å¼·åˆ¶çš?«æ£è¦åŒ–を行ã„ã¾ã™ã?
1030 * ã“ã?属æ?を利用ã—ãŸãƒã‚§ãƒ?‚¯ã‚’行ã£ãŸå?åˆã?ã€queryã‚¿ã‚°ã§PL/SQLを動作ã•ã›ã‚‹å ´åˆã«ã‚?
1031 * åŒå属æ?ã§ã‚«ãƒ©ãƒ??æŒ?®šã‚’行ã†å¿?¦ãŒã‚りã¾ã™ã?
1032 * (queryã‚¿ã‚°ã§checkNamesを利用ã—ãªã??åˆã?ã“ã?属æ?ã¯nullã«ã—ã¦ãã ã•ã„)
1033 * ã“ã?属æ?ã¯ãƒã‚§ãƒ?‚¯ã‚¿ã‚¤ãƒ—ãŒNEWã®å ´åˆã?ã¿æœ‰åйã§ã™ã?
1034 * リアルタイãƒ?ƒã‚§ãƒ?‚¯ã§ã“ã?機è?を利用ã—ãŸã??åˆã?ã€columnTagç‰ã?optionAttributes
1035 * 属æ?ã«rtOption='checkNames=VIEW_DATE'ã®ã‚ˆã†ã«è¨˜è¿°ã—ã¦ãã ã•ã„ã€?
1036 *
1037 * @og.rev 5.4.3.8 (2012/01/24) æ–°è¦è¿½åŠ?
1038 * @og.rev 5.4.4.0 (2012/02/01) コメント修æ£
1039 * @og.rev 5.6.9.4 (2013/10/31) 空白削除を行ã†
1040 *
1041 * @param nm ãƒªã‚¯ã‚¨ã‚¹ãƒˆå¤‰æ•°ã®æ£è¦åŒ–を行ã†ã‚«ãƒ©ãƒ?
1042 */
1043 public void setCheckNames( final String nm ) {
1044 // checkNames = nval( getRequestParameter( nm ),checkNames );
1045 checkNames = StringUtil.deleteWhitespace( nval( getRequestParameter( nm ),checkNames ) ); // 5.6.9.4 (2013/10/31)
1046 }
1047
1048 /**
1049 * ã“ã?オブジェクトã?æ–?—å?表ç¾ã‚’è¿”ã—ã¾ã™ã?
1050 * 基本çš?«ãƒ?ƒãƒ?‚°ç›®çš?«ä½¿ç”¨ã—ã¾ã™ã?
1051 *
1052 * @return ã“ã?ã‚¯ãƒ©ã‚¹ã®æ–?—å?表ç¾
1053 */
1054 @Override
1055 public String toString() {
1056 return org.opengion.fukurou.util.ToString.title( this.getClass().getName() )
1057 .println( "VERSION" ,VERSION )
1058 .println( "tableId" ,tableId )
1059 .println( "command" ,command )
1060 .println( "columns" ,columns )
1061 .println( "nullCheck" ,nullCheck )
1062 .println( "mustAnyCheck" ,mustAnyCheck )
1063 .println( "maxRowCount" ,maxRowCount )
1064 .println( "minRowCount" ,minRowCount )
1065 .println( "checkType" ,checkType )
1066 .println( "matchKeys" ,matchKeys )
1067 .println( "matchVals" ,matchVals )
1068 .println( "realTime" ,isRealTime )
1069 .println( "bodyString" ,StringUtil.htmlFilter( bodyString ) )
1070 .println( "Other..." ,getAttributes().getAttribute() )
1071 .fixForm().toString() ;
1072 }
1073 }