基于FTP服务、JAVA实现文件同步操作
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实现文件同步操作的更多相关文章
- 基于RMI服务传输大文件的完整解决方案
基于RMI服务传输大文件,分为上传和下载两种操作,需要注意的技术点主要有三方面,第一,RMI服务中传输的数据必须是可序列化的.第二,在传输大文件的过程中应该有进度提醒机制,对于大文件传输来说,这点很重 ...
- ftpget 从Windows FTP服务端获取文件
/********************************************************************************* * ftpget 从Windows ...
- 转:【专题十一】实现一个基于FTP协议的程序——文件上传下载器
引言: 在这个专题将为大家揭开下FTP这个协议的面纱,其实学习知识和生活中的例子都是很相通的,就拿这个专题来说,要了解FTP协议然后根据FTP协议实现一个文件下载器,就和和追MM是差不多的过程的,相信 ...
- C# FileStream进行FTP服务上传文件和下载文件
定义FileStream类的操作类:操作类名: FtpUpDown 上传文件 /// <summary> /// 上传文件 /// </summary> /// <par ...
- C# WebClient进行FTP服务上传文件和下载文件
定义WebClient使用的操作类: 操作类名称WebUpDown WebClient上传文件至Ftp服务: //// <summary> /// WebClient上传文件至Ftp服务 ...
- 基于ftp服务的三种登录方式及其相关的访问控制和优化
ftp(简单文件传输协议),是一种应用广泛的网络文件传输协议和服务,占用20和21号端口,主要用于资源的上传和下载. 在linux对于ftp同widows一样具有很多的种类,这里主要介绍vsfptd( ...
- 专题十一:实现一个基于FTP协议的程序——文件上传下载器
引言: 在这个专题将为大家揭开下FTP这个协议的面纱,其实学习知识和生活中的例子都是很相通的,就拿这个专题来说,要了解FTP协议然后根据FTP协议实现一个文件下载器,就和和追MM是差不多的过程的,相信 ...
- 基于ftp服务实现yum网络共享
安装ftp服务:yum install vsftpd 安装后: CentOS7 启动服务:systemctl start vsftpd 设置开机启动:systemctl enable vsftpd 同 ...
- Java实现连接FTP服务并传递文件
public class FtpClientUtil { private String host; private int port; private String username; private ...
随机推荐
- 【BZOJ2407/4398】探险/福慧双修 最短路建模
[BZOJ2407]探险 Description 探险家小T好高兴!X国要举办一次溶洞探险比赛,获奖者将得到丰厚奖品哦!小T虽然对奖品不感兴趣,但是这个大振名声的机会当然不能错过! 比赛即将开始,工作 ...
- Asp.Net MVC3中如何进行单元测试?
下面我们就以一个示例演示一下如何进行单元测试? public Model.UserInfo UpdateEntity(Model.UserInfo entity) { db.UserInfo.Atta ...
- SocketAsyncEventArgs里的AcceptSocket能独立存在吗?
独立存在是什么意思? 先来看一个例子.我们知道一个Socket对象(我们叫他ListenScoket)可以调用AcceptAsync并接受一个SocketAsyncEventArgs对象,如果操作成功 ...
- Android系统移植与调试之------->安装apk时出现错误Failure [INSTALL_FAILED_DEXOPT]问题解决的方法
在android4.0源码里面编译出来apk后,用adb install (或adb install -r 重装)安装时,报错[INSTALL_FAILED_DEXOPT]. xu@xu-PC:~$ ...
- c++得到本地username和IP
bool CDlgResetAlarmInfo::GetLocalUserNameAddIP(CString &a_lstrUserName ,CString &a_IpStr) { ...
- linux 创建账户
linux下创建用户 linux下创建用户(一) Linux 系统是一个多用户多任务的分时操作系统,不论什么一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统. ...
- Redis持久化——AOF(二)
核心知识点: 1.AOF:以独立日志的方式记录写命令,重启时再执行命令.与RDB不同的是解决数据持久化的实时性,可以记录所有写操作. 2.AOF工作流程:写入命令.文件同步.文件重写.文件加载. 3. ...
- dos与unix文件格式之间的转换
1. VI编辑器中转换 在VI中使用命令 set ff?(fileformat)可以查看文件的格式,使用set ff=dos(unix)可以设置文件的格式 2.使用sed处理(来至http://www ...
- myBatis中使用Map进行遍历
myBatis中使用Map获取key, value的方式 第一次的配置 <trim prefix=" tags =case" suffix="end"&g ...
- JVM - 堆外内存
看了不少资料,总结下: 堆外内存 / 直接内存(Direct Memory)JDK1.4中引入的NIO类,基于channel和Buffer的I/O方式,可用Native库直接分配堆外内存,然后利用一个 ...