お世話になります。
ApacheTomcat上にあるWebサービスから、FTPサーバ(別PC)にファイルをアップロードする
必要があるのですが、どう頑張っても動作しないため、質問させてください。
開発環境
・Java 1.8
・Tomcat 8
・commons-net-3.5.jar、commons-net-3.5-sources.jar使用
・フレームワークは特に無し
こちらで確認したこと
・Tomcat上で動作しているモジュールからFTP送信しようとするとNG
・Tomcatのエラーログには何も出ない
(ID、パスワード、サーバアドレス、ファイルが存在しないなどのエラーではない)
・コマンドプロンプトからFTPコマンドを叩いての接続はOK
(通信が拒否されているわけではない)
・ブラウザのエラーメッセージは500 Internal Server Error
-----追記-----
以下FTP通信部のコードです
Java
1 private static final int FTP_PORT = 21; 2 private static final String HOST = PropertiesUtil.getValue("ftpserver"); 3 private static final String USER = PropertiesUtil.getValue("ftpuser") ; 4 private static final String PASSWORD = PropertiesUtil.getValue("ftppass"); 5 private static final String OUTPUT_FOLDER_NAME = PropertiesUtil.getValue("outputfoldername"); 6 7 public String sendFile (String remoteFilename, InputStream is ) { 8 final FTPClient ftpclient = new FTPClient(); 9 try { 10 //指定するホスト、ポートに接続します 11 ftpclient.connect(HOST, FTP_PORT); 12 // コネクト 13 if (!FTPReply.isPositiveCompletion(ftpclient.getReplyCode())) { 14 return "connectfail"; 15 } 16 //ログイン 17 if (ftpclient.login(USER, PASSWORD) == false) { 18 return "loginfail"; 19 } 20 //ファイル転送モード設定 21 ftpclient.setFileType(FTPClient.BINARY_FILE_TYPE); 22 //ファイル転送 23 ftpclient.storeFile(OUTPUT_FOLDER_NAME + remoteFilename, is); 24 return null; 25 } catch (IOException e) { 26 return "uploadfail"; 27 } finally { 28 try { 29 ftpclient.disconnect(); //接続解除 30 } catch (IOException e) { 31 } 32 } 33 }
Java
1// プロパティファイルの中身 2ftpserver=192.168.0.xxx 3ftpuser=user 4ftppass=pass 5outputfoldername=test/
Java
1public class PropertiesUtil { 2 final static String PROP_PATH = "C:\\test\\test.properties"; 3 4 public static String getValue(String id) { 5 final Properties prop = new Properties(); 6 try { 7 final InputStream is = new FileInputStream(PROP_PATH); 8 prop.load(is); 9 is.close(); 10 return prop.getProperty(id); 11 } catch(Exception e) { 12 e.printStackTrace(); 13 } 14 return null; 15 } 16}
>「NG」というのはどういう状態なのか、詳細いただけますか。
ブラウザに500 Internal Server Errorが表示され、
tomcat8-stderr.logには何も出力されず、
localhost_access_logには接続したログが残ってます。
>FTPアクセスアカウント情報がコマンドで実行している時と同じか再確認
全く同じ情報で試してますが、コマンドで実行時は動作しました。
-----ここまで-----
何か考えられる対策でも構いません。
ご助言頂けましたら幸いです。
また、不足している情報等ございましたら、ご指摘頂けますでしょうか。
お手数おかけ致しますが、よろしくお願い致します。
回答1件
あなたの回答
tips
プレビュー