質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
FTP

FTP(File Transfer Protocol)は、ネットワークでのファイル転送を行うための通信プロトコルの1つである。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Tomcat

TomcatはApache Software Foundation (ASF)で開発されたオープンソースのWebコンテナです。

Q&A

解決済

1回答

5731閲覧

TomcatからFTP(別サーバ)にアップロード出来ない

Batoh33789

総合スコア136

FTP

FTP(File Transfer Protocol)は、ネットワークでのファイル転送を行うための通信プロトコルの1つである。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Tomcat

TomcatはApache Software Foundation (ASF)で開発されたオープンソースのWebコンテナです。

0グッド

0クリップ

投稿2017/02/20 02:43

編集2017/02/20 03:01

お世話になります。

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アクセスアカウント情報がコマンドで実行している時と同じか再確認
全く同じ情報で試してますが、コマンドで実行時は動作しました。

-----ここまで-----

何か考えられる対策でも構いません。
ご助言頂けましたら幸いです。

また、不足している情報等ございましたら、ご指摘頂けますでしょうか。
お手数おかけ致しますが、よろしくお願い致します。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kunai

2017/02/20 02:48

該当箇所のソースコードを提示いただけますか。また、「NG」というのはどういう状態なのか、詳細いただけますか。エラー等はなく正常終了しているが、送れていない等。また、確認済みかとは思いますが、ソースコードに記載のFTPアクセスアカウント情報がコマンドで実行している時と同じか再確認してみてください。
t_obara

2017/02/20 03:10

ftpサーバ側には状況がわかるログは残っていないのでしょうか?またなぜftpにするのでしょう?
Batoh33789

2017/02/20 03:12

t_obara様、FTPサーバはこちらの管理下に無いため、確認は出来ません。また、FTPを使って、という要件のため、変更は出来ません。
t_obara

2017/02/20 03:17

自前でFTPサーバを用意して問題の切り分けを進めてはいかがでしょうか。また、要件とのことですが、セキュリティ的に何か損害が発生するような事態になった場合の危険性については提示されているのでしょうか?
Batoh33789

2017/02/20 03:23

t_obara様、FTPサーバを自前で構築するのは私の権限では不可能です。また、セキュリティに関しましては本件とは異なる認識のため割愛します。
guest

回答1

0

自己解決

下記手順にて、解決致しました。
kunai様、t_obara様、お手数おかけして申し訳ございませんでした。

Tomcatサービスを起動させているアカウントがまずかったようで、
サービスアカウントをLocalServiceからAdministrators権限を持つアカウントに
変更することで正常に動作することを確認致しました。

投稿2017/02/20 03:38

Batoh33789

総合スコア136

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問