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 ...
随机推荐
- 未定义的标示符“RECT”,引入了windows.h头文件也没有用?
我用的是win8的vs2012,RECT应该引入什么头文件?windows.h我第一个就引入了,去windows.h里面搜也搜不到RECT这个关键字,应该引入哪个头文件呢? 真是奇怪啊,是不是还需要什 ...
- 开放群组架构TOGAF
作于一个架构师尤其是企业架构师来说,丰富的理论知识可以帮助他在架构规划及管理过程中站在更高的角度去看待问题,历史发展原因有很多已成体系的架构理论,TOGAF是近年来比较接地气的,受到了政府和银行业的重 ...
- c++运行时决定数组大小 variable-length array
本文由Suzzz原创,发布于 http://www.cnblogs.com/Suzzz/p/4117431.html,转载请保留此声明 variable-length array是C99添加的一个特性 ...
- navicat链接远程数据库
1.之前使用的是常规的连接方式 学习源头: https://jingyan.baidu.com/article/0aa2237573c1e688cc0d6427.html 这里的ip地址是服务器的ip ...
- (转)NHibernate之Generator主键生成方式
本文转载自:http://www.cnblogs.com/lemon-love/archive/2010/03/10/1683058.html (1) assigned主键由外部程序负责生成,无需NH ...
- python风格指南
还在让别人一眼就看出你是一只野生程序猿嘛,快来看看谷歌的python风格指南提升逼格吧! http://zh-google-styleguide.readthedocs.io/en/latest/go ...
- Spring MVC配置详解(1)
web.xml的配置 <!-- 配置前端控制器 前端控制器(DispatcherServlet)--> <servlet> <servlet-name>spring ...
- docker 安装mysql 使用navicat访问 解决
1. 下载Mysql的Docker镜像: 2. 运行镜像,设置root账号初始密码(123456),映射本地宿主机端口3306到Docker端口3306.测试过程没有挂载本地数据盘: 3. 查看已运行 ...
- nginx isis
Nginx+IIS简单的部署 随着互联网项目用户访问量不断上升,单点web服务器是无法满足大型高并发高负载的业务处理的,为了给web服务器做负载均衡方案,打算采用Nginx搭建负载均衡服务器,把用 ...
- ghld data format
%CTF: 1.00%FileType: PROF strp "VelocityProfile"%PROFSpec: 1.00 2006 00 00%Manufacturer: C ...