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.io.File;
021    import java.io.IOException;
022    import java.util.Arrays;
023    import java.util.List;
024    import java.util.ArrayList;
025    
026    import javax.servlet.http.HttpServletRequest;
027    
028    import org.opengion.fukurou.util.StringUtil;
029    import org.opengion.hayabusa.common.HybsSystem;
030    import org.opengion.hayabusa.common.HybsSystemException;
031    import org.opengion.hayabusa.db.DBColumn;
032    import org.opengion.hayabusa.db.DBTableModel;
033    import org.opengion.hayabusa.db.DBTableModelUtil;
034    import org.opengion.hayabusa.servlet.MultipartRequest;
035    import org.opengion.hayabusa.servlet.UploadedFile;
036    
037    /**
038     * クライアント?ファイルをサーバ?にア??ロードするタグです?
039     *
040     * ア??ロード後?属?は、DBTableModel に格納することにより??常の??タと
041     * 同様?取り出し方が可能です?
042     * また?通常のファイルア??ロード時の、form で使用する、enctype="multipart/form-data"
043     * を指定した?合?、他?リクエスト情報も?{@XXXX} 変数で取り出すことが可能です?
044     *
045     * こ? upload タグでは、ア??ロード後に、指定?ファイル名に変更する機?があります?
046     * file 登録?アログで?し?name に?_NEW" と?名称を付けたリクエスト??
047     * ファイルのア??ロードと同時に送信することで、この名前にファイルを付け替えます?
048     * また?ア??ロード後?ファイル名?、name ??名称で、取り?せます?
049     * クライアントから登録したオリジナルのファイル名?、name に?_ORG" と?名称
050     * で取り出すことが可能です?
051     *
052     * 通常では、これらのパラメータを?RequestAttribute 変数にセ?します?で、{@XXXX}で
053     * 取り出すことが可能になります?さらに?KEY","VALUE","ISFILE" のカラ?持った?
054     * DBTableModel にセ?します?
055     *
056     * 新機?として、columns を指定する事で、columns のカラ?持つ DBTableModel にセ?します?
057     * そ?場合?、カラ?_01 ??カラ?_99 のように、アン??バ?で列データとなるキーを定義してください?
058     * アン??バ?がな??合?、カラ?け作?されます?カラ?と同じリクエストがあれば?
059     * すべてのレコードに同じ値がセ?されます?
060     *
061     * 新ファイル名に拡張子が設定されて???合?、オリジナルファイル名?拡張子をセ?します?
062     *
063     * HTML5 の type="file" 時? multiple 属??ア??ロードファイルの?選択機??に対応します?(5.7.1.1 (2013/12/13))
064     * そ?場合?、新しいファイル名への変更はできません。オリジナルのファイル名でア??ロードされま?
065     *
066     * 5.7.1.2 (2013/12/20) zip 対?
067     * filename 属?に?.zip" の拡張子?ファイル名を?した?合?、ア??ロードされた??のファイル?
068     * ZIP圧縮します?これは、ア??ロード後?処?なります?
069     * ZIP圧縮のオリジナルファイルは、そのまま残ります?
070     * なお?ZIPファイルは、useBackup属??true に設定しても?無関係に、上書きされます?
071     *
072     * 5.7.4.3 (2014/03/28) filename 属?のリクエスト変数対?
073     * filename 属?のみ、{@XXXX} のリクエスト変数が使えるようにします?
074     * 他?パラメータでは使えません?
075     * これは、multipart/form-data のリクエストでは、パート??処?しな?、リクエスト変数?
076     * 拾えな?、リクエスト変数は、この、upload タグ以降でのみ利用可能でした?
077     * zip対応と関連付けて、filename 属?のみ、利用できるように、MultipartRequest 側の処??込みます?
078     *
079     * 5.7.6.3 (2014/05/23) ア??ロードファイルのCSVセ?
080     * 個?に?したア??ロードファイル名?、XXX_NEW ?XXX_ORG で取得できますが?
081     * HTML5 の multiple 属?使用時や、ア??ロードされたファイルを??で処?たい場合に
082     * ファイル名を、CSV形式で取り出せるようにします?
083     * キーは、?通で、UPLOAD_FILES とします?
084     *
085     * @og.formSample
086     * ●形式?lt;og:upload fileURL="…" maxPostSize="…" />
087     * ●body?な?
088     *
089     * ●Tag定義??
090     *   <og:upload
091     *       fileURL            【TAG】ファイルをア??ロードするディレクトリを指定しま?(初期値:FILE_URL[=filetemp/])
092     *       filename           【TAG?通常使?せん)ファイルを作?するとき?ファイル名をセ?しま?
093     *       maxPostSize        【TAG】最大転送サイズ(Byte)を指定しま?初期値:10485760) 0,また?マイナスで無制限です?
094     *       scope              【TAG】キャ?ュする場合?スコープ[request/page/session/applicaton]を指定しま?初期値:session)
095     *       tableId            【TAG?通常使?せん)sessionから?す?DBTableModelオブジェクト? ID
096     *       columns            【TAG】DBTableModel作?時に、指定?カラ??"_01"??_99"の添え字をレコードとして作?します?
097     *       useBackup          【TAG】ファイルア??ロード時に、すでに同名のファイルが存在した場合に、バ?ア??処?renameTo)するかど?[true/false]を指定しま?初期値:false)
098     *       language           【TAG】タグ?で使用する?コード[ja/en/zh/…]を指定しま?
099     *       debug              【TAG】デバッグ??を?力するかど?[true/false]を指定しま?初期値:false)
100     *   />
101     *
102     * ●使用?:
103     * 【query.jsp?
104     *       <form method="POST" action="result.jsp" enctype="multipart/form-data" target="RESULT">
105     *       <table summary="layout" >
106     *       <tr><og:input type="text" name="submitter" value="{@USER.JNAME}" size="20" lbl="MSG0014" /></tr>
107     *       <tr>
108     *           <og:input type="file" name="file_01"      size="30" lbl="MSG0015" />
109     *           <og:input             name="file_01_NEW"  size="10" lbl="FILENAME" />
110     *       </tr><tr>
111     *           <og:input type="file" name="file_02"      size="30" lbl="MSG0015" />
112     *           <og:input             name="file_02_NEW"  size="10" lbl="FILENAME" />
113     *       </tr><tr>
114     *           <og:input type="file" name="file_03"      size="30" lbl="MSG0015" />
115     *           <og:input             name="file_03_NEW"  size="10" lbl="FILENAME" />
116     *       </tr><tr>
117     *           <og:column name="writable"     value="false"  />
118     *       </tr>
119     *       </table>
120     *
121     * 【result.jsp?
122     *       <og:upload
123     *           fileURL     = "{@USER.ID}"
124     *       />
125     *       <br />
126     *       <og:message lbl="MSG0003" comment="ファイルの登録が完?ました? />
127     *
128     *       <og:view
129     *           command      = "NEW"
130     *           viewFormType = "HTMLTable"
131     *           writable     = "{@writable}"
132     *       />
133     *
134     *       <table>
135     *       <tr><og:input name="submitter"   value="{@submitter}"   /></tr>
136     *       <tr><og:input name="writable"    value="{@writable}"    /></tr>
137     *       <tr><og:input name="directory"   value="{@directory}"   /></tr>
138     *       <tr><og:input name="file_01"     value="{@file_01}"     /></tr>
139     *       <tr><og:input name="file_01_NEW" value="{@file_01_NEW}" /></tr>
140     *       <tr><og:input name="file_01_ORG" value="{@file_01_ORG}" /></tr>
141     *       <tr><og:input name="file_02"     value="{@file_02}"     /></tr>
142     *       <tr><og:input name="file_02_NEW" value="{@file_02_NEW}" /></tr>
143     *       <tr><og:input name="file_02_ORG" value="{@file_02_ORG}" /></tr>
144     *       <tr><og:input name="file_03"     value="{@file_03}"     /></tr>
145     *       <tr><og:input name="file_03_NEW" value="{@file_03_NEW}" /></tr>
146     *       <tr><og:input name="file_03_ORG" value="{@file_03_ORG}" /></tr>
147     *       </table>
148     *
149     * 【result.jsp?
150     *       <og:upload
151     *           fileURL     = "{@USER.ID}"
152     *           columns     = "submitter,file"
153     *       />
154     *       <br />
155     *       <og:message lbl="MSG0003" comment="ファイルの登録が完?ました? />
156     *
157     *       <og:view
158     *           command      = "NEW"
159     *           viewFormType = "HTMLTable"
160     *           writable     = "{@writable}"
161     *       />
162     *
163     * @og.group ファイル入?
164     *
165     * @version  4.0
166     * @author       Kazuhiko Hasegawa
167     * @since    JDK5.0,
168     */
169    public class FileUploadTag extends CommonTagSupport {
170            //* こ?プログラ??VERSION??を設定します?       {@value} */
171            private static final String VERSION = "5.7.6.3 (2014/05/23)" ;
172    
173            private static final long serialVersionUID = 576320140523L ;
174    
175            /** 5.7.6.3 (2014/05/23) ア??ロードファイルのCSVセ?のキー */
176            public static final String UPLOAD_FILES = "UPLOAD_FILES" ;
177    
178            // 3.5.2.0 (2003/10/20) カラ?に、ISFILEを追??
179            private static final String[] names = new String[] { "KEY","VALUE","ISFILE" };
180            private static final String   ENCODE = "UTF-8";                 // 3.5.2.0 (2003/10/20) ?
181            private String  fileURL         = HybsSystem.sys( "FILE_URL" );
182            private String  filename    = null;                                             // 3.5.4.2 (2003/12/15)
183    
184            private int     maxPostSize = 10*1024*1024;                             // ?ファイル容? 10MB
185            private String  tableId         = HybsSystem.TBL_MDL_KEY ;
186    
187            // 5.6.5.2 (2013/06/21) DBTableModel作?時に、指定?カラ??"_01"??_99"の添え字をレコードとして作?します?
188            private String          columns         = null;
189            // 5.6.5.3 (2013/06/28) ファイルア??ロード時に、すでに同名のファイルが存在した場合に、バ?ア??処?renameTo)するかど?[true/false]を指定しま?初期値:false)
190            private boolean useBackup       = false;
191    
192            /**
193             * Taglibの終?グが見つかったときに処??doEndTag() ?オーバ?ライドします?
194             *
195             * @og.rev 2.2.0.0 (2002/12/17) 中国?国際化)対?エンコード?取得方法変更
196             * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応?release2() ?doEndTag()で呼ぶ?
197             * @og.rev 3.1.3.0 (2003/04/10) UTF-8 決め打ちのエンコード情報を取得する?
198             * @og.rev 3.5.2.0 (2003/10/20) scope 属?を追??
199             * @og.rev 3.5.4.2 (2003/12/15) ファイル名を?できるようにします?
200             * @og.rev 3.6.0.8 (2004/11/19) DBTableModel をセーブする時に、トランザクションチェ?を行います?
201             * @og.rev 3.7.1.1 (2005/05/23) フォル?な??合?、?階層??フォル?自動で作?します?
202             * @og.rev 3.8.1.3A (2006/01/30) 新ファイル名にオリジナルファイル名?拡張子をセ?しま?
203             * @og.rev 5.3.7.0 (2011/07/01) エラーメ?ージ?変更
204             * @og.rev 5.6.5.2 (2013/06/21) columns 属?の追?
205             * @og.rev 5.6.5.3 (2013/06/28) useBackup 属?の追?
206             * @og.rev 5.8.8.0 (2015/06/05) エラー??日本語化
207             *
208             * @return      後続????
209             */
210            @Override
211            public int doEndTag() {
212                    debugPrint();           // 4.0.0 (2005/02/28)
213                    startQueryTransaction( tableId );               // 3.6.0.8 (2004/11/19)
214                    HttpServletRequest request = (HttpServletRequest)getRequest();
215    
216                    try {
217                            String directory = HybsSystem.url2dir( fileURL );
218                            File dir = new File(directory);
219                            if( ! dir.exists() && ! dir.mkdirs() ) {
220    //                              String errMsg = "?レクトリの作?に失敗しました?" + directory + "]";
221                                    String errMsg = getResource().getLabel( "ERR0043" ) + "[" + directory + "]"; // 5.8.8.0 (2015/06/05)
222                                    throw new HybsSystemException( errMsg );
223                            }
224    
225                            // 3.8.1.3A (2006/01/30) 新ファイル名にオリジナルファイル名?拡張子をセ?しま?
226    //                      MultipartRequest multi = new MultipartRequest( request,directory,maxPostSize,ENCODE,filename );
227                            // 5.6.5.3 (2013/06/28) useBackup 属?の追?
228                            MultipartRequest multi = new MultipartRequest( request,directory,maxPostSize,ENCODE,filename,useBackup );
229                            // 5.6.5.2 (2013/06/21) columns 属?の追?
230    //                      DBTableModel table = makeDBTable( multi );
231                            DBTableModel table = null;
232                            if( columns == null ) {                                         // 5.6.5.2 (2013/06/21) columns 属?の追?
233                                    table = makeDBTable( multi );
234                            }
235                            else {
236                                    table = makeDBTableFromClms( multi );
237                            }
238    
239                            // 3.5.2.0 (2003/10/20) scope 属?を追??
240                            // 3.6.0.8 (2004/11/19) トランザクションチェ?を行います?
241                            if( ! commitTableObject( tableId, table ) ) {
242    //                              jspPrint( "FileUploadTag Query処?割り込まれました?BTableModel は登録しません? );
243                                    jspPrint( "FileUploadTag " + getResource().getLabel( "ERR0041" ) ); // 5.8.8.0 (2015/06/05)
244                                    return (SKIP_PAGE);
245                            }
246    
247                    } catch(IOException ex) {
248    //                      String errMsg = "ファイルの取り扱?にエラーが発生しました?
249    //                                      + toString() + HybsSystem.CR
250    //                                      + "FileURL=" + fileURL + HybsSystem.CR
251    //                                      + ex.getMessage();                              // 5.1.8.0 (2010/07/01) errMsg 修正
252                            
253    //                      String errMsg = "ファイル登録エラー??
254                            String errMsg = getResource().getLabel( "ERR0044" ) // 5.8.8.0 (2015/06/05)
255                                    + ex.getMessage() + HybsSystem.CR       // 5.3.7.0 (2011/07/01) errMsg 修正
256                                    + "(" + toString() + HybsSystem.CR
257                                    + "FileURL=" + fileURL + ")";
258                            throw new HybsSystemException( errMsg,ex );             // 3.5.5.4 (2004/04/15) 引数の並び?更
259                    }
260    
261                    return(EVAL_PAGE);
262            }
263    
264            /**
265             * タグリブオブジェクトをリリースします?
266             * キャ?ュされて再利用される?で、フィールド?初期設定を行います?
267             *
268             * @og.rev 2.0.0.4 (2002/09/27) カスタ?グの release() メソ?を?追?
269             * @og.rev 3.0.1.1 (2003/03/06) columns を?
270             * @og.rev 3.1.1.2 (2003/04/04) Tomcat4.1 対応?release2() ?doEndTag()で呼ぶ?
271             * @og.rev 3.5.4.2 (2003/12/15) ファイル名を?できるようにします?
272             * @og.rev 5.6.5.2 (2013/06/21) columns 属?の追?
273             * @og.rev 5.6.5.2 (2013/06/21) useBackup 属?の追?
274             *
275             */
276            @Override
277            protected void release2() {
278                    super.release2();
279                    fileURL                 = HybsSystem.sys( "FILE_URL" );
280                    maxPostSize             = 10*1024*1024;                         // ?ファイル容? 10MB
281                    tableId                 = HybsSystem.TBL_MDL_KEY ;
282                    filename                = null;                                         // 3.5.4.2 (2003/12/15)
283                    columns                 = null;                                         // 5.6.5.2 (2013/06/21)
284                    useBackup               = false;                                        // 5.6.5.3 (2013/06/28) 
285            }
286    
287            /**
288             * ファイルア??ロード?実行結果?DBTableModel に記述します?
289             *
290             * ここでは?KEY","VALUE","ISFILE" のカラ?対して、?を設定して?ます?
291             * 同時に、RequestAttribute 変数に、これらの値をセ?することで?
292             * {@XXXX} で値が取り?せる様にして?す?
293             *
294             * @og.rev 2.2.0.0 (2002/12/17) 中国?国際化)対?エンコード?取得方法変更
295             * @og.rev 3.0.1.1 (2003/03/06) request ??から{@XXXX} で値が取り?せる様に修正?
296             * @og.rev 3.5.2.0 (2003/10/20) カラ?(KEY,VALUE)に ISFILE を追?
297             * @og.rev 3.5.6.5 (2004/08/09) MultipartRequest 変更に伴な?正(Enum変更、?ファイル名取?
298             * @og.rev 3.5.6.6 (2004/08/23) 上記変更時?バグ修正?
299             * @og.rev 3.5.6.6 (2004/08/23) ?ァイルのキーを?XXXX_ORG にします?
300             * @og.rev 4.0.0.0 (2007/10/12) ??ブルモ?の登録方法を変更
301             * @og.rev 5.3.2.0 (2011/02/01) チェ?行?パラメーターはint配?側に変換して復?る?パラメーター名を保存する?
302             * @og.rev 5.4.4.2 (2012/02/03) CommonTagSupportと同様?チェ?ボックス判定を行う
303             * @og.rev 5.7.1.1 (2013/12/13) HTML5 ファイルア??ロード??選択?ultiple?対?
304             * @og.rev 5.7.1.2 (2013/12/20) 5.7.1.2 (2013/12/20) zip対応で、UploadedFile のメソ?変更
305             * @og.rev 5.7.3.0 (2014/02/07) zip対応?修正で、取得ファイル名が異なって??
306             * @og.rev 5.7.6.3 (2014/05/23) ア??ロードファイルのCSVセ?
307             *
308             * @param        multi     MultipartRequestオブジェク?
309             *
310             * @return       ??ブルモ?
311             */
312            private DBTableModel makeDBTable( final MultipartRequest multi ) {
313    
314                    DBTableModel table = DBTableModelUtil.newDBTable();
315    
316                    table.init( names.length );
317    
318                    for( int i=0; i<names.length; i++ ) {
319                            DBColumn dbColumn = getDBColumn( names[i] );
320                            table.setDBColumn( i,dbColumn );
321                    }
322    
323                    String[] values ;               // 4.0.0.0 (2007/10/12)
324                    List<String> prmNames = new ArrayList<String>();
325    
326                    // 5.7.6.3 (2014/05/23) ア??ロードファイルのCSVセ?
327                    StringBuilder buf = new StringBuilder();
328    
329                    // 5.7.1.1 (2013/12/13) HTML5 ファイルア??ロード??選択?ultiple?対?
330    //              String[] files = multi.getFilenames();          // 3.6.0.0 (2004/09/17)
331                    UploadedFile[] files = multi.getUploadedFile();
332                    for( int i=0; i<files.length; i++ ) {
333    //                      String name = files[i];
334    //                      File fin = multi.getFile(name);
335    //                      File fin = files[i].getFile();
336    //                      if( fin != null ) {
337    //                              String val = multi.getFilesystemName(name);
338                                    String name = files[i].getName();                               // multiple対応では、キーがかぶることがある?
339    //                              String val  = files[i].getFilesystemName();
340    //                              String val  = files[i].getUploadFile().getPath();       // 5.7.1.2 (2013/12/20) zip対応で、UploadedFile のメソ?変更
341                                    String val  = files[i].getUploadFile().getName();       // 5.7.3.0 (2014/02/07) 取得ファイル名が異なって??
342    
343                                    // 5.7.6.3 (2014/05/23) ア??ロードファイルのCSVセ?
344                                    if( i==0 ) { buf.append( val ); }
345                                    else { buf.append( "," ).append( val ); }                       // カンマ結合で、最初だけ結合しな??
346    
347                                    // "KEY","VALUE","ISFILE" の???タを作?します?
348                                    values = new String[] { name, val, "1" };
349                                    table.addColumnValues( values );
350                                    setRequestAttribute( name,val );
351                                    prmNames.add( name );                           // 5.7.1.1 (2013/12/13) List に設定する?
352    
353                                    String orgName = name + "_ORG" ;
354    //                              val  = multi.getOriginalFileName(name); // 注意:取得???信?
355                                    val  = files[i].getOriginalFileName();  // 注意:取得???信?
356    
357                                    // "KEY","VALUE","ISFILE" の???タを作?します?
358                                    values = new String[] { orgName, val, "2" };
359                                    table.addColumnValues( values );
360                                    setRequestAttribute( orgName,val );
361    //                      }
362                    }
363    
364                    // 5.7.6.3 (2014/05/23) ア??ロードファイルのCSVセ?
365                    setRequestAttribute( UPLOAD_FILES,buf.toString() );
366    
367                    // "KEY","VALUE","ISFILE" の???タを作?します?
368                    values = new String[] { "directory", fileURL, "0" };
369                    table.addColumnValues( values );
370                    setRequestAttribute( "directory",fileURL );
371    
372                    String[] params = multi.getParameterNames();
373                    for( int i=0; i<params.length; i++ ) {
374                            String name = params[i];
375                            // 5.3.2.0 (2011/02/01) チェ?行?パラメーターはint配?側に変換
376                            if ( HybsSystem.ROW_SEL_KEY.equals( name ) ) {
377                                    setRequestAttribute( name,multi.getIntParameters(name) );
378                            }
379                            else {
380                                    // 5.6.5.2 (2013/06/21) チェ?ボックス配?の値取得を??した、MultipartRequest のパラメータ値取?
381                                    String val = getParamVal( name,multi );
382    //                              String val = multi.getParameter(name);
383    //                              // "KEY","VALUE","ISFILE" の???タを作?します?
384    //                              if( "0".equals(val) ){ // 5.4.4.2 チェ?ボックス配?対応?
385    //                                      String[] vals = multi.getParameters(name);
386    //                                      if( vals != null && vals.length > 1 ) {
387    //                                              for( int j=0; j<vals.length; j++ ) {
388    //                                                      if( "1".equals( vals[j] ) ) {
389    //                                                              val = "1";
390    //                                                              break;
391    //                                                      }
392    //                                              }
393    //                                      }
394    //                              }
395    
396                                    values = new String[] { name, val, "0" };
397                                    table.addColumnValues( values );
398                                    setRequestAttribute( name,val );
399                                    prmNames.add( name );                           // 5.7.1.1 (2013/12/13) List に設定する?
400                            }
401                    }
402    
403                    // 5.3.2.0 (2011/02/01) パラメーター名を保存する?
404                    // 5.7.1.1 (2013/12/13) List に設定する?
405    //              String[] names = new String[ files.length + params.length ];
406    //          System.arraycopy( files, 0, names, 0, files.length );
407    //          System.arraycopy( params, 0, names, files.length, params.length );
408    //          setParameterNames( names );
409                setParameterNames( prmNames.toArray( new String[prmNames.size()] ) );
410    
411                    return table ;
412            }
413    
414            /**
415             * ファイルア??ロード?実行結果?横持? DBTableModel に記述します?
416             * 
417             * こ?処??、columns 属?を設定した?合?みとします?
418             * 
419             * DBTableModel作?時に、指定?カラ??"_01"??_99"の添え字をレコードとして作?します?
420             * 現状は?KEY","VALUE","ISFILE" のカラ?、データを縦持ちで作?して?す?
421             * これを?横持で作?しますが、カラ??末尾に?_01"??_99" までの添え字を
422             * 持つ場合?、これをレコードと認識させます?
423             * 添え字がな??合?、カラ?け作?されます?カラ?と同じリクエストがあれば?
424             * すべてのレコードに同じ値がセ?されます?
425             *
426             * @og.rev 5.6.5.2 (2013/06/21) 新規作?
427             * @og.rev 5.6.6.1 (2013/07/12) 添え字がな??合?処??見直?
428             * @og.rev 5.7.1.2 (2013/12/20) zip対応で、UploadedFile のメソ?変更
429             * @og.rev 5.7.3.0 (2014/02/07) zip対応?修正で、取得ファイル名が異なって??
430             * @og.rev 5.7.6.3 (2014/05/23) ア??ロードファイルのCSVセ?
431             *
432             * @param        multi     MultipartRequestオブジェク?
433             *
434             * @return       ??ブルモ?
435             */
436            private DBTableModel makeDBTableFromClms( final MultipartRequest multi ) {
437    
438                    DBTableModel table = DBTableModelUtil.newDBTable();
439    
440                    String[] clmNames = columns.split( "," );
441    
442                    table.init( clmNames.length );
443    
444                    // 値配??1行???
445                    String[] rowVal = new String[clmNames.length];
446    
447                    // 5.7.1.1 (2013/12/13) HTML5 ファイルア??ロード??選択?ultiple?対?
448                    UploadedFile[] files = multi.getUploadedFile();
449    
450                    List<String> prmNames = new ArrayList<String>();
451    
452                    for( int i=0; i<clmNames.length; i++ ) {
453                            String clm = clmNames[i] ;
454                            DBColumn dbColumn = getDBColumn( clm );
455                            table.setDBColumn( i,dbColumn );
456    
457                            // 先に、カラ?と??するパラメータを?期?としてセ?しておきます?
458                            String val = getParamVal( clm,multi );
459    
460                            // 5.6.6.1 (2013/07/12) ファイル名も同様に、あれ?初期値セ?しておきます?
461                            if( val == null ) {
462                                    // 5.7.1.1 (2013/12/13) HTML5 ファイルア??ロード??選択?ultiple?対?
463    //                              val = multi.getFilesystemName( clm );
464                                    for( int j=0; j<files.length; j++ ) {
465                                            String nm = files[j].getName();
466                                            if( clm.equalsIgnoreCase( nm ) ) {
467    //                                              val = files[j].getFilesystemName();
468    //                                              val = files[i].getUploadFile().getPath();       // 5.7.1.2 (2013/12/20) zip対応で、UploadedFile のメソ?変更
469                                                    val = files[i].getUploadFile().getName();       // 5.7.3.0 (2014/02/07) 取得ファイル名が異なって??
470                                                    break;                                                                          // 5.7.6.3 (2014/05/23) た?ん有ったほ?良??
471                                            }
472                                    }
473                            }
474                            // 5.7.1.1 (2013/12/13) getFilesystemName() の中に、newFile ?null の場合?、original を返す処?ある?
475    //                      if( val == null ) {
476    //                              // 5.7.1.1 (2013/12/13) HTML5 ファイルア??ロード??選択?ultiple?対?
477    ////                            val = multi.getOriginalFileName( clm ); // 注意:取得???信?
478    //                              for( int j=0; j<files.length; j++ ) {
479    //                                      String nm = files[j].getName();
480    //                                      if( clm.equalsIgnoreCase( nm ) ) {
481    //                                              val = files[j].getOriginalFileName();
482    //                                              break;
483    //                                      }
484    //                              }
485    //                      }
486                            rowVal[i] = ( val == null ) ? "" : val ;
487                    }
488    
489                    // 5.7.6.3 (2014/05/23) ア??ロードファイルのCSVセ?
490                    StringBuilder buf = new StringBuilder();
491    
492    //              String[] files = multi.getFilenames();          // 3.6.0.0 (2004/09/17)
493                    for( int i=0; i<files.length; i++ ) {
494    //                      String name = files[i];
495    //                      File fin = multi.getFile(name);
496                            String name = files[i].getName();
497    //                      File fin = files[i].getFile();
498    //                      if( fin != null ) {
499                                    // 5.6.6.1 (2013/07/12) 添え字がな??合?処??見直し?先にレコードを作?
500                                    String[] values = new String[clmNames.length];
501                                    System.arraycopy( rowVal,0,values,0,values.length );            // 行にセ?するに当たり?rowVal ?values にコピ?しておく?
502    
503                                    // ファイル名を Attribute で使えるようにセ?しておく?
504    //                              String fval = multi.getFilesystemName(name);
505    //                              String fval = files[i].getFilesystemName();
506    //                              String fval = files[i].getUploadFile().getPath();       // 5.7.1.2 (2013/12/20) zip対応で、UploadedFile のメソ?変更
507                                    String fval = files[i].getUploadFile().getName();       // 5.7.3.0 (2014/02/07) 取得ファイル名が異なって??
508                                    setRequestAttribute( name,fval );
509                                    prmNames.add( name );                           // 5.7.1.1 (2013/12/13) List に設定する?
510    
511                                    // 5.7.6.3 (2014/05/23) ア??ロードファイルのCSVセ?
512                                    if( i==0 ) { buf.append( fval ); }
513                                    else { buf.append( "," ).append( fval ); }                      // カンマ結合で、最初だけ結合しな??
514    
515                                    String orgName = name + "_ORG" ;
516    //                              String oval  = multi.getOriginalFileName(name); // 注意:取得???信?
517                                    String oval  = files[i].getOriginalFileName();  // 注意:取得???信?
518                                    setRequestAttribute( orgName,oval );
519    
520                                    // ファイルのキーを?に、添え字を検索します?
521                                    int adrs = name.lastIndexOf( '_' );             // 添え字??_' で区?れます?
522                                    // 5.6.6.1 (2013/07/12) 添え字がな??合?処??見直し?後続??行う?
523    //                              if( adrs < 0 ) { continue; }                 // 添え字がな?
524                                    if( adrs > 0 ) {
525                                            String fnm = name.substring( 0,adrs );  // ファイル???
526                                            String sub = name.substring( adrs );    // 添え?アン??バ?含?
527    
528    //                                      String[] values = new String[clmNames.length];
529    //                                      System.arraycopy( rowVal,0,values,0,values.length );            // 行にセ?するに当たり?rowVal ?values にコピ?しておく?
530    
531                                            // カラ?で検索しながら、レコード単位になるよ?セ?して?ます?
532                                            for( int j=0; j<clmNames.length; j++ ) {
533                                                    String clm = clmNames[j] ;
534                                                    String nm  = null;
535                                                    String val = null;
536    
537                                                    if( fnm.equalsIgnoreCase( clm ) ) {             // ファイル名カラ?_NEWファイル名も、この値にすでに変わって???
538    //                                                      nm  = name;
539    //                                                      val = multi.getFilesystemName( nm );
540                                                            val = fval;
541                                                    }
542                                                    else if( ( fnm + "_ORG" ).equalsIgnoreCase( clm ) ) {           // ?ァイル名カラ?
543    //                                                      nm   = name + "_ORG" ;
544    //                                                      val  = multi.getOriginalFileName( name );       // 注意:取得???信?
545                                                            val  = oval;
546                                                    }
547                                                    else if( ( fnm + "_NEW" ).equalsIgnoreCase( clm ) ) {           // 新ファイル名カラ?
548                                                            nm   = name + "_NEW" ;
549                                                            val  = multi.getParameter( nm );
550                                                    }
551                                                    else {
552                                                            nm  = clmNames[j] + sub;                                        // sub は、アン??バ?含?え?
553                                                            // 5.6.5.2 (2013/06/21) チェ?ボックス配?の値取得を??した、MultipartRequest のパラメータ値取?
554                                                            val = getParamVal( nm,multi );
555                                                    }
556                                                    if( val != null ) { values[j] = val ; }         // val ?null でな?き?みセ?します?
557    //                                              setRequestAttribute( nm,val );
558                                            }
559                                    }
560                                    table.addColumnValues( values );
561    //                      }
562                    }
563                    // 5.7.6.3 (2014/05/23) ア??ロードファイルのCSVセ?
564                    setRequestAttribute( UPLOAD_FILES,buf.toString() );
565    
566                    // Attribute で使えるようにセ?しておく?
567                    setRequestAttribute( "directory",fileURL );
568    
569                    // Attribute で使えるようにセ?しておく?
570                    String[] params = multi.getParameterNames();
571                    for( int i=0; i<params.length; i++ ) {
572                            String name = params[i];
573                            // 5.3.2.0 (2011/02/01) チェ?行?パラメーターはint配?側に変換
574                            if ( HybsSystem.ROW_SEL_KEY.equals( name ) ) {
575                                    setRequestAttribute( name,multi.getIntParameters(name) );
576                            }
577                            else {
578                                    // 5.6.5.2 (2013/06/21) チェ?ボックス配?の値取得を??した、MultipartRequest のパラメータ値取?
579                                    String val = getParamVal( name,multi );
580                                    setRequestAttribute( name,val );
581                                    prmNames.add( name );                           // 5.7.1.1 (2013/12/13) List に設定する?
582                            }
583                    }
584    
585                    // 5.3.2.0 (2011/02/01) パラメーター名を保存する?
586                    // 5.7.1.1 (2013/12/13) List に設定する?
587    //              String[] names = new String[ files.length + params.length ];
588    //              System.arraycopy( files, 0, names, 0, files.length );
589    //              System.arraycopy( params, 0, names, files.length, params.length );
590    //              setParameterNames( names );
591                setParameterNames( prmNames.toArray( new String[prmNames.size()] ) );
592    
593                    return table ;
594            }
595    
596            /**
597             * チェ?ボックス配?の値取得を??した、MultipartRequest のパラメータ値取?
598             * 
599             * ここでは、?MultipartRequest のパラメータ値を取得します?
600             * 値の取得で、チェ?ボックス配?の場合?、取得した?が?"0" の場合?み
601             * 配?でパラメータを取得し直し?"1" がな?ど?再度検索します?
602             * チェ?ボックスでは、チェ?時? "1" と、チェ?されなかった?合??
603             * hidden の "0" の両方の値が?列としてリクエストされるケースがある為です?
604             *
605             * @og.rev 5.6.5.2 (2013/06/21) 新規作?
606             *
607             * @param        key       MultipartRequest のパラメータ取得?ためのキー
608             * @param        multi     MultipartRequestオブジェク?
609             *
610             * @return       チェ?ボックス配?を?慮したパラメータ値
611             */
612            private String getParamVal( final String key , final MultipartRequest multi ) {
613                    String val = multi.getParameter( key );
614    
615                    if( "0".equals(val) ){ // 5.4.4.2 チェ?ボックス配?対応?
616                            String[] vals = multi.getParameters( key );
617                            if( vals != null && vals.length > 1 ) {
618                                    for( int j=0; j<vals.length; j++ ) {
619                                            if( "1".equals( vals[j] ) ) {
620                                                    val = "1";
621                                                    break;
622                                            }
623                                    }
624                            }
625                    }
626                    return val ;
627            }
628    
629            /**
630             * 【TAG】ファイルをア??ロードするディレクトリを指定しま?
631             *              (初期値:FILE_URL[={@og.value org.opengion.hayabusa.common.SystemData#FILE_URL}])?
632             *
633             * @og.tag
634             * こ?属?で?される?レクトリに、ア??ロードされたファイルをセーブします?
635             * ?方法???常の fileURL 属?と同様に、?頭が?'/' (UNIX) また??文字目が?
636             * ":" (Windows)の場合?、指定?URLそ?ままの?レクトリに、そ?な??合??
637             * fileURL = "{&#064;USER.ID}" と?すると、FILE_URL 属?で??フォル??下に?
638             * さらに、各個人ID別のフォル?作?して、そこにセーブします?
639             * (初期値:シス?定数のFILE_URL[={@og.value org.opengion.hayabusa.common.SystemData#FILE_URL}])?
640             *
641             * @og.rev 4.0.0.0 (2005/01/31) StringUtil.urlAppend メソ?の利用
642             * @og.rev 4.0.0.0 (2007/11/20) ?された?レクトリ名??が"\"or"/"で終わって???合に?/"を付加する?
643             * @og.rev 5.7.1.1 (2013/12/13) リクエスト変数が使えな?ラーを表示する?
644             * @og.rev 5.7.4.3 (2014/03/28) リクエスト変数が使えな??チェ?を行う?
645             *
646             * @param       url ファイルURL
647             * @see         org.opengion.hayabusa.common.SystemData#FILE_URL
648             */
649            public void setFileURL( final String url ) {
650                    String furl = nval( getRequestParameter( url ),null );
651                    if( furl != null ) {
652                            char ch = furl.charAt( furl.length()-1 );
653                            if( ch != '/' && ch != '\\' ) { furl = furl + "/"; }
654                            fileURL = StringUtil.urlAppend( fileURL,furl );
655                    }
656    //              else if( url != null && url.startsWith( "{@" ) ) {
657    //                      String errMsg = "upload では、enctype=\"multipart/form-data\" のため、{@XXXX}形式?パラメータが使えません?
658    //                                                              + " fileURL=[" + url + "]" ;
659    //                      throw new HybsSystemException( errMsg );                // 5.7.1.1 (2013/12/13) リクエスト変数が使えな?ラー
660    //              }
661                    else {
662                            chckReqParam( url,"fileURL" );          // 5.7.4.3 (2014/03/28) リクエスト変数が使えな??チェ?
663                    }
664            }
665    
666            /**
667             * 【TAG】最大転送サイズ(Byte)を指定しま?初期値:10485760)?
668             *
669             * @og.tag
670             * ?転送サイズを指定します?初期値は?0*1024*1024 = 10MB です?
671             * ??、Byte 単位で?します?
672             * 0,また?マイナスを指定することで、制限チェ?を外す?=無制限)事ができます?
673             *
674             * @og.rev 3.0.1.1 (2003/03/06) maxPostSize の設定バグ修正?
675             * @og.rev 5.6.5.3 (2013/06/28) コメント追??,また?マイナスで無制限?
676             * @og.rev 5.7.4.3 (2014/03/28) リクエスト変数が使えな??チェ?を行う?
677             *
678             * @param       maxPS ?転送サイズ
679             */
680            public void setMaxPostSize( final String maxPS ) {
681                    maxPostSize = nval( getRequestParameter( maxPS ),maxPostSize );
682    
683                    chckReqParam( maxPS,"maxPostSize" );            // 5.7.4.3 (2014/03/28) リクエスト変数が使えな??チェ?
684            }
685    
686            /**
687             * 【TAG?通常は使?せん)結果のDBTableModelを?sessionに登録するとき?キーを指定しま?
688             *              (初期値:HybsSystem#TBL_MDL_KEY[={@og.value org.opengion.hayabusa.common.HybsSystem#TBL_MDL_KEY}])?
689             *
690             * @og.tag
691             * 検索結果より、DBTableModelオブジェクトを作?します?これを?下流?viewタグ等に
692             * 渡す?合に??常は、session を利用します?そ?場合?登録キーです?
693             * query タグを同時に実行して、結果を求める?合?同?モリに配置される為?
694             * こ? tableId 属?を利用して、メモリ空間を?ます?
695             *              (初期値:HybsSystem#TBL_MDL_KEY[={@og.value org.opengion.hayabusa.common.HybsSystem#TBL_MDL_KEY}])?
696             *
697             * @og.rev 5.7.4.3 (2014/03/28) リクエスト変数が使えな??チェ?を行う?
698             *
699             * @param       id sessionに登録する時? ID
700             */
701            public void setTableId( final String id ) {
702                    tableId = nval( getRequestParameter( id ),tableId );
703    
704                    chckReqParam( id,"tableId" );           // 5.7.4.3 (2014/03/28) リクエスト変数が使えな??チェ?
705            }
706    
707            /**
708             * 【TAG?通常使?せん)ファイルを作?するとき?ファイル名をセ?します?
709             *
710             * @og.tag
711             * ファイルを作?するとき?ファイル名をセ?します?
712             * これは、?同時にア??ロードファイル名を変更する時に使用できません?
713             * 通常、ア??ロードされたファイル名を?する?合?ア??ロードするinput タグの
714             * name 属?に?する名称 ??"_NEW" と?リクエスト?を同時に送信すれば?
715             * ??関連付けて、ファイル名を更新します?
716             * そ?場合?クライアントより指定したファイル名?、name属???_ORG" と?
717             * リクエスト?として取得することが可能になります?
718             * name属? には、最終的に設定されたファイル名がセ?されて?す?
719             * ?れ?値も?{&#064;name属???_ORG"} ??{&#064;name属???_NEW"}として?
720             * ア??ロード?オリジナルと変更後?ファイル名を取得することが?来ます?
721             *
722             * 5.7.1.2 (2013/12/20) zip 対?
723             * filename 属?に?.zip" の拡張子?ファイル名を?した?合?、ア??ロードされた??のファイル?
724             * ZIP圧縮します?これは、ア??ロード後?処?なります?
725             * ZIP圧縮のオリジナルファイルは、そのまま残ります?
726             * なお?ZIPファイルは、useBackup属??true に設定しても?無関係に、上書きされます?
727             *
728             * 5.7.4.3 (2014/03/28) filename 属?のリクエスト変数対?
729             * filename 属?のみ、{&#064;XXXX} のリクエスト変数が使えるようにします?
730             * 他?パラメータでは使えません?
731             * これは、multipart/form-data のリクエストでは、パート??処?しな?、リクエスト変数?
732             * 拾えな?、リクエスト変数は、この、upload タグ以降でのみ利用可能でした?
733             * zip対応と関連付けて、filename 属?のみ、利用できるように、MultipartRequest 側の処??込みます?
734             *
735             * @og.rev 3.5.4.2 (2003/12/15) ファイル名を?できるようにします?
736             * @og.rev 5.7.1.1 (2013/12/13) リクエスト変数が使えな?ラーを表示する?
737             * @og.rev 5.7.4.3 (2014/03/28) リクエスト変数を使えるようにします?
738             *
739             * @param   fname ファイル?
740             */
741            public void setFilename( final String fname ) {
742                    filename = nval( getReservedParameter( fname ),null );          // 予??み処?します?
743    
744    //              filename = nval( getRequestParameter( fname ),null );
745    
746    //              if( filename == null && fname != null && fname.startsWith( "{@" ) ) {
747    //                      String errMsg = "upload では、enctype=\"multipart/form-data\" のため、{@XXXX}形式?パラメータが使えません? 
748    //                                                              + " filename=[" + fname + "]" ;
749    //                      throw new HybsSystemException( errMsg );                // 5.7.1.1 (2013/12/13) リクエスト変数が使えな?ラー
750    //              }
751            }
752    
753            /**
754             * 【TAG】DBTableModel作?時に、指定?カラ??"_01"??_99"の添え字をレコードとして作?します?
755             *
756             * @og.tag
757             * 現状は?KEY","VALUE","ISFILE" のカラ?、データを縦持ちで作?して?す?
758             * これを?横持で作?しますが、カラ??末尾に?_01"??_99" までの添え字を
759             * 持つ場合?、これをレコードと認識させます?
760             * アン??バ?がな??合?、カラ?け作?されます?カラ?と同じリクエストがあれば?
761             * すべてのレコードに同じ値がセ?されます?
762             * こ?処??、columns 属?を設定した?合?みとします?
763             *
764             * @og.rev 5.6.5.2 (2013/06/21) 新規作?
765             * @og.rev 5.7.4.3 (2014/03/28) リクエスト変数が使えな??チェ?を行う?
766             *
767             * @param   clms DBTableModel作?時?カラ??(カンマ区???
768             */
769            public void setColumns( final String clms ) {
770                    columns = nval( getRequestParameter( clms ),columns );
771    
772                    chckReqParam( clms,"columns" );         // 5.7.4.3 (2014/03/28) リクエスト変数が使えな??チェ?
773            }
774    
775            /**
776             * 【TAG】ファイルア??ロード時に、すでに同名のファイルが存在した場合に、バ?ア??処?renameTo)するかど?[true/false]を指定しま?初期値:false)?
777             *
778             * @og.tag
779             * ファイルア??ロード時に、ア??ロード?に、同名?ファイルが存在した場合?、既存機?は、そのまま
780             * 置き換えて?したが?簡易バージョンア??機?として、useBackup="true" を指定すると、既存?ファイル?
781             * リネ??て、バ?ア??ファイルを作?します?
782             * バックア??ファイルは、ア??ロードフォル?基準として、_backup/ファイル?拡張子_処?刻のlong値.拡張?になります?
783             * オリジナルのファイル名(拡張子付)を残したまま?_処?刻のlong値" を追?、さらに、オリジナルの拡張子を追?ます?
784             * バックア??ファイルの形式??できません?
785             * 
786             * 初期値は、互換性を持たせるため?false です?
787             *
788             * @og.rev 5.6.5.3 (2013/06/28) 新規作?
789             * @og.rev 5.7.4.3 (2014/03/28) リクエスト変数が使えな??チェ?を行う?
790             *
791             * @param   flag ファイルア??ロード時に、バ?ア??処?renameTo)するかど?[true/false]を指?
792             */
793            public void setUseBackup( final String flag ) {
794                    useBackup = nval( getRequestParameter( flag ),useBackup );
795    
796                    chckReqParam( flag,"useBackup" );               // 5.7.4.3 (2014/03/28) リクエスト変数が使えな??チェ?
797            }
798    
799            /**
800             * リクエスト変数が使えな??チェ?を行います?
801             *
802             * upload では、enctype="multipart/form-data" のため、{&#064;XXXX}形式?パラメータが使えません?
803             * 5.7.4.3 (2014/03/28) から、filename のみ利用可能としたことで、同様に利用できると
804             * 勘違?るケースに対応する為、すべてのパラメータにつ?チェ?を行います?
805             * ここでは、getRequestParameter( String ) の実行後?すぐに、isNull() 判定を行う事で?
806             * リクエスト変数の存在チェ?を行う事にして?す?
807             *
808             * @og.rev 5.7.4.3 (2014/03/28) リクエスト変数が使えな??チェ?を行う?
809             *
810             * @param   org 引数のオリジナル値
811             * @param   key エラーの発生した変数?
812             * @throws      HybsSystemException     パラメータが使用されて?場?
813             */
814            private void chckReqParam( final String org,final String key ) {
815                    if( isNull() && org != null && org.contains( "{@" ) ) {
816                            String errMsg = "upload では、enctype=\"multipart/form-data\" のため、{@XXXX}形式?パラメータが使えません?
817                                                                    + HybsSystem.CR
818                                                                    + "    " + key + "=[" + org + "]" ;
819                            throw new HybsSystemException( errMsg );                // リクエスト変数が使えな?ラー
820                    }
821            }
822    
823            /**
824             * タグの名称を?返します?
825             * 自??身のクラス名より?自動的に取り出せな?め?こ?メソ?をオーバ?ライドします?
826             *
827             * @og.rev 4.0.0.0 (2005/01/31) 新規追?
828             *
829             * @return  タグの名称
830             */
831            @Override
832            protected String getTagName() {
833                    return "upload" ;
834            }
835    
836            /**
837             * こ?オブジェクト???表現を返します?
838             * 基本???目?使用します?
839             *
840             * @return こ?クラスの??表現
841             */
842            @Override
843            public String toString() {
844                    return org.opengion.fukurou.util.ToString.title( this.getClass().getName() )
845                                    .println( "VERSION"             ,VERSION        )
846                                    .println( "names"               ,names          )
847                                    .println( "ENCODE"              ,ENCODE         )
848                                    .println( "fileURL"     ,fileURL        )
849                                    .println( "filename"    ,filename       )
850                                    .println( "maxPostSize" ,maxPostSize)
851                                    .println( "tableId"     ,tableId        )
852                                    .println( "columns"     ,columns        )                               // 5.6.5.2 (2013/06/21)
853                                    .println( "useBackup"   ,useBackup      )                               // 5.6.5.3 (2013/06/28)
854                                    .println( "Other..."    ,getAttributes().getAttribute() )
855                                    .fixForm().toString() ;
856            }
857    }