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. gridControl使用集锦

    1.grid控件默认选择一行时,focused的cell并不是蓝色的,而是白色的 要想实现一次选择一行全都是蓝色的只要改一个属性就可以了 this.gridView1.OptionsSelection ...

  2. 【BZOJ4358】permu kd-tree

    [BZOJ4358]permu Description 给出一个长度为n的排列P(P1,P2,...Pn),以及m个询问.每次询问某个区间[l,r]中,最长的值域连续段长度. Input 第一行两个整 ...

  3. 爬虫入门【3】BeautifulSoup4用法简介

    快速开始使用BeautifulSoup 首先创建一个我们需要解析的html文档,这里采用官方文档里面的内容: html_doc = """ <html>< ...

  4. eclipse同一个工作空间下分开多个项目

    在Package Explorer顶部的右侧有有机表图标按钮,点击倒三角 Top Level Elements->Working Set.此时就会发现,很多项目会自动纳入一个文件夹,这个文件夹的 ...

  5. POJ 2993 Emag eht htiw Em Pleh【模拟画棋盘】

    链接: http://poj.org/problem?id=2993 http://acm.hust.edu.cn/vjudge/contest/view.action?cid=27454#probl ...

  6. 核函数 深度学习 统计学习 强化学习 神经网络 xx

  7. Python菜鸟之路:前端HTML基础

    前面的章节中,Python的基本知识已经差不多介绍完了.本节介绍HTML相关的知识.需要着重声明的是,前端知识是非常非常重要的知识,以我实际项目经验来看,一个项目的瓶颈在设计和前端.设计就先不说了,前 ...

  8. spring+thymeleaf实现表单验证数据双向绑定

    前言 这个教程介绍了Thymeleaf与Spring框架的集成,特别是SpringMvc框架. 注意Thymeleaf支持同Spring框架的3.和4.版本的集成,但是这两个版本的支持是封装在thym ...

  9. 查看当前.net版本 cmd

    reg query "HKLM\Software\Microsoft\NET Framework Setup\NDP" /s /v version | findstr /i ver ...

  10. 数据库存储I/O类型分析与配置

    存储设备作为数据的容器,为应用提供数据存取服务,而存储系统将数据展现给不同的应用后,应用程序对数据访问不尽相同.简要来说,就是读和写,更加细分的话是以不同的传输单元(I/O大小)进行顺序和随机类型的读 ...