C# 实现文件(夹)在ftp服务器间的同步【无需将文件(夹)保存到本地】
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服务器间的同步【无需将文件(夹)保存到本地】的更多相关文章
- Win7 自带FTP将文件复制到FTP服务器时发生错误。
错误截图: 错误信息: 将文件复制到FTP服务器时发生错误.请检查是否有权限将文件放到该服务器上. 详细信息: 200 Type set to I. 200 PORT commad successfu ...
- 检验指定路径的文件是否存在ftp服务器中
import org.apache.commons.net.ftp.FTP;import org.apache.commons.net.ftp.FTPClient;import org.apache. ...
- [转]实用教程:搭建FTP服务器以实现局域网飞速传输文件
原文地址:https://www.ithome.com/html/win10/304059.htm 相信很多人都面临过这样的问题:一个局域网下有很多设备,我们想在这些设备之间互传文件,有些文件非常大, ...
- Android和FTP服务器交互,上传下载文件(实例demo)
今天同学说他备份了联系人的数据放在一个文件里,想把它存到服务器上,以便之后可以进行下载恢复..于是帮他写了个上传,下载文件的demo 主要是 跟FTP服务器打交道-因为这个东东有免费的可以身亲哈 1. ...
- Linux小工具:文件上传ftp服务器
工作期间,每次将文件上传至ftp服务器时,均需要手工输入ip.用户名.密码等,因此,考虑编写脚本完成文件的上传任务.具体的脚本sync.sh如下: #!/bin/bash source ~/.bash ...
- Linux 常用命令 服务器间scp 用户 export 创建文件、软连接
获取外网ip curl icanhazip.com 服务器间的 文件 复制 scp root@ip:/源目录 目标目录 软连接 查看软连接 ls -li 创建软连接 ln -s 源文件 目标文件 -s ...
- CentOS6.5下搭建ftp服务器(三种认证模式:匿名用户、本地用户、虚拟用户)
CentOS 6.5下搭建ftp服务器 vsftpd(very secure ftp daemon,非常安全的FTP守护进程)是一款运行在Linux操作系统上的FTP服务程序,不仅完全开源而且免费,此 ...
- 使用rsync实现不同Linux服务器间目录同步
实现目标: A 服务器上 /opt/web 目录,与B服务器上 /opt/web目录实现同步.即:B主动与A进行同步. OS: Reaht AS4 A Server 192.168.1 ...
- c#之向ftp服务器传文件
.Net提供了FtpWebRequest类,代码如下: using System; using System.Collections.Generic; using System.IO; using S ...
随机推荐
- CANopenNode drvTemplate/CO_driver.h hacking
/************************************************************************ * CANopenNode drvTemplate/ ...
- 利用MsChart控件绘制多曲线图表
在.Net4.0框架中,微软已经将Mschart控件集成了进来,以前一直在web下面用过,原来winform下的Mschart控件更加简单更加方便,今天我们用mschart绘制一个多曲线图,发现MsC ...
- Xml日志记录文件最优方案(附源代码)
Xml作为数据存储的一种方式,当数据非常大的时候,我们将碰到很多Xml处理的问题.通常,我们对Xml文件进行编辑的最直接的方式是将xml文件加载到XmlDocument,在内存中来对XmlDocume ...
- mysql下this is incompatible with sql_mode=only_full_group_by解决方案
本地测试没有问题,部署到客户服务器之后报如下错误: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Expression #1 o ...
- compile cef2526
fetch --nohooks chromium cd /path/to/chromium/src# git checkout -b 51.0.2704.103 refs/tags/51.0.2704 ...
- ASP.NET网站性能提升的几个方法
1. HTTP 压缩 HTTP 压缩通常用于压缩从服务端返回的页面内容.它压缩HTTP请求和响应,这个会是巨大的性能提升.我的项目是基于Window Server 2003开发的,可以参考这篇文章. ...
- 【转】LTE-NAS过程学习总结
为了从网络得到非接入层服务,网络中非接入层节点必须知道有关UE的信息.为了这个目的,UE不得不发起附属过程,该过程是在UE开机和初始接入网络时必须被执行的. 一旦该过程成功,MME上就会建立好一个该U ...
- 实现MVC
为什么需要MVC? 1.代码规模越来越大,切分职责是大势所趋: 2.为了复用:很多逻辑是一模一样的: 3.为了后期维护方便:修改一块功能不影响其他功能 MVC只是手段,最终目的是模块化和复用 Cont ...
- Spring学习十一
一: 创建bean的方法: 1: 如果不采用构造注入:默认调用bean的无参构造函数,因此该类必须要提供无参构造函数,用无参构造函数用反射创建bean. : 如果采用构造 ...
- VisualGDB系列11:Linux C++项目中使用外部Linux库
根据VisualGDB官网(https://visualgdb.com)的帮助文档大致翻译而成.主要是作为个人学习记录.有错误的地方,Robin欢迎大家指正. 在<使用VS创建Linux静态库和 ...