001/*
002 * Copyright (c) 2009 The openGion Project.
003 *
004 * Licensed under the Apache License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 *     http://www.apache.org/licenses/LICENSE-2.0
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
013 * either express or implied. See the License for the specific language
014 * governing permissions and limitations under the License.
015 */
016package org.opengion.hayabusa.taglib;
017
018import static org.opengion.fukurou.util.StringUtil.nval;
019
020import java.io.BufferedInputStream;
021import java.io.BufferedWriter;
022import java.io.ByteArrayInputStream;
023import java.io.ByteArrayOutputStream;
024import java.io.File;
025import java.io.IOException;
026import java.io.InputStream;
027import java.io.OutputStreamWriter;
028import java.io.UnsupportedEncodingException;
029import java.io.Writer;
030import java.util.Map;
031
032import org.opengion.fukurou.model.FileOperation;
033import org.opengion.fukurou.util.Closer;
034import org.opengion.fukurou.util.FileString;
035import org.opengion.fukurou.util.FileUtil;
036import org.opengion.fukurou.util.LogWriter;
037import org.opengion.fukurou.util.SOAPConnect;
038import org.opengion.fukurou.util.StringUtil;
039import org.opengion.fukurou.util.URLConnect;
040import org.opengion.fukurou.util.XHTMLTag;
041import org.opengion.fukurou.xml.XML2TableParser;
042import org.opengion.fukurou.xml.XSLT;
043import org.opengion.hayabusa.common.HybsSystem;
044import org.opengion.hayabusa.common.HybsSystemException;
045import org.opengion.hayabusa.db.DBTableModel;
046import org.opengion.hayabusa.db.DBTableModelUtil;
047import org.opengion.hayabusa.io.HybsFileOperationFactory;
048
049/**
050 * 指定のURLに接続します。
051 *
052 * エンジンでは、URL にアクセスすることで、デーモンを起動したり、
053 * コマンドを実行(adminメニュー)することが出来ます。
054 * もちろん、検索条件を指定して、結果を取得することも可能です。
055 * このタグでは、URLにアクセスして、コマンドを実行したり結果を取得できます。
056 * さらに、ファイルを POST で転送したり、処理結果を XSLT変換したり出来ます。
057 *
058 * @og.formSample
059 * ●形式:
060 *     <og:urlConnect
061 *         url           = "http://・・・ "    必須
062 *         proxyHost     = "proxy.opengion.org"
063 *         proxyPort     = "8080"
064 *         timeout       = "1"
065 *         keys          = "command,SYSTEM_ID"
066 *         vals          = "NEW,GE"
067 *         useSystemUser = "true/false"     初期値:true
068 *         authUserPass  = "admin:******"   初期値:admin:******
069 *         display       = "false/true"     初期値:false
070 *         xslFile       = "filter.xsl"
071 *         saveFile      = "outdata.xml"
072 *         soapNameSpace = "MyWebService"
073 *         soapMethodName= "test"
074 *         tableId       = "DEFAULT"
075 *         rowKey        = "item"
076 *         colKeys       = "person_id,person_name"
077 *         rtnKeys       = "version,summary"
078 *         encode        = "UTF-8"
079 *     />
080 *
081 * url           : 接続するURLを指定します。必須属性です。
082 * proxyHost     : proxy が存在する場合は、そのホスト名(例:proxy.opengion.org)
083 * proxyPort     : proxy が存在する場合は、そのポート番号(例:8080)
084 * timeout       : 通信リンクのオープン時に、指定された秒単位のタイム・アウト値を使用(例:10)
085 * keys,vals     : URLの指定時に、パラメータ(引数)を追加します。URLに含めても構いません。
086 *               : SOAPによる呼び出しの場合の詳細については、keysの属性定義を参照して下さい。
087 * postKey       : POST を使って、postFile属性のファイル内容を送信する時のキーです。
088 * postFile      : POST を使って、postFile属性のファイル内容を送信します。
089 *                 postFile を指定せず、postKey のみ指定して、BODY部に何か書き込めば、
090 *                 そのBODY部の文字列を POSTの内容として送信します。
091 * authUserPass  : Basic認証を使用する場合の接続ユーザー:パスワードを指定します。
092 *                 接続時のユーザーとパスワードを、USER:PASSWD 形式 で指定します。
093 *                 useSystemUser="false" で何も指定しない場合は、Basic認証を使用しません。
094 * useSystemUser : Basic認証の接続ユーザー:パスワードに、システムユーザーを使用
095 *                 するかどうかを指定します(初期値:true)。
096 *                 true の場合は、SYSTEM:***** を使用します。
097 * xslFile       : 接続先データを取得し、そのデータを XSLT変換する場合のXSLファイルを指定します。
098 * display       : 接続した結果のレスポンスを画面に表示するかどうかを指定します(初期値:false)。
099 *                 エンジンの場合、コマンドを投げるだけであれば、結果を取得する必要は
100 *                 ありません。イメージ的には、取得データが、このタグの位置に置き換わります。
101 *                 xslFile が指定されている場合、XSLT変換してセーブします。
102 * saveFile      : 接続先データを取得した結果を、ファイル出力します。
103 *                 display="true" と、saveFile を併用することはできません。
104 *                 xslFile が指定されている場合、XSLT変換してセーブします。
105 * soapNameSpace : SOAPによるWebサービスの呼び出しで、メソッド名及びパラメーターの名前空間を指定します。
106 *                 この名前空間は、通常WSDLファイルのdescriptionsタグのtargetNamespace属性の値により
107 *                 定義されます。
108 * soapMethodName: SOAPによるWebサービスの呼び出しで、メソッド名を指定します。
109 *                 WSDLファイルで定義されるoperationタグのname属性の値に相当します。
110 * tableId       : 結果のXMLファイルをDBTableModelに変換した際に、登録するTableIdを指定します。
111 * rowKey        : XMLをDBTableModelに変換する際の、行を表すタグキーを指定します。
112 * colKeys       : XMLをDBTableModelに変換する際の、項目を表すタグキーの一覧を指定します。
113 *                 キーにPARENT_TAG、PARENT_FULL_TAGを指定することで、rowKeyで指定されたタグの
114 *                 直近の親タグ、及びフルの親タグ名(親タグの階層を">[タグA]>[タグB]>[タグC]>"で表現)を
115 *                 取得することができます。
116 * rtnKeys       : XMLのタグキーを指定して値を取り出します。取り出した値は、{@XX}形式で処理することが可能です。
117 * encode        : データの入出力を行うエンコードを指定します。
118 *
119 * ●body:あり(EVAL_BODY_BUFFERED:BODYを評価し、{@XXXX} を解析します)
120 *         POSTデータを記述します。
121 *
122 * ●Tag定義:
123 *   <og:urlConnect
124 *       url              ○【TAG】アクセスする URL を指定します(必須)(必須)。
125 *       proxyHost          【TAG】プロキシ経由で接続する場合の、プロキシホスト名を指定します
126 *       proxyPort          【TAG】プロキシ経由で接続する場合の、プロキシポート番号を指定します
127 *       timeout            【TAG】通信リンクのオープン時に、指定された秒単位のタイム・アウト値を使用
128 *                                  (初期値:URL_CONNECT_TIMEOUT[={@og.value org.opengion.hayabusa.common.SystemData#URL_CONNECT_TIMEOUT}])。)
129 *       keys               【TAG】アクセスパラメータキーをCSV形式で複数指定します
130 *       vals               【TAG】keys属性に対応する値をCSV形式で複数指定します
131 *       useSystemUser      【TAG】Basic認証で接続するユーザーにSYSTEMユーザーを使用するかどうか[true/false]を指定します(初期値:true)
132 *       authUserPass       【TAG】Basic認証を使用して接続する場合のユーザー:パスワードを指定します(初期値:null)
133 *       display            【TAG】接続の結果を表示するかどうかを指定します(初期値:false)
134 *       xslFile            【TAG】接続の結果を表示する場合にXSLT変換する場合のファイルを指定します
135 *       saveFile           【TAG】接続の結果をファイルに保存します
136 *       postKey            【TAG】POST を使って、postFile属性のファイル内容を送信する時のキーを指定します
137 *       postFile           【TAG】POST を使って、postFile属性のファイル内容を送信します
138 *       method             【TAG】送信メソッドを指定します(GET/POST/PUT/DELETE/SOAP)
139 *       errNeglect         【TAG】(通常は使いません) 接続エラーを無視する場合にtrueとします(初期値false)
140 *       soapNameSpace      【TAG】SOAPによるWebサービスの呼び出しで、メソッド名及びパラメーターの名前空間を指定します
141 *       soapMethodName     【TAG】SOAPによるWebサービスの呼び出しで、メソッド名を指定します
142 *       tableId            【TAG】(通常は使いません)結果のDBTableModelを、sessionに登録するときのキーを指定します
143 *       scope              【TAG】キャッシュする場合のスコープ[request/page/session/applicaton]を指定します(初期値:session)
144 *       rowKey             【TAG】結果のXMLをDBTableModelに変換する際に、行のキーとなるタグ名を指定します
145 *       colKeys            【TAG】結果のXMLをDBTableModelに変換する際に、項目のキーとなるタグ名の一覧を指定します
146 *       rtnKeys            【TAG】結果のXMLを変換する際に、パラメータ(Attributes)として取り込むキーの一覧を指定します
147 *       encode             【TAG】データの入出力のエンコードを指定します
148 *       mainTrans          【TAG】(通常使いません)タグで処理される処理がメインとなるトランザクション処理かどうかを指定します(初期値:false)
149 *       caseKey            【TAG】このタグ自体を利用するかどうかの条件キーを指定します(初期値:null) 5.7.7.2 (2014/06/20)
150 *       caseVal            【TAG】このタグ自体を利用するかどうかの条件値を指定します(初期値:null) 5.7.7.2 (2014/06/20)
151 *       caseNN             【TAG】指定の値が、null/ゼロ文字列 でない場合(Not Null=NN)は、このタグは使用されます(初期値:true) 5.7.7.2 (2014/06/20)
152 *       caseNull           【TAG】指定の値が、null/ゼロ文字列 の場合は、このタグは使用されます(初期値:true) 5.7.7.2 (2014/06/20)
153 *       storageType            【TAG】保存先ストレージタイプを指定します
154 *       bucketName                     【TAG】保存先バケット名を指定します
155 *       debug              【TAG】デバッグ情報を出力するかどうか[true/false]を指定します(初期値:false)
156 *   >   ... Body ...
157 *   </og:urlConnect>
158 *
159 * ●例:
160 * アドミン関連
161 * http://localhost:8823/gf/jsp/admin?COMMAND=infomation     [状況表示]
162 * http://localhost:8823/gf/jsp/admin?COMMAND=close          [プール削除]
163 * http://localhost:8823/gf/jsp/admin?COMMAND=loginUser      [ログインユーザー]
164 * http://localhost:8823/gf/jsp/admin?COMMAND=システムパラメータ [システムパラメータ]
165 *
166 * 帳票デーモン
167 * http://localhost:8823/gf/jsp/REP08/result.jsp?cmd=SET&period=5000&command=NEW&timerTask=org.opengion.hayabusa.report.ReportDaemon&name=ReportDaemon  デーモン起動
168 * http://localhost:8823/gf/jsp/REP08/result.jsp?cmd=CANCEL&period=5000&command=NEW&timerTask=org.opengion.hayabusa.report.ReportDaemon&name=ReportDaemon  デーモン停止
169 *
170 *Tomcat Manager 画面
171 * http://localhost:8823/manager/reload?path=/ver4 アプリケーションを再ロード
172 *
173 * @og.rev 3.6.0.0 (2004/09/17) 新規作成
174 * @og.rev 4.1.0.0 (2007/12/22) POSTメソッドで複数キーを登録できるように属性追加
175 * @og.rev 5.1.5.0 (2010/04/01) SOAP対応
176 * @og.rev 5.10.9.0 (2019/03/01) oota クラウドストレージ対応を追加。(Fileクラスを拡張)
177 *  
178 * @og.group その他部品
179 *
180 * @version  4.0
181 * @author   Kazuhiko Hasegawa
182 * @since    JDK5.0,
183 */
184public class URLConnectTag extends CommonTagSupport {
185        //* このプログラムのVERSION文字列を設定します。   {@value} */
186        private static final String VERSION = "5.7.7.2 (2014/06/20)" ;
187
188        private static final long serialVersionUID = 577220140620L ;
189
190        private static final String DEFAULT_USER = "SYSTEM:MANAGER" ;
191        
192        private static final String[] POST_LIST = new String[] {
193                        "POST","PUT","DELETE" }; // 5.10.10.0 (2019/03/29)
194
195        private String          urlStr                  = null;
196        private String[]        keys                    = null;
197        private String[]        vals                    = null;
198        private String          xslFile                 = null;
199        private String          saveFile                = null;
200        private String          postKey                 = null;
201        private String          postData                = null;         // postFile ファイルか、BODY部
202        private int                     timeout                 = HybsSystem.sysInt( "URL_CONNECT_TIMEOUT" );   // 5.8.8.1 (2015/06/05) 新規追加
203        private boolean         useSystemUser   = true;
204        private String          authUserPass    = null;
205        private boolean         display                 = false;
206        private String          proxyHost               = null;         // 4.0.0 (2007/07/25)
207        private int             proxyPort               = -1;           // 4.0.0 (2007/07/25)
208        private String          method                  = "GET";        // 4.1.0.0 (2007/12/22) POSTorGETorSOAP
209        private boolean         errNglctFlag    = false;        // 4.1.1.0 (2008/01/22) エラー無視フラグ
210        private String          soapNameSpace   = null;         // 5.1.5.0 (2010/04/01) SOAP対応
211        private String          soapMethodName  = null;         // 5.1.5.0 (2010/04/01) SOAP対応
212        private transient DBTableModel table                    = null;         // 5.1.5.0 (2010/04/01) DBTableModel出力対応
213        private String          tableId                 = HybsSystem.TBL_MDL_KEY; // 5.1.5.0 (2010/04/01) DBTableModel出力対応
214        private String          rowKey                  = null;         // 5.1.5.0 (2010/04/01) DBTableModel出力対応
215        private String[]        colKeys                 = null;         // 5.1.5.0 (2010/04/01) DBTableModel出力対応
216        private String[]        rtnKeys                 = null;         // 5.1.5.0 (2010/04/01) DBTableModel出力対応
217        private String          encode                  = "UTF-8";      // 5.1.6.0 (2010/05/01) エンコード指定対応
218
219        private boolean         isTableOut              = false;        // 5.1.5.0 (2010/04/01) DBTableModel出力対応
220        private boolean         isOutParse              = false;        // 5.1.5.0 (2010/04/01) DBTableModel出力対応
221        private boolean         isMainTrans             = true;         // 5.1.6.0 (2010/05/01) DBLastSqlの処理の見直し
222        private String          storageType             = null;         // 5.10.9.0 (2019/03/01) ADD
223        private String          bucketName              = null;         // 5.10.9.0 (2019/03/01) ADD
224        private String          contentType             = null;         // 5.10.10.2 (2019/04/12)
225        
226        private String propKeys = null; // 5.10.16.0 (2019/10/04)
227        private String propVals = null; // 5.10.16.0 (2019/10/04)
228        
229        /**
230         * Taglibの開始タグが見つかったときに処理する doStartTag() を オーバーライドします。
231         *
232         * @og.rev 5.1.5.0 (2010/04/01) SOAP・DBTableModel出力対応
233         * @og.rev 5.1.6.0 (2010/05/01) DBLastSqlの処理は、DBTableModelが新規作成された処理でのみ行う。
234         * @og.rev 5.7.7.2 (2014/06/20) caseKey,caseVal,caseNN,caseNull 属性を追加
235         *
236         * @return      後続処理の指示
237         */
238        @Override
239        public int doStartTag() {
240                // 5.7.7.2 (2014/06/20) caseKey,caseVal,caseNN,caseNull 属性を追加
241                if( !useTag() ) { return SKIP_BODY ; }
242
243                // 5.1.5.0 (2010/04/01) DBTableModel出力対応
244                if( rowKey != null || colKeys != null || rtnKeys != null ) {
245                        isOutParse = true;
246                        if( rowKey != null || colKeys != null ) {
247                                isTableOut = true;
248                                useMainTrans( isMainTrans );                    // 5.1.6.0 (2010/05/01) DBLastSqlの処理の見直し
249                                startQueryTransaction( tableId );
250                        }
251                }
252
253                // 5.1.5.0 (2010/04/01) SOAPの場合は、postKeyが指定されない。
254                if( postData != null ) {
255                        return SKIP_BODY ;                      // Body を評価しない
256                }
257                else {
258                        return EVAL_BODY_BUFFERED ;     // Body を評価する。( extends BodyTagSupport 時)
259                }
260        }
261
262        /**
263         * Taglibのタグ本体を処理する doAfterBody() を オーバーライドします。
264         *
265         * @return      後続処理の指示(SKIP_BODY)
266         */
267        @Override
268        public int doAfterBody() {
269                postData = getBodyString();
270
271                return SKIP_BODY ;
272        }
273
274        /**
275         * Taglibの終了タグが見つかったときに処理する doEndTag() を オーバーライドします。
276         *
277         * @og.rev 4.0.1.0 (2007/12/12) PostKeys,PostVals処理を追加
278         * @og.rev 5.1.5.0 (2010/04/01) SOAP・DBTableModel出力対応
279         * @og.rev 5.2.0.0 (2010/09/01) エラー処理でNullPointerExceptionが発生するバグを修正
280         * @og.rev 5.7.7.2 (2014/06/20) caseKey,caseVal,caseNN,caseNull 属性を追加
281         * @og.rev 5.10.10.0 (2019/03/29) クラウド対応修正
282         *
283         * @return      後続処理の指示
284         */
285        @Override
286        public int doEndTag() {
287                debugPrint();           // 4.0.0 (2005/02/28)
288
289                // 5.7.7.2 (2014/06/20) caseKey,caseVal,caseNN,caseNull 属性を追加
290                if( !useTag() ) { return EVAL_PAGE ; }
291
292                URLConnect conn = null;
293                ByteArrayOutputStream pipeOut = null;
294                try {
295                        conn = connect();
296
297                        // 出力先が、画面かファイルかを判断します。
298                        Writer outWriter = null;
299                        // 5.1.5.0 (2010/04/01) DBTableModel出力対応
300                        if( isOutParse ) {
301                        pipeOut = new ByteArrayOutputStream();
302                                try {
303                                        outWriter = new BufferedWriter( new OutputStreamWriter( pipeOut, "UTF-8" ) );
304                                }
305                                catch( UnsupportedEncodingException ex ) {
306                                        throw new HybsSystemException( "不正なエンコードが指定されました。[UTF-8]",ex );
307                                }
308                        }
309                        else if( display ) {
310                                outWriter = FileUtil.getNonFlushPrintWriter( pageContext.getOut() ) ;           // JspWriter の取得
311
312                        }
313                        else if( saveFile != null ) {
314                                outWriter = FileUtil.getPrintWriter( new File( saveFile ),"UTF-8" );
315                        }
316
317                        // 出力先が存在する場合。
318                        if( outWriter != null ) {
319                                if( xslFile != null ) {
320                                        XSLT xslt = new XSLT();
321                                        xslt.setXslFile( xslFile );
322                                        xslt.setOutFile( outWriter );
323                                        xslt.transform( conn.getReader() );
324                                        xslt.close();
325                                }
326                                else {
327                                        outWriter.write( conn.readData() );
328                                }
329                                Closer.ioClose( outWriter );
330                                
331                                // 5.10.9.0 (2019/03/01) クラウドストレージ指定の場合は、アップロードする。
332                                if( saveFile != null) { // 5.10.10.0 (2019/03/29)
333                                        FileOperation cloudFile = HybsFileOperationFactory.create(storageType, bucketName, saveFile);
334                                        if(!cloudFile.isLocal()) {
335                                                File localFile = new File(saveFile);
336                                                FileUtil.copy(localFile, cloudFile);
337                                                localFile.delete();
338                                        }
339                                }
340                        }
341                }
342                catch( IOException ex ) {
343                        String errMsg = "データ取得中にエラーが発生しました。" + HybsSystem.CR
344                                                + " url=[" + urlStr + "]"
345                                                // 5.2.0.0 (2010/09/01) エラー処理でNullPointerExceptionが発生するバグを修正
346                                                + " message=[" + ( conn == null ? "NO_CONNECTION" : conn.getMessage() ) + "]";
347                        if( errNglctFlag ) { // 4.1.1.0 (2008/01/22) エラーを無視(標準エラー出力のみ)
348                                LogWriter.log( errMsg );
349                        }
350                        else { // 通常は無視しない
351                                throw new HybsSystemException( errMsg,ex );
352                        }
353                }
354                finally {
355                        if( conn != null ) { conn.disconnect(); }
356                }
357
358                // 5.1.5.0 (2010/04/01) DBTableModel出力対応
359                if( isOutParse ) {
360                        parse( new BufferedInputStream( new ByteArrayInputStream( pipeOut.toByteArray() ) ) );
361                        if( isTableOut && table != null && !commitTableObject( tableId, table ) ) {
362                                jspPrint( "URLConnectTag Query処理が割り込まれました。DBTableModel は登録しません。" );
363                                return SKIP_PAGE ;
364                        }
365                }
366
367                return EVAL_PAGE ;
368        }
369
370        /**
371         * URLに対して接続を行います。
372         *
373         * @og.rev 5.1.6.0 (2010/05/01) エンコード指定対応
374         * @og.rev 5.8.8.1 (2015/06/12) timeout追加
375         * @og.rev 5.10.10.0 (2019/03/19) PUT.DELETE対応
376         * @og.rev 5.10.10.2 (2019/04/12) contentType
377         * @og.rev 5.10.16.0 (2019/10/04) prop指定追加
378         *
379         * @return 接続オブジェクト
380         * @throws IOException 入出力エラーが発生したとき
381         */
382        private URLConnect connect() throws IOException {
383                if( useSystemUser ) { authUserPass = DEFAULT_USER; }
384
385                // 5.1.5.0 (2010/04/01) SOAP対応
386                // SOAPの場合、PostDataは、SOAPConnectタグの中で生成します。
387                URLConnect conn = null;
388                if( "SOAP".equalsIgnoreCase( method ) ) {
389                        if( soapNameSpace == null || soapNameSpace.length() == 0
390                                        || soapMethodName == null || soapMethodName.length() == 0 ) {
391                                String errMsg = "SOAP接続の場合、soapNameSpace及びsoapMethodNameは必ず指定して下さい。";
392                                throw new HybsSystemException( errMsg );
393                        }
394
395                        if( postData != null && postData.length() > 0 ) {
396                                conn = new SOAPConnect( urlStr,authUserPass, soapNameSpace, soapMethodName, postData );
397                        }
398                        else {
399                                conn = new SOAPConnect( urlStr,authUserPass, soapNameSpace, soapMethodName, keys, vals );
400                        }
401                }
402                else {
403                        String urlEnc = XHTMLTag.urlEncode( keys,vals );
404                        if( postKey != null ) { // 4.1.0.0 (2007/12/22)
405                                if( !check(method, POST_LIST) ) {
406                                        method = "POST";
407                                }
408                                String addEnc = postKey + "=" + postData;
409                                urlEnc = urlEnc + "&" + addEnc; // &連結
410                        }
411
412//                      if( ! "POST".equals( method ) ) { // 4.1.0.0 (2007/12/22)
413                        if( !check( method, POST_LIST) ) { // 5.10.10.0 (2019/03/29)
414                                // String urlEnc = XHTMLTag.urlEncode( keys,vals );
415                                urlStr = XHTMLTag.addUrlEncode( urlStr,urlEnc );
416                        }
417                        conn = new URLConnect( urlStr,authUserPass );
418
419                        // if( postKey != null ) {
420                        //      conn.setPostData( postKey,postData );
421                        // }
422//                      if( "POST".equals( method ) && keys != null && vals != null ) { // 4.1.0.0 (2007/12/22)
423                        if( check( method, POST_LIST ) && keys != null && vals != null ) { // 5.10.10.0 (2019/03/29)
424                                conn.setPostData( urlEnc );
425                                conn.setMethodOverride( method ); // 5.10.10.0 (2019/03/29)
426                        }
427                }
428
429                // 4.0.0 (2007/07/25) プロキシの設定追加
430                if( proxyHost != null ) {
431                        conn.setProxy( proxyHost,proxyPort );
432                }
433
434                // 5.1.6.0 (2010/05/01) エンコード指定対応
435                if( encode != null && encode.length() > 0 ) {
436                        conn.setCharset( encode );
437                }
438                
439                // 5.8.8.1 (2015/06/12) timeout属性追加
440                if( timeout >= 0 ) {
441                        conn.setTimeout( timeout );
442                }
443
444                // 5.10.10.2 (2019/04/12)
445                if( contentType != null && contentType.length() > 0 ){
446                        conn.setConentType( contentType );
447                }
448                
449                // 5.10.16.0 (2019/10/04)
450                if( propKeys != null && propVals != null ) {
451                        conn.setRequestProperty(propKeys,propVals);
452                }
453                
454                conn.connect();
455
456                return conn;
457        }
458
459        /**
460         * 出力データをパースし、DBTableModel及び属性パラメーターに分解します。
461         * 現時点では、XMLデータのみパースすることが可能です。
462         *
463         * @param input インプットストリーム
464         */
465        private void parse( final InputStream input ) {
466                XML2TableParser parser = new XML2TableParser( input );
467                parser.setTableCols( rowKey, colKeys );
468                parser.setReturnCols( rtnKeys );
469                parser.parse();
470
471                // DBTableModelを生成します。
472                if( isTableOut ) {
473                        table = DBTableModelUtil.makeDBTable( parser.getCols(), parser.getData(), getResource() );
474                }
475
476                // 戻り値を取得し、Attributeに登録します。
477                if( rtnKeys != null ) {
478                        Map<String,String> rtn = parser.getRtn();
479                        for( Map.Entry<String, String> entry : rtn.entrySet() ) {
480                                setRequestAttribute( entry.getKey(), entry.getValue() );
481                        }
482                }
483        }
484
485        /**
486         * タグリブオブジェクトをリリースします。
487         * キャッシュされて再利用されるので、フィールドの初期設定を行います。
488         *
489         * @og.rev 5.1.6.0 (2010/05/01) DBLastSqlの処理は、DBTableModelが新規作成された処理でのみ行う。
490         * @og.rev 5.8.1.1 (2015/06/12) timeout追加
491         * @og.rev 5.10.9.0 (2019/03/01) storageType,bucketNameの初期を追加
492         * @og.rev 5.10.16.0 (2019/10/04) prop追加
493         *
494         */
495        @Override
496        protected void release2() {
497                super.release2();
498                urlStr                  = null;
499                proxyHost               = null;         // 4.0.0 (2007/07/25)
500                proxyPort               = -1;           // 4.0.0 (2007/07/25)
501                keys                    = null;
502                vals                    = null;
503                xslFile                 = null;
504                saveFile                = null;
505                postKey                 = null;
506                postData                = null;
507                timeout                 = HybsSystem.sysInt( "URL_CONNECT_TIMEOUT" );   // 5.8.1.1 (2015/06/05) 新規追加
508                useSystemUser   = true;
509                authUserPass    = null;
510                display                 = false;
511                method                  = "GET";        // 4.1.0.0 (2007/12/22)
512                errNglctFlag    = false;        // 4.1.1.0 (2008/01/22)
513                soapNameSpace   = null;         // 5.1.5.0 (2010/04/01) SOAP対応
514                soapMethodName  = null;         // 5.1.5.0 (2010/04/01) SOAP対応
515                table                   = null;         // 5.1.5.0 (2010/04/01) DBTableModel出力対応
516                tableId                 = HybsSystem.TBL_MDL_KEY; // 5.1.5.0 (2010/04/01) DBTableModel出力対応
517                rowKey                  = null;         // 5.1.5.0 (2010/04/01) DBTableModel出力対応
518                colKeys                 = null;         // 5.1.5.0 (2010/04/01) DBTableModel出力対応
519                rtnKeys                 = null;         // 5.1.5.0 (2010/04/01) DBTableModel出力対応
520                isTableOut              = false;        // 5.1.5.0 (2010/04/01) DBTableModel出力対応
521                isOutParse              = false;        // 5.1.5.0 (2010/04/01) DBTableModel出力対応
522                encode                  = "UTF-8";      // 5.1.6.0 (2010/05/01) エンコード指定対応
523                isMainTrans             = true;         // 5.1.6.0 (2010/05/01) DBLastSqlの処理の見直し
524                storageType             = null;         // 5.10.9.0 (2019/03/01) ADD
525                bucketName              = null;         // 5.10.9.0 (2019/03/01) ADD
526                contentType             = null;         // 5.10.10.2 (2019/04/12)
527                propKeys                = null;         // 5.10.16.0 (2019/10/04)
528                propVals                = null;         // 5.10.16.0 (2019/10/04)
529        }
530
531        /**
532         * 【TAG】アクセスする URL を指定します(必須)。
533         *
534         * @og.tag
535         * 接続するURLを指定します。(例:http:// ・・・・・・)
536         * ?以降のパラメータが含まれていても構いません。
537         * このURL に、keys,vals で指定されたパラメータも追加されます。
538         *
539         * @param       url     アクセスする URL
540         */
541        public void setUrl( final String url ) {
542                urlStr = nval( getRequestParameter( url ),urlStr );
543        }
544
545        /**
546         * 【TAG】プロキシ経由で接続する場合の、プロキシホスト名を指定します。
547         *
548         * @og.tag
549         * 接続先が、プロキシ経由の場合、プロキシのホスト名を指定します。
550         * 例:proxy.opengion.org
551         *
552         * @param       host    プロキシホスト名
553         */
554        public void setProxyHost( final String host ) {
555                proxyHost = nval( getRequestParameter( host ),proxyHost );
556                useSystemUser = false;  // プロキシ接続時は、システムユーザーは使えません。
557        }
558
559        /**
560         * 【TAG】プロキシ経由で接続する場合の、プロキシポート番号を指定します。
561         *
562         * @og.tag
563         * 接続先が、プロキシ経由の場合、プロキシのポート番号を指定します。
564         * 例:8080
565         *
566         * @param       port    プロキシポート番号
567         */
568        public void setProxyPort( final String port ) {
569                proxyPort = nval( getRequestParameter( port ),proxyPort );
570        }
571
572        /**
573         * 【TAG】アクセスパラメータキーをCSV形式で複数指定します。
574         *
575         * @og.tag
576         * アクセスする URLに追加するパラメータのキーを指定します。
577         * カンマ区切りで複数指定できます。
578         * vals 属性には、キーに対応する値を、設定してください。
579         * 例:<b>keys="command,SYSTEM_ID"</b> vals="NEW,GE"
580         * 分解方法は、CSV変数を先に分解してから、getRequestParameter で値を取得します。
581         * こうしないとデータ自身にカンマを持っている場合に分解をミスる為です。
582         *
583         * [SOAP対応]
584         * SOAPによるWebサービスの呼び出しの場合、keys,valsに指定された値より、env:Envelopタグを
585         * rootタグとするXMLデータを生成します。
586         * (BODY部分に直接XMLデータを出力することも可能です。)
587         * この際、項目名に'&gt;'を含めることで、階層的なXMLデータを表現することができます。
588         * 例)
589         *   [属性定義]
590         *   keys="param0&gt;AAA,param0&gt;BBB,param1&gt;CCC,DDD"
591         *   vals="v1,v2,v3,v4"
592         *   [XMLデータ(※データ部のみ)]
593         *   &lt;param0&gt;
594         *     &lt;AAA&gt;v1&lt;/AAA&gt;
595         *     &lt;BBB&gt;v2&lt;/BBB&gt;
596         *   &lt;/param0&gt;
597         *   &lt;param1&gt;
598         *     &lt;CCC&gt;v3&lt;/CCC&gt;
599         *   &lt;/param1&gt;
600         *   &lt;DDD&gt;v4&lt;/DDD&gt;
601         * 項目の値を"null"とすることで、XMLで言うところの「xsi:nil=\"true\"」のデータを表現すること
602         * もできます。
603         * また、キー名の先頭を'&#064;'にすることで、項目名に名前空間のPREFIXを付加することができます。
604         * 一般的には、JavaやRubyで実装されたWebサービスを呼び出しする場合は、必要ありませんが、
605         * .NETで実装されたWebサービスを呼び出しする場合は、各項目にPREFIXを付与しないと、正しく
606         * パラメーターを渡すことができません。
607         * ※現時点では、keysの階層定義は、2階層まで対応しています。
608         *   3階層以上のXML構造を定義する場合は、postFile属性によるファイル指定又は、Body部分で直接
609         *   XMLデータを記述して下さい。
610         *
611         * @param       key リンク先に渡すキー
612         * @see         #setVals( String )
613         */
614        public void setKeys( final String key ) {
615                keys = getCSVParameter( key );
616        }
617
618        /**
619         * 【TAG】keys属性に対応する値をCSV形式で複数指定します。
620         *
621         * @og.tag
622         * キーに設定した値を、カンマ区切り文字で複数して出来ます。
623         * 指定順序は、キーと同じにしておいて下さい。
624         * 例:<b>keys="command,SYSTEM_ID"</b> vals="NEW,GE"
625         * 分解方法は、CSV変数を先に分解してから、getRequestParameter で値を取得します。
626         * こうしないとデータ自身にカンマを持っている場合に分解をミスる為です。
627         *
628         * @param       val names属性に対応する値
629         * @see         #setKeys( String )
630         */
631        public void setVals( final String val ) {
632                vals = getCSVParameter( val );
633        }
634
635        /**
636         * 【TAG】送信メソッドを指定します(GET/POST/SOAP)。
637         *
638         * @og.tag
639         * URLConnectTagのメソッドの初期設定はGETです。
640         * ここで"POST"(大文字)を指定するとkyes,valsの値セットをPOSTで送信します。
641         * postKeyが設定されている場合はこの値に関係なくPOSTです。
642         * (PUT,DELETEの場合もPOST同様の動作をしますがX-HTTP-Method-Overrideを付加します)
643         * 
644         *
645         * @og.rev 4.1.0.0 (2007/12/22) 新規作成
646         *
647         * @param       post_get        送信メソッド(GET/POST/SOAP)
648         */
649        public void setMethod ( final String post_get ) {
650                method = nval( getRequestParameter( post_get ), method );
651        }
652
653        /**
654         * 【TAG】Basic認証で接続するユーザーにSYSTEMユーザーを使用するかどうか[true/false]を指定します(初期値:true)。
655         *
656         * @og.tag
657         * useSystemUser="true"(初期値) の場合、URL接続時のコネクションに、Basic認証を
658         * 使用しますが、その時のユーザーにシステムユーザー(SYSTEM)を使用します。
659         * useSystemUser="false"の場合は、authUserPass で指定したユーザー:パスワードを
660         * 使用します。authUserPass で、何も指定されなかった場合は、Basic認証を使用しません。
661         * 初期値は、true(SYSTEMユーザー認証する) です。
662         *
663         * @param   flag [true:SYSTEMユーザー認証する/false:この接続のユーザーで認証する]
664         * @see #setAuthUserPass( String )
665         */
666        public void setUseSystemUser( final String flag ) {
667                useSystemUser = nval( getRequestParameter( flag ),useSystemUser );
668        }
669
670        /**
671         * 【TAG】Basic認証を使用して接続する場合のユーザー:パスワードを指定します(初期値:null)。
672         *
673         * @og.tag
674         * 接続時のユーザーとパスワードを、USER:PASSWD 形式で指定します。
675         * useSystemUser="false"の場合は、ここで指定したユーザーとパスワードを使用します。
676         * その場合に、何も指定しない場合は、Basic認証を使用しません。
677         *
678         * @param       userPass        接続のユーザーとパスワード(USER:PASSWD 形式)
679         * @see #setUseSystemUser( String )
680         */
681        public void setAuthUserPass( final String userPass ) {
682                authUserPass = nval( getRequestParameter( userPass ),authUserPass );
683        }
684
685        /**
686         * 【TAG】接続の結果を表示する場合にXSLT変換する場合のファイルを指定します。
687         *
688         * @og.tag
689         *
690         * 接続先のデータが、XML形式の場合、そのままでは、画面出力できない場合が
691         * あります。通常は、HTML形式に変換しますが、その変換に、 XSL ファイルを
692         * 指定することが可能です。
693         * display="true" の場合や、saveFile を指定した場合に、適用されます。
694         *
695         * @param       file    接続の結果を表示する場合にXSLT変換する場合のファイル
696         * @see #setSaveFile( String )
697         * @see #setDisplay( String )
698         */
699        public void setXslFile( final String file ) {
700                xslFile = HybsSystem.url2dir( nval( getRequestParameter( file ),xslFile ) );
701        }
702
703        /**
704         * 【TAG】接続の結果を表示するかどうかを指定します(初期値:false)。
705         *
706         * @og.tag
707         * true で、接続結果を表示します。 false では、何も表示しません(初期値:false)
708         * 接続結果を表示する使い方より、admin 画面に接続して、キャッシュクリアするような
709         * 使い方が多いと考え、初期値は、false になっています。
710         * xslFile が指定されている場合、XSLT変換して画面表示します。
711         * display="true" と、saveFile を併用することはできません。
712         *
713         * @param       flag    接続の結果を表示するかどうか(初期値:false)
714         * @see #setSaveFile( String )
715         * @see #setXslFile( String )
716         */
717        public void setDisplay( final String flag ) {
718                display = nval( getRequestParameter( flag ),display );
719
720                if( display && saveFile != null ) {
721                        String errMsg = "display=\"true\" と、saveFile を併用することはできません。";
722                        throw new HybsSystemException( errMsg );
723                }
724        }
725
726        /**
727         * 【TAG】接続の結果をファイルに保存します。
728         *
729         * @og.tag
730         * 接続先のデータを受け取って、ファイルに保存します。その場合、
731         * xslFile が指定されている場合、XSLT変換してセーブします。
732         * display="true" と、saveFile を併用することはできません。
733         *
734         * @param       file    接続の結果を表示する場合にXSLT変換する場合のファイル
735         * @see #setXslFile( String )
736         * @see #setDisplay( String )
737         */
738        public void setSaveFile( final String file ) {
739                saveFile = HybsSystem.url2dir( nval( getRequestParameter( file ),saveFile ) );
740
741                if( display ) {
742                        String errMsg = "display=\"true\" と、saveFile を併用することはできません。";
743                        throw new HybsSystemException( errMsg );
744                }
745        }
746
747        /**
748         * 【TAG】POST を使って、postFile属性のファイル内容を送信する時のキーを指定します。
749         *
750         * @og.tag
751         * 接続先にパラメータ(引数)を投げる場合に、POST を使用できます。
752         * そのときの キーをここで指定します。
753         * POSTするデータは、postFileで指定されたファイルか、BODY部に記述された文字列です。
754         *
755         * @param       key     POST を使って、postFile属性のファイル内容を送信する時のキー
756         * @see  #setPostFile( String )
757         */
758        public void setPostKey( final String key ) {
759                postKey = nval( getRequestParameter( key ),postKey );
760        }
761
762        /**
763         * 【TAG】POST を使って、postFile属性のファイル内容を送信します。
764         *
765         * @og.tag
766         * 接続先にパラメータ(引数)を投げる場合に、POST を使用できます。
767         * そのときの 送信データのファイルをここで指定します。
768         * postKey のみ指定されて、postFile が指定されない場合は、BODY部を送信します。
769         * SOAPによる呼び出しの場合は、ここ(BODY部での定義を含む)で、送信するXMLデータを
770         * 定義することができます。
771         *
772         * @param       file    接続の結果を表示する場合にXSLT変換する場合のファイル
773         * @see  #setPostKey( String )
774         */
775        public void setPostFile( final String file ) {
776                String postFile = nval( getRequestParameter( file ),null );
777
778                if( postFile != null ) {
779                        FileString fileStr = new FileString();
780                        fileStr.setFilename( HybsSystem.url2dir( postFile ) );
781                        postData = fileStr.getValue();
782                }
783        }
784        
785        /**
786         * 【TAG】接続タイムアウト時間を(秒)で指定します
787         *              (初期値:URL_CONNECT_TIMEOUT[={@og.value org.opengion.hayabusa.common.SystemData#URL_CONNECT_TIMEOUT}])。
788         *
789         * @og.tag
790         * 実際には、java.net.URLConnection#setConnectTimeout(int) に 1000倍して設定されます。
791         * 0 は、無限のタイムアウト、マイナスは、設定しません。(つまりJavaの初期値のまま)
792         * (初期値:システム定数のURL_CONNECT_TIMEOUT[={@og.value org.opengion.hayabusa.common.SystemData#URL_CONNECT_TIMEOUT}])。
793         *
794         * @og.rev 5.8.1.1 (2015/06/12) timeout属性追加
795         *
796         * @param       tout    タイムアウト時間(秒) (ゼロは、無制限)
797         * @see         org.opengion.fukurou.util.URLConnect#setTimeout(int)
798         * @see         java.net.URLConnection#setConnectTimeout(int)
799         */
800        public void setTimeout( final String tout ) {
801                timeout = nval( getRequestParameter( tout ),timeout );
802        }
803
804        /**
805         * 【TAG】(通常は使いません) 接続エラーを無視する場合にtrueとします(初期値false)。
806         *
807         * @og.tag
808         * trueにするとConnectで発生したエラーを投げずに処理を続行します。
809         * (標準エラー出力にエラー内容は出力されます)
810         * 接続エラーが発生しても処理を中断したくない場合に設定します。
811         *
812         * @og.rev 4.1.1.0 (2008/01/22) 新規追加
813         *
814         * @param       flag    エラーを無視する場合にtrue
815         */
816        public void setErrNeglect( final String flag ) {
817                errNglctFlag = nval( getRequestParameter( flag ), errNglctFlag );
818        }
819
820        /**
821         * 【TAG】SOAPによるWebサービスの呼び出しで、メソッド名及びパラメーターの名前空間を指定します。
822         *
823         * @og.tag
824         * SOAPによるWebサービスの呼び出しで、メソッド名及びパラメーターの名前空間を指定します。
825         * この名前空間は、通常WSDLファイルのdescriptionsタグのtargetNamespace属性の値により
826         * 定義されます。
827         *
828         * @og.rev 5.1.5.0 (2010/04/01) 新規追加
829         *
830         * @param       ns      名前空間
831         */
832        public void setSoapNameSpace( final String ns ) {
833                soapNameSpace = nval( getRequestParameter( ns ), soapNameSpace );
834        }
835
836        /**
837         * 【TAG】SOAPによるWebサービスの呼び出しで、メソッド名を指定します。
838         *
839         * @og.tag
840         * SOAPによるWebサービスの呼び出しで、メソッド名を指定します。
841         * WSDLファイルで定義されるoperationタグのname属性の値に相当します。
842         *
843         * @og.rev 5.1.5.0 (2010/04/01) 新規追加
844         *
845         * @param       method  メソッド名
846         */
847        public void setSoapMethodName( final String method ) {
848                soapMethodName = nval( getRequestParameter( method ), soapMethodName );
849        }
850
851        /**
852         * 【TAG】(通常は使いません)結果のDBTableModelを、sessionに登録するときのキーを指定します
853         *              (初期値:HybsSystem#TBL_MDL_KEY[={@og.value org.opengion.hayabusa.common.HybsSystem#TBL_MDL_KEY}])。
854         *
855         * @og.tag
856         * 検索結果より、DBTableModelオブジェクトを作成します。これを、下流のviewタグ等に
857         * 渡す場合に、通常は、session を利用します。その場合の登録キーです。
858         * query タグを同時に実行して、結果を求める場合、同一メモリに配置される為、
859         * この tableId 属性を利用して、メモリ空間を分けます。
860         *              (初期値:HybsSystem#TBL_MDL_KEY[={@og.value org.opengion.hayabusa.common.HybsSystem#TBL_MDL_KEY}])。
861         *
862         * @param       id sessionに登録する時の ID
863         */
864        public void setTableId( final String id ) {
865                tableId   = nval( getRequestParameter( id ),tableId );
866        }
867
868        /**
869         * 【TAG】結果のXMLをDBTableModelに変換する際に、行のキーとなるタグ名を指定します。
870         *
871         * @og.tag
872         * 結果のXMLを表形式に変換する際に、行のキーとなるタグ名を指定します。
873         * このキーのタグを基点として、colKeysで指定されたタグの値を各項目の値として取り込みます。
874         * (詳細は、colKeysのタグリブ属性マニュアルを参照して下さい。)
875         *
876         * @param       key 行のキーとなるタグ名
877         * @see #setColKeys( String )
878         */
879        public void setRowKey( final String key ) {
880                rowKey = nval( getRequestParameter( key ),rowKey );
881        }
882
883        /**
884         * 【TAG】結果のXMLをDBTableModelに変換する際に、項目のキーとなるタグ名の一覧を指定します。
885         *
886         * @og.tag
887         * 結果のXMLをDBTableModelに変換する際に、項目のキーとなるタグ名の一覧を指定します。
888         * rowKeyで行を、colKeysで項目を表現し、rowKeyのタグで囲われた固まりを1つの行とみなします。
889         * このため、colKeysに指定されたキーのタグでも、rowKeyの外にある場合は、取り込み対象となりません。
890         *
891         * また、キーにPARENT_TAG、PARENT_FULL_TAGを指定することで、rowKeyで指定されたタグの
892         * 直近の親タグ、及びフルの親タグ名(親タグの階層を"&gt;[タグA]&gt;[タグB]&gt;[タグC]&gt;"で表現)を
893         * 取得することができます。
894         *
895         * @param       keys 項目のキーとなるタグ名の一覧
896         */
897        public void setColKeys( final String keys ) {
898                colKeys = StringUtil.csv2Array( getRequestParameter( keys ) );
899        }
900
901        /**
902         * 【TAG】結果のXMLを変換する際に、パラメータ(Attributes)として取り込むキーの一覧を指定します。
903         *
904         * @og.tag
905         * 結果のXMLを変換する際に、パラメータ(Attributes)として取り込むキーの一覧を指定します。
906         * ここで指定されたキーのタグの値を取り出し、{&#064;XX}形式(Attributes)として処理できるようにします。
907         *
908         * @param       keys パラメーター(Attributes)のキーとなるタグ名の一覧
909         */
910        public void setRtnKeys( final String keys ) {
911                rtnKeys = StringUtil.csv2Array( getRequestParameter( keys ) );
912        }
913
914        /**
915         * 【TAG】データの入出力のエンコードを指定します。
916         *
917         * @og.tag
918         * データの入出力のエンコードを指定します。
919         * 初期値は、"UTF-8"です。
920         *
921         * @og.rev 5.1.6.0 (2010/05/01) 新規作成
922         * @param       enc     エンコード
923         */
924        public void setEncode( final String enc ) {
925                encode = nval( getRequestParameter( enc ), encode );
926        }
927
928        /**
929         * タグの名称を、返します。
930         * 自分自身のクラス名より、自動的に取り出せないため、このメソッドをオーバーライドします。
931         *
932         * @og.rev 4.0.0.0 (2005/01/31) 新規追加
933         *
934         * @return  タグの名称
935         */
936        @Override
937        protected String getTagName() {
938                return "urlConnect" ;
939        }
940
941        /**
942         * 【TAG】(通常使いません)タグで処理される処理がメインとなるトランザクション処理かどうかを指定します(初期値:false)。
943         *
944         * @og.tag
945         * (通常使いません)タグで処理される処理が、メインとなるトランザクション処理かどうかを指定します。(初期値:false)
946         * この値は、ファイルダウンロード処理に影響します。この値がtrueに指定された時にcommitされたDBTableModelが
947         * ファイルダウンロードの対象の表になります。
948         *
949         * このパラメーターは、通常、各タグにより実装され、ユーザーが指定する必要はありません。
950         * 但し、1つのJSP内でDBTableModelが複数生成される場合に、前に処理したDBTableModelについてファイルダウンロードをさせたい
951         * 場合は、後ろでDBTableModelを生成するタグで、明示的にこの値をfalseに指定することで、ファイルダウンロード処理の対象から
952         * 除外することができます。
953         *
954         * @og.rev 5.1.6.0 (2010/05/01) 新規作成
955         *
956         * @param  flag メイントランザクションかどうか
957         */
958        public void setMainTrans( final String flag ) {
959                isMainTrans = nval( getRequestParameter( flag ),isMainTrans );
960        }
961
962        /**
963         * 【TAG】保存先ストレージタイプを設定します。
964         *  
965         * @og.tag
966         * ファイルを読み取り元の、ストレージタイプを設定します。
967         * 未設定の場合は、システムリソースの「CLOUD_TARGET」が参照されます。
968         * 自身のサーバを指定する場合は、「default」を設定してください。
969         * 
970         * @og.rev 5.10.9.0 (2019/03/01) 新規追加
971         * 
972         * @param storage 保存先ストレージタイプ
973         */
974        public void setStorageType( final String storage ) {
975                storageType = nval( getRequestParameter( storage ), storageType );
976        }
977        
978        /**
979         * 【TAG】保存先バケット名を設定します。
980         * 
981         * @og.tag
982         * ファイルを読み取り元の、バケット名を指定します。
983         * クラウドストレージ利用時のみ有効です。
984         * 未設定の場合は、システムリソースの「CLOUD_BUKET」が参照されます。
985         * 
986         * @og.rev 5.10.9.0 (2019/03/01) 新規追加
987         * 
988         * @param bucket 保存先バケット名
989         */
990        public void setBucketName( final String bucket ) {
991                bucketName = nval( getRequestParameter( bucket ), bucketName );
992        }
993        
994        /**
995         * 【TAG】送信ヘッダのコンテントタイプを指定します。
996         * 
997         * 通常は指定不要です。
998         * API等でapplication/json等を指定された場合に設定してください。
999         * 
1000         * @og.rev 5.10.10.2 (2019/04/12) 追加
1001         * 
1002         * @param ctype コンテントタイプ
1003         */
1004        public void setContentType( final String ctype ) {
1005                contentType = nval( getRequestParameter( ctype ), contentType );
1006        }
1007        
1008        /**
1009         * 【TAG】コネクションのrequestParameterに渡すキーをCSV形式で複数指定します。
1010         *
1011         * @og.tag 
1012         * 分解方法は、CSV変数を先に分解してから、getRequestParameter で値を取得します。
1013         *
1014         * @og.rev 5.10.16.0 (2019/10/4) 新規追加
1015         *
1016         * @param       key キー(CSV形式)
1017         */
1018        public void setPropKeys( final String key ) {
1019                propKeys = nval( getRequestParameter( key ), propKeys );
1020        }
1021        
1022        /**
1023         * 【TAG】コネクションのrequestParameterに渡す値をCSV形式で複数指定します。
1024         *
1025         * @og.tag 
1026         * 分解方法は、CSV変数を先に分解してから、getRequestParameter で値を取得します。
1027         *
1028         * @og.rev @og.rev 5.10.16.0 (2019/10/4)
1029         *
1030         * @param       val 値(CSV形式) 新規追加
1031         */
1032        public void setPropVals( final String val ) {
1033                propVals = nval( getRequestParameter( val ), propVals );
1034        }
1035        
1036        /**
1037         * このオブジェクトの文字列表現を返します。
1038         * 基本的にデバッグ目的に使用します。
1039         *
1040         * @og.rev 5.10.9.0 (2019/03/01) storageType,bucketNameを出力対象に追加。
1041         * @og.rev 5.10.16.0 (2019/10/04) prop追加
1042         * 
1043         * @return このクラスの文字列表現
1044         */
1045        @Override
1046        public String toString() {
1047                return org.opengion.fukurou.util.ToString.title( this.getClass().getName() )
1048                                .println( "VERSION"                     ,VERSION                )
1049                                .println( "method"                      ,method                 )
1050                                .println( "urlStr"                      ,urlStr                 )
1051                                .println( "keys"                        ,StringUtil.array2csv( keys ) )
1052                                .println( "vals"                        ,StringUtil.array2csv( vals ) )
1053                                .println( "proxyHost"           ,proxyHost              )
1054                                .println( "proxyPort"           ,proxyPort              )
1055                                .println( "timeout"                     ,timeout                )               // 5.8.1.1 (2015/06/12) 新規追加
1056                                .println( "useSystemUser"       ,useSystemUser  )
1057                                .println( "authUserPass"        ,authUserPass   )
1058                                .println( "display"                     ,display                )
1059                                .println( "postData"            ,postData               )
1060                                .println( "xslFile"                     ,xslFile                )
1061                                .println( "saveFile"            ,saveFile               )
1062                                .println( "errNglctFlag"        ,errNglctFlag   )
1063                                .println( "soapNameSpace"       ,soapNameSpace  )
1064                                .println( "soapMethodName"      ,soapMethodName )
1065                                .println( "tableId"                     ,tableId                )
1066                                .println( "rowKey"                      ,rowKey                 )
1067                                .println( "colKeys"                     ,StringUtil.array2csv( colKeys ) )
1068                                .println( "rtnKeys"                     ,StringUtil.array2csv( rtnKeys ) )
1069                                .println( "storageType"         ,storageType    )
1070                                .println( "bucketName"          ,bucketName             )
1071                                .println( "contentType"         ,contentType    )
1072                                .println( "propKeys"            ,propKeys       )
1073                                .println( "propVals"            ,propVals       )
1074                                .println( "Other..."            ,getAttributes().getAttribute() )
1075                                .fixForm().toString() ;
1076        }
1077}