C#实现不同ftp服务器间文件(夹)同步

图1 实现不同ftp服务器间文件(夹)同步的实现思路图

    /// <summary>
/// 将文件夹1从ftp服务器1移到ftp服务器2文件夹2
/// </summary>
/// <param name="sFtpUriD">源ftp url:ftp://ip+port</param>
/// <param name="sFilePathD">源ftp 文件路径:/xxx/xxx/xxx</param>
/// <param name="sFtpUserD">源ftp用户名</param>
/// <param name="sFtpPwdD">源ftp密码</param>
/// <param name="sFtpUriU">目的ftp url:ftp://ip+port</param>
/// <param name="sFilePathU">目的ftp 文件路径:/xxx/xxx/xxx</param>
/// <param name="sFtpUserU">目的ftp用户名</param>
/// <param name="sFtpPwdU">目的ftp密码</param>
/// <returns></returns>
public bool MoveFolderOnDiffFtp(string sFtpUriD, string sFolderPathD, string sFtpUserD, string sFtpPwdD,
string sFtpUriU, string sFolderPathU, string sFtpUserU, string sFtpPwdU)
{
//获取文件夹中的详细文件列表信息(包括文件大小信息)
string[] sFileNameArr = GetFileList(sFtpUriD + sFolderPathD, WebRequestMethods.Ftp.ListDirectoryDetails, sFtpUserD, sFtpPwdD);
//判断是否为单个文件
if (sFileNameArr.Length <= ) //文件夹中存在单文件
{
//在ftp服务器2上创建文件夹
FtpCheckDirectoryExist(sFtpUriU + "/", sFolderPathU + "/", sFtpUserU, sFtpPwdU);
if (sFileNameArr[sFileNameArr.Length - ] == "")
{
string[] onlyname = GetFileList(sFtpUriD + sFolderPathD, WebRequestMethods.Ftp.ListDirectory, sFtpUserD, sFtpPwdD);
foreach (string onlynames in onlyname)
{
if (onlynames == "" || onlynames == " ")
{
break;
}
else
{
MoveFileOnDiffFtp(sFtpUriD, sFolderPathD + "/" + onlynames, sFtpUserD, sFtpPwdD,
sFtpUriU, sFolderPathU + "/" + onlynames, sFtpUserU, sFtpPwdU);
break;
}
}
}
}
else //文件夹中存在多文件或子文件夹
{
//在ftp服务器2上创建文件夹
FtpCheckDirectoryExist(sFtpUriU + "/", sFolderPathU + "/", sFtpUserU, sFtpPwdU);
foreach (string sFileName in sFileNameArr)
{
//判断是否具有文件夹标识<DIR>
if (sFileName.Contains("<DIR>"))
{
string sInnerFloder = sFileName.Split(new string[] { "<DIR>" }, StringSplitOptions.None)[].Trim();
MoveFolderOnDiffFtp(sFtpUriD, sFolderPathD + "/" + sInnerFloder, sFtpUserD, sFtpPwdD,
sFtpUriU, sFolderPathU + "/" + sInnerFloder, sFtpUserU, sFtpPwdU); //递归文件夹中的子文件夹
}
else
{
string[] onlyname = GetFileList(sFtpUriD + sFolderPathD, WebRequestMethods.Ftp.ListDirectory, sFtpUserD, sFtpPwdD);
foreach (string onlynames in onlyname)
{
if (onlynames == "" || onlynames == " " || sFileName == "")
{
break;
}
else
{
if (sFileName.Contains(" " + onlynames))
{
MoveFileOnDiffFtp(sFtpUriD, sFolderPathD + "/" + onlynames, sFtpUserD, sFtpPwdD,
sFtpUriU, sFolderPathU + "/" + onlynames, sFtpUserU, sFtpPwdU);
break;
}
}
}
}
}
}
return true;
}
/// <summary>
/// 将文件从ftp服务器1移到ftp服务器2文件
/// </summary>
/// <param name="sFtpUriD">源ftp url:ftp://ip+port</param>
/// <param name="sFilePathD">源ftp 文件路径:/xxx/xxx/xxx</param>
/// <param name="sFtpUserD">源ftp用户名</param>
/// <param name="sFtpPwdD">源ftp密码</param>
/// <param name="sFtpUriU">目的ftp url:ftp://ip+port</param>
/// <param name="sFilePathU">目的ftp 文件路径:/xxx/xxx/xxx</param>
/// <param name="sFtpUserU">目的ftp用户名</param>
/// <param name="sFtpPwdU">目的ftp密码</param>
/// <returns></returns>
public bool MoveFileOnDiffFtp(string sFtpUriD, string sFilePathD, string sFtpUserD, string sFtpPwdD,
string sFtpUriU, string sFilePathU, string sFtpUserU, string sFtpPwdU)
{
try
{
//在目的ftp服务器上创建文件夹
string sFolderPathU = sFilePathU.Substring(, sFilePathU.LastIndexOf("/"));
FtpCheckDirectoryExist(sFtpUriU + "/", sFolderPathU + "/", sFtpUserU, sFtpPwdU);
//1.从源ftp服务器1下载
FtpWebRequest reqFtpDownload;
reqFtpDownload = (FtpWebRequest)FtpWebRequest.Create(new Uri(sFtpUriD + sFilePathD));
reqFtpDownload.Credentials = new NetworkCredential(sFtpUserD, sFtpPwdD);
reqFtpDownload.Method = WebRequestMethods.Ftp.DownloadFile; //下载方法
reqFtpDownload.KeepAlive = false;
reqFtpDownload.UseBinary = true;
reqFtpDownload.Proxy = null;
FtpWebResponse response = (FtpWebResponse)reqFtpDownload.GetResponse();
//将从服务器1下载的响应流直接作为上传到服务器2的上传流
Stream stream = response.GetResponseStream();
//2.上传到目的ftp服务器2
FtpWebRequest reqFTPUpload;
reqFTPUpload = (FtpWebRequest)FtpWebRequest.Create(new Uri(sFtpUriU + sFilePathU));
reqFTPUpload.Credentials = new NetworkCredential(sFtpUserU, sFtpPwdU);
reqFTPUpload.Method = WebRequestMethods.Ftp.UploadFile; //上传方法
reqFTPUpload.KeepAlive = false;
reqFTPUpload.UseBinary = true;
reqFTPUpload.Proxy = null;
int buffLength = ; //每次读入文件流2kb
byte[] buff = new byte[buffLength];
Stream requestStream = reqFTPUpload.GetRequestStream();
int len = stream.Read(buff, , buff.Length); //文件大小
while (len > )
{
requestStream.Write(buff, , len);
len = stream.Read(buff, , buffLength);
}
stream.Close();
requestStream.Close();
stream.Dispose();//释放资源
requestStream.Dispose();//释放资源return true;
}
catch (Exception ex)
{
         return false;
}
}
/// <summary>
/// 获取ftp上文件夹中的文件(夹)列表信息
/// </summary>
/// <param name="sFloderPath">ftp路径</param>
/// <param name="type">获取列表的类型(详细或只有文件名)</param>
/// <param name="sFtpUser">ftp用户名</param>
/// <param name="sFtpPwd">ftp密码</param>
/// <returns></returns>
private string[] GetFileList(string sFloderPath, string type ,string sFtpUser,string sFtpPwd)
{
WebResponse webresp = null;
StreamReader ftpFileListReader = null;
FtpWebRequest ftpRequest = null;
StringBuilder str = new StringBuilder();
try
{
ftpRequest = (FtpWebRequest)WebRequest.Create(new Uri(sFloderPath));
ftpRequest.Credentials = new NetworkCredential(sFtpUser, sFtpPwd);
ftpRequest.Method = type;
webresp = ftpRequest.GetResponse();
ftpFileListReader = new StreamReader(webresp.GetResponseStream(), Encoding.UTF8);
string line = ftpFileListReader.ReadLine();
while (line != null)
{
str.Append(line);
str.Append("/n");
line = ftpFileListReader.ReadLine();
}
}
catch (Exception ex)
{}
return str.ToString().Split(new string[] { "/n" }, StringSplitOptions.None);
}
/// <summary>
/// 判断文件的目录是否存,不存则创建
/// </summary>
/// <param name="destFilePath"></param>
private static void FtpCheckDirectoryExist(string strFtpURI, string destFilePath, string strFtpUserID, string strFtpPassword)
{
string fullDir = destFilePath.Substring(, destFilePath.LastIndexOf("/"));
string[] dirs = fullDir.Split('/');
string curDir = "";
for (int i = ; i < dirs.Length; i++)
{
string dir = dirs[i];
//如果是以/开始的路径,第一个为空
if (dir != null && dir.Length > )
{
try
{
curDir += dir + "/";
FtpMakeDir(strFtpURI, curDir, strFtpUserID, strFtpPassword);
}
catch (Exception)
{}
}
}
}
/// <summary>
/// 创建ftp目录
/// </summary>
private static Boolean FtpMakeDir(string strFtpURI, string destFilePath, string strFtpUserID, string strFtpPassword)
{
FtpWebRequest req = (FtpWebRequest)WebRequest.Create(strFtpURI + destFilePath);
req.Credentials = new NetworkCredential(strFtpUserID, strFtpPassword);
req.Proxy = null;
req.KeepAlive = false;
req.Method = WebRequestMethods.Ftp.MakeDirectory;//请求方法为创建目录方法
req.UseBinary = true;
FtpWebResponse response = req.GetResponse() as FtpWebResponse;
Stream ftpStream = response.GetResponseStream();
ftpStream.Close();
response.Close();
req.Abort();
return true;
}

......

C# 实现文件(夹)在ftp服务器间的同步【无需将文件(夹)保存到本地】的更多相关文章

  1. Win7 自带FTP将文件复制到FTP服务器时发生错误。

    错误截图: 错误信息: 将文件复制到FTP服务器时发生错误.请检查是否有权限将文件放到该服务器上. 详细信息: 200 Type set to I. 200 PORT commad successfu ...

  2. 检验指定路径的文件是否存在ftp服务器中

    import org.apache.commons.net.ftp.FTP;import org.apache.commons.net.ftp.FTPClient;import org.apache. ...

  3. [转]实用教程:搭建FTP服务器以实现局域网飞速传输文件

    原文地址:https://www.ithome.com/html/win10/304059.htm 相信很多人都面临过这样的问题:一个局域网下有很多设备,我们想在这些设备之间互传文件,有些文件非常大, ...

  4. Android和FTP服务器交互,上传下载文件(实例demo)

    今天同学说他备份了联系人的数据放在一个文件里,想把它存到服务器上,以便之后可以进行下载恢复..于是帮他写了个上传,下载文件的demo 主要是 跟FTP服务器打交道-因为这个东东有免费的可以身亲哈 1. ...

  5. Linux小工具:文件上传ftp服务器

    工作期间,每次将文件上传至ftp服务器时,均需要手工输入ip.用户名.密码等,因此,考虑编写脚本完成文件的上传任务.具体的脚本sync.sh如下: #!/bin/bash source ~/.bash ...

  6. Linux 常用命令 服务器间scp 用户 export 创建文件、软连接

    获取外网ip curl icanhazip.com 服务器间的 文件 复制 scp root@ip:/源目录 目标目录 软连接 查看软连接 ls -li 创建软连接 ln -s 源文件 目标文件 -s ...

  7. CentOS6.5下搭建ftp服务器(三种认证模式:匿名用户、本地用户、虚拟用户)

    CentOS 6.5下搭建ftp服务器 vsftpd(very secure ftp daemon,非常安全的FTP守护进程)是一款运行在Linux操作系统上的FTP服务程序,不仅完全开源而且免费,此 ...

  8. 使用rsync实现不同Linux服务器间目录同步

    实现目标:    A 服务器上 /opt/web 目录,与B服务器上 /opt/web目录实现同步.即:B主动与A进行同步.   OS: Reaht AS4   A Server  192.168.1 ...

  9. c#之向ftp服务器传文件

    .Net提供了FtpWebRequest类,代码如下: using System; using System.Collections.Generic; using System.IO; using S ...

随机推荐

  1. Memcache mutex设计模式

    Memcache mutex设计模式 转自:https://timyang.net/programming/memcache-mutex/ 场景 Mutex主要用于有大量并发访问并存在cache过期的 ...

  2. bzoj 4059:Non-boring sequences 分治

    题目: 我们害怕把这道题题面搞得太无聊了,所以我们决定让这题超短.一个序列被称为是不无聊的,仅当它的每个连续子序列存在一个独一无二的数字,即每个子序列里至少存在一个数字只出现一次.给定一个整数序列,请 ...

  3. hadoop-pig学习笔记

    A1 = LOAD '/luo/lzttxt01.txt' AS (col1:chararray,col2:int,col3:int,col4:int,col5:double,col6:double) ...

  4. js 自定义方法 设置可选参数的方法

    原链接 http://www.cnblogs.com/RightDear/p/3156652.html PHP有个很方便的用法是在定义函数时可以直接给参数设默认值,如: function simue ...

  5. VS2005环境下的DLL应用

    VS2005环境下的DLL应用 作者:一点一滴的Beer http://beer.cnblogs.com/ 以前写过一篇题为<VC++的DLL应用(含Demo演示)>的文章,当时是刚开始接 ...

  6. php system()

    学习源头: https://blog.csdn.net/ltx06/article/details/53992905 system(“nohup ./test.py $s &”); 这个不会在 ...

  7. PHP:JSON字符串转换为中文,中文转换为JSON字符串

    /** * 中文转换为JSON字符串 * @param $chinese_str 中文:可以包含中文字母数字 * @return string */ function json_encode($chi ...

  8. Spark on yarn的两种模式 yarn-cluster 和 yarn-client

    从深层次的含义讲,yarn-cluster和yarn-client模式的区别其实就是Application Master进程的区别,yarn-cluster模式下,driver运行在AM(Applic ...

  9. mongoTemplate操作内嵌文档

    关系型数据库中,表与表的关联关系有1:1,也有1:n的.在java的面向对象的世界里就是主对象嵌子对象,与主对象嵌集合<子对象>的两种形式. 主对象嵌子对象操作: 新增.修改都直接用如下方 ...

  10. Java-API-Package:java.lang

    ylbtech-Java-API-Package:java.lang 1.返回顶部 1. Package java.lang Provides classes that are fundamental ...