做项目时遇到的需求如下:本地查询的结果,导出XLS,上传至FTP。
---------------------
1、本地搭建FTP服务器用来测试
2、编写JAVA程序实现FTP上传
---------------------
具体如下:
1、本地搭建FTP服务器用来测试
服务端FTP的建立选用了【Serv-U】程序,很小,20M的样子,简洁好用,网上教程一堆,搭建的FTP地址:127.0.0.1,端口21,用户名test,密码test。
FTP客户端工具很多,如:FlashFXP、cuteftppro等
2、编写JAVA程序实现FTP上传
网上找了下资料,发现apache的FTPClient封装的很好,对于简单的FTP上传,直接拿来用就行。
引入包:commons-net-3.1.jar
代码如下:
2.1 FTP上传工具类
import java.io.IOException;
import java.io.InputStream;
import org.apache.commons.net.ftp.FTPClient;
import org.apache.commons.net.ftp.FTPReply;
public class FtpUtil {
/**
* Description: 向FTP服务器上传文件
* @param url FTP服务器hostname
* @param port FTP服务器端口
* @param username FTP登录账号
* @param password FTP登录密码
* @param path FTP服务器保存目录
* @param filename 上传到FTP服务器上的文件名
* @param input 输入流
* @return 成功返回true,否则返回false
*/
public static boolean uploadFile(String url,int port,String username, String password,
String path, String filename, InputStream input) {
boolean success = false;
FTPClient ftp = new FTPClient();
try {
int reply;
ftp.connect(url, port);//连接FTP服务器
//如果采用默认端口,可以使用ftp.connect(url)的方式直接连接FTP服务器
ftp.login(username, password);//登录
reply = ftp.getReplyCode();
if (!FTPReply.isPositiveCompletion(reply)) {
ftp.disconnect();
return success;
}
//设置上传目录
ftp.changeWorkingDirectory(path);
ftp.setBufferSize(1024);
ftp.setControlEncoding("GBK");
//设置文件类型(二进制)
ftp.setFileType(FTPClient.BINARY_FILE_TYPE);
ftp.storeFile(filename, input);
input.close();
ftp.logout();
success = true;
} catch (IOException e) {
e.printStackTrace();
} finally {
if (ftp.isConnected()) {
try {
ftp.disconnect();
} catch (IOException ioe) {
}
}
}
return success;
}
}
2.2 测试方法
public void testUpload(){
try {
FileInputStream in=new FileInputStream(new File("D:/test.xlsx"));
boolean flag = uploadFile("127.0.0.1", 21, "test", "test", "/", "test.xlsx", in);
if(flag){
log.info("上传成功!文件路径:" + filepath + filename);
} else{
log.info("上传失败!");
}
} catch (FileNotFoundException e) {
e.printStackTrace();
}
}
使用过程中,遇到的问题如下:
在本地的D:/test.xlsx是能打开的,但上传到FTP后,文件却打不开了。
原因:因为一开始在FTP工具类中没有设置编码,导致乱码,文件打不开,具体的代码设置请看2.1中的33-39行。(ftp.setControlEncoding("GBK"); )
-------------------------------------
文件下载没有做,具体参考文档:
http://blog.csdn.net/haidage/article/details/6859716
官方参考文档:
http://commons.apache.org/proper/commons-net/apidocs/org/apache/commons/net/ftp/FTPClient.html