package lixj.ftp;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.net.SocketException;
import java.util.logging.Logger; import org.apache.commons.net.ftp.FTPClient;
import org.apache.commons.net.ftp.FTPReply; public class FTPUtils { private static FTPUtils instance = null;
private static FTPClient ftpClient = null;
//本地文件目录所在磁盘路径
private static final String DISC_PATH = "D:/server";
// 本地字符编码
private static final String LOCAL_CHARSET = "GBK";
// FTP协议规定文件名编码为iso-8859-1
private static final String SERVER_CHARSET = "ISO-8859-1"; //FTP服务器IP
private String server = "172.20.10.105";
//FTP服务器端口
private int port = 21;
//FTP用户名
private String userName = "lixj";
//FTP用户密码
private String userPassword = "123456"; //日志工具
private static Logger logger = Logger.getLogger(FTPUtils.class.getName()); public static FTPUtils getInstance(){
if(instance == null){
instance = new FTPUtils();
}
ftpClient = new FTPClient();
return instance;
} /**
* 连接FTP服务器
* @return
*/
private boolean connect(){
boolean stat = false;
try {
if(ftpClient.isConnected())
return true;
ftpClient.connect(server, port);
stat = true;
} catch (SocketException e) {
stat = false;
e.printStackTrace();
} catch (IOException e) {
stat = false;
e.printStackTrace();
}
return stat;
} /**
* 打开FTP服务器
* @return
*/
public boolean open(){
if(!connect()){
return false;
} boolean stat = false;
try {
stat = ftpClient.login(userName, userPassword);
// 检测连接是否成功
int reply = ftpClient.getReplyCode();
if (!FTPReply.isPositiveCompletion(reply)) {
close();
stat = false;
}
} catch (IOException e) {
e.printStackTrace();
stat = false;
}
return stat;
} /**
* 关闭FTP服务器
*/
public void close(){
if(ftpClient != null && ftpClient.isConnected()){
try {
ftpClient.logout();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
try {
ftpClient.disconnect();
ftpClient = null;
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
} /**
* 同步文件
* @param relativeFilePath 文件相对路径
* @return succ = true | fail = false
*/
public boolean syncFile(String relativeFilePath) {
if (relativeFilePath == null || "".equals(relativeFilePath.trim())) {
logger.info("文件相对路径不能为空!");
return false;
}
if (new File(DISC_PATH + relativeFilePath).exists()) { //本地存在文件,执行文件上传操作
logger.info("上传文件【"+relativeFilePath+"】");
return uploadFile(DISC_PATH, relativeFilePath);
} else {//本地不存在文件,到FTP服务器下载文件
logger.info("下载文件【"+relativeFilePath+"】");
return downloadFile(DISC_PATH, relativeFilePath);
}
} /**
* 上传文件
* @param discPath 文件所在磁盘路径
* @param relativePath 文件所在相对路径
* @return succ = true | fail = false
*/
public boolean uploadFile(String discPath, String relativePath){
if (discPath == null || "".equals(discPath.trim())) {
logger.info("discPath 文件所在磁盘路径不能为空!");
return false;
}
if (relativePath == null || "".equals(relativePath.trim())) {
logger.info("relativePath 文件相对路径不能为空!");
return false;
}
String dir = relativePath.substring(0, relativePath.lastIndexOf("/"));
String filename = relativePath.substring(relativePath.lastIndexOf("/")+1);
logger.info("文件相对目录="+dir);
logger.info("文件名="+filename);
return uploadFile(dir, filename, discPath + relativePath);
} /**
* 上传文件到FTP服务器
* @param ftpPath FTP-目录
* @param ftpFileName FTP-文件名
* @param filePath 本地文件完整路径
* @return succ = true | fail = false
*/
public boolean uploadFile(String ftpPath, String ftpFileName, String filePath){
FileInputStream input = null;
try {
mkFtpDirs(ftpPath);
ftpClient.changeWorkingDirectory(changeCode(ftpPath));
ftpClient.setBufferSize(1024);
ftpClient.setControlEncoding(LOCAL_CHARSET);
ftpClient.setFileType(FTPClient.BINARY_FILE_TYPE);
input = new FileInputStream(new File(filePath));
boolean result = ftpClient.storeFile(changeCode(ftpFileName), input);
if (result) {
logger.info("上传成功!");
} else {
logger.info("上传失败!");
}
} catch (IOException e) {
e.printStackTrace();
} finally {
if (input != null) {
try {
input.close();
input = null;
} catch (IOException e) {
// TODO Auto-generated catch block
}
}
}
return false;
} /**
* 下载文件
* @param discPath 文件所在磁盘路径
* @param relativePath 文件所在相对路径
* @return
*/
public boolean downloadFile(String discPath, String relativePath){
if (discPath == null || "".equals(discPath.trim())) {
logger.info("discPath 文件所在磁盘路径不能为空!");
return false;
}
if (relativePath == null || "".equals(relativePath.trim())) {
logger.info("relativePath 文件路径不能为空!");
return false;
}
String dir = relativePath.substring(0, relativePath.lastIndexOf("/"));
String filename = relativePath.substring(relativePath.lastIndexOf("/")+1);
logger.info("文件相对目录="+dir);
logger.info("文件名="+filename);
return downloadFile(dir, filename, discPath + dir);
} /**
* 下载文件路径
* @param ftpPath
* @param ftpFileName
* @param localPath
* @return
*/
public boolean downloadFile(String ftpPath, String ftpFileName, String localPath) {
FileOutputStream fos = null ;
try {
File localDirFile = new File(localPath);
if (!localDirFile.exists()) {
localDirFile.mkdirs();
}
fos = new FileOutputStream(new File(localPath, ftpFileName));
ftpClient.enterLocalPassiveMode();
ftpClient.changeWorkingDirectory(changeCode(ftpPath)) ;
boolean result = ftpClient.retrieveFile(changeCode(ftpFileName), fos);
if (result) {
logger.info("下载成功!");
} else {
logger.info("下载失败!");
}
return result;
} catch (Exception e) {
e.printStackTrace();
} finally {
if (fos!=null) {
try {
fos.close() ;
fos = null ;
} catch (Exception e2) { }
}
}
return false;
} /***
* 创建FTP服务器多个层级目录
* @param dir e.g:/目录1/目录2/目录3
* @return
*/
public boolean mkFtpDirs(String dir){
boolean stat = false;
String[] dirs = dir.split("/");
if(dirs.length == 0){
return stat;
}
try {
ftpClient.changeToParentDirectory();
for(String dirss : dirs){
ftpClient.makeDirectory(changeCode(dirss));
ftpClient.changeWorkingDirectory(changeCode(dirss));
}
ftpClient.changeToParentDirectory();
stat = true;
} catch (IOException e) {
e.printStackTrace();
stat = false;
}
return stat;
} /**
* 删除文件
* @param filePathName
* @return
*/
public boolean removeFtpFile(String filePathName){
boolean stat = false;
try{
stat = ftpClient.deleteFile(changeCode(filePathName));
}catch(Exception e){
e.printStackTrace();
stat = false;
}
return stat;
} /**
* 转换文件或目录字符编码
* @param fileOrDirName 文件名或目录名
* @return 转换后的字符串
*/
private String changeCode(String fileOrDirName) {
try {
return new String(fileOrDirName.getBytes(LOCAL_CHARSET), SERVER_CHARSET);
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
return null;
}
} public static void main(String[] args) {
FTPUtils ftp = FTPUtils.getInstance();
ftp.open();
ftp.syncFile("/upload/测试目录/建设项目技术规范书V3.5(1).docx");
ftp.close();
} }

基于FTP服务、JAVA实现文件同步操作的更多相关文章

  1. 基于RMI服务传输大文件的完整解决方案

    基于RMI服务传输大文件,分为上传和下载两种操作,需要注意的技术点主要有三方面,第一,RMI服务中传输的数据必须是可序列化的.第二,在传输大文件的过程中应该有进度提醒机制,对于大文件传输来说,这点很重 ...

  2. ftpget 从Windows FTP服务端获取文件

    /********************************************************************************* * ftpget 从Windows ...

  3. 转:【专题十一】实现一个基于FTP协议的程序——文件上传下载器

    引言: 在这个专题将为大家揭开下FTP这个协议的面纱,其实学习知识和生活中的例子都是很相通的,就拿这个专题来说,要了解FTP协议然后根据FTP协议实现一个文件下载器,就和和追MM是差不多的过程的,相信 ...

  4. C# FileStream进行FTP服务上传文件和下载文件

    定义FileStream类的操作类:操作类名: FtpUpDown 上传文件 /// <summary> /// 上传文件 /// </summary> /// <par ...

  5. C# WebClient进行FTP服务上传文件和下载文件

    定义WebClient使用的操作类: 操作类名称WebUpDown WebClient上传文件至Ftp服务: //// <summary> /// WebClient上传文件至Ftp服务 ...

  6. 基于ftp服务的三种登录方式及其相关的访问控制和优化

    ftp(简单文件传输协议),是一种应用广泛的网络文件传输协议和服务,占用20和21号端口,主要用于资源的上传和下载. 在linux对于ftp同widows一样具有很多的种类,这里主要介绍vsfptd( ...

  7. 专题十一:实现一个基于FTP协议的程序——文件上传下载器

    引言: 在这个专题将为大家揭开下FTP这个协议的面纱,其实学习知识和生活中的例子都是很相通的,就拿这个专题来说,要了解FTP协议然后根据FTP协议实现一个文件下载器,就和和追MM是差不多的过程的,相信 ...

  8. 基于ftp服务实现yum网络共享

    安装ftp服务:yum install vsftpd 安装后: CentOS7 启动服务:systemctl start vsftpd 设置开机启动:systemctl enable vsftpd 同 ...

  9. Java实现连接FTP服务并传递文件

    public class FtpClientUtil { private String host; private int port; private String username; private ...

随机推荐

  1. HDU-4031-Attack(树状数组)

    Problem Description Today is the 10th Annual of "September 11 attacks", the Al Qaeda is ab ...

  2. ios开发:如何用js调用ios

    本文转载至 :http://blog.chinaunix.net/uid-29415710-id-4058564.html - (BOOL)webView:(UIWebView *)webView s ...

  3. 【问题解决】Tomcat 启动时闪退或提示“Neither the JAVA_HOME or the JRE_HOME environmental variable is defined.”

    问题解决思路: 1.分析startup.bat启动脚本:发现其调用了catalina.bat,而catalina.bat调用了setclasspath.bat 2.在setclasspath.bat的 ...

  4. APNS推送原理详解

    推送是解决轮询所造成的流量消耗和电量消耗的一个比较好的解决方案,在Android上,虽然Google提供了GCM(之前为C2DM),但在国内基本等于没用,各大Android应用基本都自己架设推送Ser ...

  5. SQL查询 [SCOPE_IDENTITY、IDENT_CURRENT 和 @@IDENTITY的区别(比较)] ---转载

    @@IDENTITY (Transact-SQL) 返回最后插入的标识值的系统函数. 备注 在一条 INSERT.SELECT INTO 或大容量复制语句完成后,@@IDENTITY 中包含语句生成的 ...

  6. The path "fos_user.from_email.address" cannot contain an empty value, but got null.

    The path "fos_user.from_email.address" cannot contain an empty value, but got null.. 修改 pa ...

  7. LATEX ——WinEdt 破解

    WinEdt 是目前我发现最好的LaTeX编辑器,但是在国内支付不便,且学生许可需$40,只能出此下策,望有余力者尽量购买正版. WinEdt 的旧版本的破解方法众所周知,只需定时删除HKCU\Sof ...

  8. CentOS 7.0 systemd

    CentOS 7 已经切换到 systemd,系统指令也有所变化.之前用于启动.重启.停止各种服务的service 作为向后兼容的指令还能使用,但是将来可能会消失.同时,chkconfig 也改成了s ...

  9. Bootstrap学习5--bootstrap中的模态框(modal,弹出层)

    bootstrap中的模态框(modal),不同于Tooltips,模态框以弹出对话框的形式出现,具有最小和最实用的功能集. 务必将模态框的 HTML 代码放在文档的最高层级内(也就是说,尽量作为 b ...

  10. .vimrc .bashrc

    怕丢了,赶快保存! .bashrc # switch caps lock with escxmodmap -e 'clear Lock' -e 'keycode 0x42 = Escape'sudo ...