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. Android hellocharts 柱形图详解

    近日需要做图表结构的项目,目前最火的就是hellocharts  和MPAndroidChart  相对来说hellocharts集成比较简单: 官网地址   https://github.com/l ...

  2. 初步认识Spring MVC框架

    Spring MVC 框架和Struts2等一样属于MVC框架,用于处理页面和后台的交互,据说它的效率要高于Struts2.下面县先说一下Spring MVC的结构,Spring MVC主要由Disp ...

  3. Mysql字符串截取函数

    今天建视图时,用到了MySQL中的字符串截取,很是方便. 感觉上MySQL的字符串函数截取字符,比用程序截取(如PHP或JAVA)来得强大,所以在这里做一个记录,希望对大家有用. 函数: 1.从左开始 ...

  4. DELL inspiron1420 linux下的wifi驱动安装

    首先确定无线网卡类型: lspci -vnn -d 14e4: 比如我的网卡类型为 04:00.0 Network controller [0280]:Broadcom Corporation BCM ...

  5. php读写csv、xml文件: SimpleExcel

    实例结构: 1. csv2xml.demo.php <?php use SimpleExcel\SimpleExcel; // 这句不能少! require_once ('../lib/Simp ...

  6. BZOJ3211花神游历各国

    BZOJ3211花神游历各国 BZOJ luogu 分块 记一个all表示该块是否全部<=1,如果all不为真就暴力修改 因为一个数被开根的次数不多,即使\(10^{12}\)只要开根6次也会变 ...

  7. 我的Android进阶之旅------>android中getLocationInWindow 和 getLocationOnScreen的区别

    View.getLocationInWindow(int[] location) 一个控件在其父窗口中的坐标位置 View.getLocationOnScreen(int[] location) 一个 ...

  8. Mysql 学习1

      Mysql学习   一.数据库   1 数据库概念(了解) 1.1 什么是数据库 数据库就是用来存储和管理数据的仓库! 数据库存储数据的优先: 可存储大量数据: 方便检索: 保持数据的一致性.完整 ...

  9. QT发布的EXE打包压缩成单文件

    Enigma virtual box 是免费的软件虚拟化工具,它可以将多个文件封装到您的应用程序主文件,这样您的软件就可以制作成为单文件的绿色软件. enigma virtual box 支持所有类型 ...

  10. Kindeditor API

    根据map规则删除range中的element或attribute. cmd.remove({ span : '*', div : 'class,border' });   commonNode(ma ...