问题背景:在本地使用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以后就可以正常上传了。