C#版ftp方法实现类的代码_C#教程

/* 
FTPFactory.cs 
Better view with tab space=4 
Written by Jaimon Mathew (jaimonmathew@rediffmail.com) 
Rolander,Dan (Dan.Rolander@marriott.com) has modified the 
download 
method to cope with file name with path information. He also 
provided 
the XML comments so that the library provides Intellisense 
descriptions. 
use the following line to compile 
csc /target:library /out:FTPLib.dll /r:System.DLL FTPFactory.cs 
*/ 
using System; 
using System.Threading; 
using System.Net; 
using System.IO; 
using System.Text; 
using System.Net.Sockets; 
using System.Configuration; 
namespace AudioCollect 

/// <summary> 
/// FTPFactory 的摘要说明。 
/// </summary> 
public class FTPFactory 

static readonly log4net.ILog log = log4net.LogManager.GetLogger("log4net"); 
private string 
remoteHost,remotePath,remoteUser,remotePass,mes; 
private int remotePort,bytes; 
private Socket clientSocket; 
private int retValue; 
private Boolean debug; 
private Boolean logined; 
private string reply; 
private static int BLOCK_SIZE = 512; 
Byte[] buffer = new Byte[BLOCK_SIZE]; 
Encoding ASCII = Encoding.ASCII; 
public FTPFactory() 

string FTPRemoteIP = ConfigurationSettings.AppSettings["FTPRemoteIP"]; 
int FTPRemotePort = Convert.ToInt32( ConfigurationSettings.AppSettings["FTPRemotePort"] ); 
string FTPUser = ConfigurationSettings.AppSettings["FTPUser"]; 
string FTPPassword = ConfigurationSettings.AppSettings["FTPPassword"]; 
remoteHost = FTPRemoteIP; 
remotePath = "."; 
remoteUser = FTPUser; 
remotePass = FTPPassword; 
remotePort =FTPRemotePort; 
debug = false; 
logined = false; 

/// 
/// Set the name of the FTP server to connect to. 
/// 
/// Server name 
public void setRemoteHost(string remoteHost) 

this.remoteHost = remoteHost; 

/// 
/// Return the name of the current FTP server. 
/// 
/// Server name 
public string getRemoteHost() 

return remoteHost; 

/// 
/// Set the port number to use for FTP. 
/// 
/// Port number 
public void setRemotePort(int remotePort) 

this.remotePort = remotePort; 

/// 
/// Return the current port number. 
/// 
/// Current port number 
public int getRemotePort() 

return remotePort; 

/// 
/// Set the remote directory path. 
/// 
/// The remote directory path 
public void setRemotePath(string remotePath) 

this.remotePath = remotePath; 

/// 
/// Return the current remote directory path. 
/// 
/// The current remote directory path. 
public string getRemotePath() 

return remotePath; 

/// 
/// Set the user name to use for logging into the remote server. 
/// 
/// Username 
public void setRemoteUser(string remoteUser) 

this.remoteUser = remoteUser; 

/// 
/// Set the password to user for logging into the remote server. 
/// 
/// Password 
public void setRemotePass(string remotePass) 

this.remotePass = remotePass; 

/// 
/// Return a string array containing the remote directory's file list. 
/// 
/// 
/// 
public string[] getFileList(string mask) 

if(!logined) 

login(); 

Socket cSocket = createDataSocket(); 
sendCommand("NLST " + mask); 
if(!(retValue == 150 || retValue == 125)) 

throw new IOException(reply.Substring(4)); 

mes = ""; 
Thread.Sleep(700); 
while(true) 

if(cSocket.Connected) 

int bytes = cSocket.Receive(buffer, buffer.Length, 0); 
mes += ASCII.GetString(buffer, 0, bytes); 
if(bytes < buffer.Length) 

break; 


else 

log.Info("socket 连接断了!"); 


log.Info(mes); 
char[] seperator = {'\n'}; 
string[] mess = mes.Split(seperator); 
foreach(string fileName in mess) 

log.Info(fileName); 

cSocket.Close(); 
readReply(); 
if(retValue != 226) 

throw new IOException(reply.Substring(4)); 

return mess; 

public string[] getFileList() 

if(!logined) 

login(); 

Socket cSocket = createDataSocket(); 
sendCommand("LIST "); 
if(!(retValue == 150 || retValue == 125)) 

throw new IOException(reply.Substring(4)); 

mes = ""; 
while(true) 

int bytes = cSocket.Receive(buffer, buffer.Length, 0); 
mes += ASCII.GetString(buffer, 0, bytes); 
if(bytes < buffer.Length) 

break; 


log.Info(mes); 
char[] seperator = {'\n'}; 
string[] mess = mes.Split(seperator); 
cSocket.Close(); 
readReply(); 
if(retValue != 226) 

throw new IOException(reply.Substring(4)); 

return mess; 

/// 
/// Return the size of a file. 
/// 
/// 
/// 
public long getFileSize(string fileName) 

if(!logined) 

login(); 

sendCommand("SIZE " + fileName); 
long size=0; 
if(retValue == 213) 

size = Int64.Parse(reply.Substring(4)); 

else 

throw new IOException(reply.Substring(4)); 

return size; 

/// 
/// Login to the remote server. 
/// 
public void login() 

clientSocket = new 
Socket(AddressFamily.InterNetwork,SocketType.Stream,ProtocolType.Tcp); 
IPEndPoint ep = new 
IPEndPoint(Dns.Resolve(remoteHost).AddressList[0], remotePort); 
try 

clientSocket.Connect(ep); 

catch(Exception) 

throw new IOException("Couldn't connect to remote server"); 

readReply(); 
if(retValue != 220) 

close(); 
throw new IOException(reply.Substring(4)); 

if(debug) 
Console.WriteLine("USER "+remoteUser); 
sendCommand("USER "+remoteUser); 
if( !(retValue == 331 || retValue == 230) ) 

cleanup(); 
throw new IOException(reply.Substring(4)); 

if( retValue != 230 ) 

if(debug) 
Console.WriteLine("PASS xxx"); 
sendCommand("PASS "+remotePass); 
if( !(retValue == 230 || retValue == 202) ) 

cleanup(); 
throw new IOException(reply.Substring(4)); 


logined = true; 
Console.WriteLine("Connected to "+remoteHost); 
chdir(remotePath); 

/// 
/// If the value of mode is true, set binary mode for downloads. 
/// Else, set Ascii mode. 
/// 
/// 
public void setBinaryMode(Boolean mode) 

if(mode) 

sendCommand("TYPE I"); 

else 

sendCommand("TYPE A"); 

if (retValue != 200) 

throw new IOException(reply.Substring(4)); 


/// 
/// Download a file to the Assembly's local directory, 
/// keeping the same file name. 
/// 
/// 
public void download(string remFileName) 

download(remFileName,"",false); 

/// 
/// Download a remote file to the Assembly's local directory, 
/// keeping the same file name, and set the resume flag. 
/// 
/// 
/// 
public void download(string remFileName,Boolean resume) 

download(remFileName,"",resume); 

/// 
/// Download a remote file to a local file name which can include 
/// a path. The local file name will be created or overwritten, 
/// but the path must exist. 
/// 
/// 
/// 
public void download(string remFileName,string locFileName) 

download(remFileName,locFileName,false); 

/// 
/// Download a remote file to a local file name which can include 
/// a path, and set the resume flag. The local file name will be 
/// created or overwritten, but the path must exist. 
/// 
/// 
/// 
/// 
public void download(string remFileName,string 
locFileName,Boolean resume) 

if(!logined) 

login(); 

setBinaryMode(false); 
Console.WriteLine("Downloading file "+remFileName+" from "+remoteHost + "//"+remotePath); 
if (locFileName.Equals("")) 

locFileName = remFileName; 

if(!File.Exists(locFileName)) 

Stream st = File.Create(locFileName); 
st.Close(); 

FileStream output = new 
FileStream(locFileName,FileMode.Create); 
Socket cSocket = createDataSocket(); 
long offset = 0; 
if(resume) 

offset = output.Length; 
if(offset > 0 ) 

setBinaryMode(false); 
sendCommand("REST "+offset); 
if(retValue != 350) 

//throw new IOException(reply.Substring(4)); 
//Some servers may not support resuming. 
offset = 0; 


if(offset > 0) 

if(debug) 

Console.WriteLine("seeking to " + offset); 

long npos = output.Seek(offset,SeekOrigin.Begin); 
Console.WriteLine("new pos="+npos); 


sendCommand("RETR " + remFileName); 
if(!(retValue == 150 || retValue == 125)) 

throw new IOException(reply.Substring(4)); 

while(true) 

bytes = cSocket.Receive(buffer, buffer.Length, 0); 
output.Write(buffer,0,bytes); 
if(bytes <= 0) 

break; 


output.Close(); 
if (cSocket.Connected) 

cSocket.Close(); 

Console.WriteLine(""); 
readReply(); 
if( !(retValue == 226 || retValue == 250) ) 

throw new IOException(reply.Substring(4)); 


/// 
/// Upload a file. 
/// 
/// 
public void upload(string fileName) 

upload(fileName,false); 

/// 
/// Upload a file and set the resume flag. 
/// 
/// 
/// 
public void upload(string fileName,Boolean resume) 

if(!logined) 

login(); 

Socket cSocket = createDataSocket(); 
long offset=0; 
if(resume) 

try 

setBinaryMode(true); 
offset = getFileSize(fileName); 

catch(Exception) 

offset = 0; 


if(offset > 0 ) 

sendCommand("REST " + offset); 
if(retValue != 350) 

//throw new IOException(reply.Substring(4)); 
//Remote server may not support resuming. 
offset = 0; 


/*==========================*/ 
sendCommand("STOR "+Path.GetFileName(fileName)); 
if( !(retValue == 125 || retValue == 150) ) 

throw new IOException(reply.Substring(4)); 

// open input stream to read source file 
FileStream input = new FileStream(fileName,FileMode.Open); 
if(offset != 0) 

if(debug) 

Console.WriteLine("seeking to " + offset); 

input.Seek(offset,SeekOrigin.Begin); 

Console.WriteLine("Uploading file "+fileName+" to "+remotePath); 
while ((bytes = input.Read(buffer,0,buffer.Length)) > 0) 

cSocket.Send(buffer, bytes, 0); 

input.Close(); 
Console.WriteLine(""); 
if (cSocket.Connected) 

cSocket.Close(); 

readReply(); 
if( !(retValue == 226 || retValue == 250) ) 

throw new IOException(reply.Substring(4)); 


/// 
/// Delete a file from the remote FTP server. 
/// 
/// 
public void deleteRemoteFile(string fileName) 

if(!logined) 

login(); 

sendCommand("DELE "+fileName); 
if(retValue != 250) 

throw new IOException(reply.Substring(4)); 


/// 
/// Rename a file on the remote FTP server. 
/// 
/// 
/// 
public void renameRemoteFile(string oldFileName,string 
newFileName) 

if(!logined) 

login(); 

sendCommand("RNFR "+oldFileName); 
if(retValue != 350) 

throw new IOException(reply.Substring(4)); 

// known problem 
// rnto will not take care of existing file. 
// i.e. It will overwrite if newFileName exist 
sendCommand("RNTO "+newFileName); 
if(retValue != 250) 

throw new IOException(reply.Substring(4)); 


/// 
/// Create a directory on the remote FTP server. 
/// 
/// 
public void mkdir(string dirName) 

if(!logined) 

login(); 

sendCommand("MKD "+dirName); 
if(retValue != 250) 

throw new IOException(reply.Substring(4)); 


/// 
/// Delete a directory on the remote FTP server. 
/// 
/// 
public void rmdir(string dirName) 

if(!logined) 

login(); 

sendCommand("RMD "+dirName); 
if(retValue != 250) 

throw new IOException(reply.Substring(4)); 


/// 
/// Change the current working directory on the remote FTP server. 
/// 
/// 
public void chdir(string dirName) 

if(dirName.Equals(".")) 

return; 

if(!logined) 

login(); 

sendCommand("CWD "+dirName); 
if(retValue != 250) 

throw new IOException(reply.Substring(4)); 

this.remotePath = dirName; 
Console.WriteLine("Current directory is "+remotePath); 

/// 
/// Close the FTP connection. 
/// 
public void close() 

if( clientSocket != null ) 

sendCommand("QUIT"); 

cleanup(); 
Console.WriteLine("Closing..."); 

/// 
/// Set debug mode. 
/// 
/// 
public void setDebug(Boolean debug) 

this.debug = debug; 

private void readReply() 

mes = ""; 
reply = readLine(); 
retValue = Int32.Parse(reply.Substring(0,3)); 

private void cleanup() 

if(clientSocket!=null) 

clientSocket.Close(); 
clientSocket = null; 

logined = false; 

private string readLine() 

while(true) 

bytes = clientSocket.Receive(buffer, buffer.Length, 0); 
mes += ASCII.GetString(buffer, 0, bytes); 
if(bytes < buffer.Length) 

break; 


char[] seperator = {'\n'}; 
string[] mess = mes.Split(seperator); 
if(mes.Length > 2) 

mes = mess[mess.Length-2]; 

else 

mes = mess[0]; 

if(!mes.Substring(3,1).Equals(" ")) 

return readLine(); 

if(debug) 

for(int k=0;k < mess.Length-1;k++) 

Console.WriteLine(mess[k]); 


return mes; 

private void sendCommand(String command) 

Byte[] cmdBytes = 
Encoding.ASCII.GetBytes((command+"\r\n").ToCharArray()); 
clientSocket.Send(cmdBytes, cmdBytes.Length, 0); 
readReply(); 

private Socket createDataSocket() 

sendCommand("PASV"); 
if(retValue != 227) 

throw new IOException(reply.Substring(4)); 

int index1 = reply.IndexOf('('); 
int index2 = reply.IndexOf(')'); 
string ipData = 
reply.Substring(index1+1,index2-index1-1); 
int[] parts = new int[6]; 
int len = ipData.Length; 
int partCount = 0; 
string buf=""; 
for (int i = 0; i < len && partCount <= 6; i++) 

char ch = Char.Parse(ipData.Substring(i,1)); 
if (Char.IsDigit(ch)) 
buf+=ch; 
else if (ch != ',') 

throw new IOException("Malformed PASV reply: " + 
reply); 

if (ch == ',' || i+1 == len) 

try 

parts[partCount++] = Int32.Parse(buf); 
buf=""; 

catch (Exception) 

throw new IOException("Malformed PASV reply: " + 
reply); 



string ipAddress = parts[0] + "."+ parts[1]+ "." + 
parts[2] + "." + parts[3]; 
int port = (parts[4] << 8) + parts[5]; 
Socket s = new 
Socket(AddressFamily.InterNetwork,SocketType.Stream,ProtocolType.Tcp); 
s.SetSocketOption (SocketOptionLevel.Socket, SocketOptionName.SendTimeout, 5000); 
IPEndPoint ep = new 
IPEndPoint(Dns.Resolve(ipAddress).AddressList[0], port); 
try 

s.Connect(ep); 

catch(Exception) 

    throw new IOException("Can't connect to remote server"); 

return s; 


时间: 2024-09-19 02:22:49

C#版ftp方法实现类的代码_C#教程的相关文章

C#版ftp方法实现类库代码

最近要做个MP3搜索,并自动ftp上传的程序,找来找去发现了这个ftp方法的类库不错,发上来给大家共享共享./* FTPFactory.cs Better view with tab space=4 Written by Jaimon Mathew (jaimonmathew@rediffmail.com) Rolander,Dan (Dan.Rolander@marriott.com) has modified the download method to cope with file nam

C# MVC 微信支付教程系列之公众号支付代码_C#教程

今天,我们接着讲微信支付的系列教程,前面,我们讲了这个微信红包和扫码支付.现在,我们讲讲这个公众号支付.公众号支付的应用环境常见的用户通过公众号,然后再通过公众号里面的菜单链接,进入公众号的商城,然后在里面完成购买和支付功能,我们可以看看官方对这个公众号支付的场景的解释,链接:https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=7_1,通过这个官方的解释,那我们大概清楚这个公众号的用途了,下面,我就说说,做这个公众号支付的准备工作有哪

C# 邮件发送和接收实现代码_C#教程

邮件发送 方法一:使用System.Web.Mail命名空间(此方法我测试没有成功过)  复制代码 代码如下: #region 发送邮件:此方法失败 protected void SendFailed() { System.Web.Mail.MailMessage mail = new System.Web.Mail.MailMessage(); mail.From = "test@ gmail.com"; mail.To = " test@ gmail.com "

C#实现图片分割方法与代码_C#教程

1. 概述 有时候我们需要在web页面上显示一张图,比如说一张地图,而这张地图会比较大.这时候如果我们把一张大图分隔成一组小图,那么客户端的显示速度会明显地感觉块.希望阅读本文对你有所帮助. 2. 实现思路 .NET Framework GDI+ 为我们提供了一组丰富地类来编辑图形图像.有关.NET Framework GDI+的详细资料请查阅msdn相关文档.这里只简要叙述本程序要用的的几个类. System.Drawing.Image.LoadFile 方法可以从指定的文件创建 Image 

C# 无需COM组件创建快捷方式的实现代码_C#教程

看了一下手中的一些小工具, 很多都是单文件但可以创建快捷方式, 于是翻遍 Google, 最后终于在俄罗斯论坛 RSDN 找到了一个很强大的类. 类文件下载: http://asen.googlecode.com/files/Shortcut.cs (无注释精简版)RSDN 原帖: http://www.rsdn.ru/forum/src/3098615.flat.aspx (带英文注释) 使用方法很简单, 把这个文件添加到你的项目中, 然后用法跟 COM 组件那个类似, 但稍有不同: 复制代码

C#实现动态生成静态页面的类详解_C#教程

本文实例讲述了C#实现动态生成静态页面的类.分享给大家供大家参考,具体如下: 动态生成静态页面有许多好处,比如生成html网页有利于被搜索引擎收录.同时,由于减少了数据访问,减轻对数据库访问的压力,提高了网页打开速度. 基本思路: 使用一个字符串作为页面模板,再页面中包含用若干标志(用 {标志名} 表示),生成页面时,将标志替换为对应的值. 实现方法: 在初始化TextTemplate实例时读入模板,以标志为分割点将模板分割成几部分,生成页面时只需简单的将模板内容和标志的值连接起来.例如: 假如

C# 中文简体转繁体实现代码_C#教程

方法一: 复制代码 代码如下: /// <summary> /// 中文字符工具类 /// </summary> private const int LOCALE_SYSTEM_DEFAULT = 0x0800; private const int LCMAP_SIMPLIFIED_CHINESE = 0x02000000; private const int LCMAP_TRADITIONAL_CHINESE = 0x04000000;  [DllImport("ker

c# 调用.bat文件的实现代码_C#教程

c# 调用.bat文件 使用命名空间:using System.Diagnostics; System.Diagnostics.Process.Start(Server.MapPath("ah.bat")); ===================================================================== 扩展名是bat(在nt/2000/xp/2003下也可以是cmd)的文件就是批处理文件 首先,批处理文件是一个文本文件,这个文件的每一行都是

用C#生成不重复的随机数的代码_C#教程

对于随机数,大家都知道,计算机不 可能产生完全随机的数字,所谓的随机数发生器都是通过一定的算法对事先选定的随机种子做复杂的运算,用产生的结果来近似的模拟完全随机数,这种随机数被称 作伪随机数.伪随机数是以相同的概率从一组有限的数字中选取的.所选数字并不具有完全的随机性,但是从实用的角度而言,其随机程度已足够了.伪随机数的选 择是从随机种子开始的,所以为了保证每次得到的伪随机数都足够地"随机",随机种子的选择就显得非常重要.如果随机种子一样,那么同一个随机数发生器产生 的随机数也会一样.