问题背景:在本地使用java代码进行文件上传到远程的ftp服务器上,出现了425错误
使用的是commons-net-3.5.jar中的ftpclient进行文件上传,以下是上传的代码:
/**
* 向FTP服务器上传文件
* @param host FTP服务器hostname
* @param port FTP服务器端口
* @param username FTP登录账号
* @param password FTP登录密码
* @param basePath FTP服务器基础目录
* @param filePath FTP服务器文件存放路径。例如分日期存放:/2015/01/01。文件的路径为basePath+filePath
* @param filename 上传到FTP服务器上的文件名
* @param input 输入流
* @return 成功返回true,否则返回false
* */
public static boolean upload(String host, int port, String username, String password,
String basePath, String filePath, String filename, InputStream input) {
boolean result = false;
FTPClient ftp = new FTPClient();
try {
// 登录
if(!loginToFtp(ftp, host, port, username, password))
return result;
//切换到上传目录
if (!ftp.changeWorkingDirectory(basePath + filePath)) {
//如果目录不存在创建目录
String[] dirs = filePath.split("/");
String tempPath = basePath;
for (String dir : dirs) {
if (null == dir || "".equals(dir)) continue;
tempPath += "/" + dir;
if (!ftp.changeWorkingDirectory(tempPath)) {
if (!ftp.makeDirectory(tempPath)) {
return result;
} else {
ftp.changeWorkingDirectory(tempPath);
}
}
}
}
//设置上传文件的类型为二进制类型
ftp.setFileType(FTP.BINARY_FILE_TYPE);
//上传文件
if (!ftp.storeFile(filename, input)) {
return result;
}
input.close();
ftp.logout();
result = true;
} catch (IOException e) {
e.printStackTrace();
} finally {
if (ftp.isConnected()) {
try {
ftp.disconnect();
} catch (IOException ioe) {
}
}
}
return result;
}
// 登录ftp服务器
private static boolean loginToFtp(FTPClient ftp, String host, int port, String username, String password) throws SocketException, IOException {
int reply;
ftp.connect(host, port);
// 如果采用默认端口,可以使用ftp.connect(host)的方式直接连接FTP服务器
ftp.login(username, password);// 登录
reply = ftp.getReplyCode();
if (!FTPReply.isPositiveCompletion(reply)) {
ftp.disconnect();
return false;
}
return true;
}
备注:
1.使用windows自身的ftp客户端可以进行上传至远程服务器
2.将ftp服务器放在本地同样可以上传
2017.1.25日更新
後面再次遇到上傳425的錯誤,發現主要的問題就是ftp的主動模式和被動模式。客戶端如果開放連接埠(或關閉防火牆)採取主動模式上傳是沒有問題的。如果客戶端開啟防火牆或防火牆沒有開放相應端口,則採取主動模式是上傳文件的,雖然可以登錄,所以採用被動模式可以解決,客戶端也要設定為被動模式。
==================
偶然更換了tomcat以後,就找到了原因。之前使用的是myeclipse自備的tomcat7,可能與ftp有衝突,後面更換為tomcat8.X以後就可以正常上傳了。