public class FtpUpload
{
public static string serverIP = "127.0.0.1:2121";
public static string userName = "xxx";
public static string password = "xxx";
public static int UploadFtp(string filename)
{
FtpWebRequest reqFTP = null;
string url;
try
{
FileInfo fileInf = new FileInfo(filename);
url = "ftp://" + serverIP + "/" + Path.GetFileName(filename);
reqFTP = (FtpWebRequest)FtpWebRequest.Create(new Uri(url));
reqFTP.Credentials = new NetworkCredential(userName, password);
reqFTP.KeepAlive = false;
reqFTP.Method = WebRequestMethods.Ftp.UploadFile;
reqFTP.UseBinary = true;
reqFTP.ContentLength = fileInf.Length;
int buffLength = 2048;
byte[] buff = new byte[buffLength];
int contentLen;
FileStream fs = fileInf.Open(FileMode.Open, FileAccess.Read, FileShare.ReadWrite);
Stream strm = reqFTP.GetRequestStream();
contentLen = fs.Read(buff, 0, buffLength);
while (contentLen != 0)
{
strm.Write(buff, 0, contentLen);
contentLen = fs.Read(buff, 0, buffLength);
}
strm.Close();
fs.Close();
return 0;
}
catch (Exception ex)
{
if (reqFTP != null)
{
reqFTP.Abort();
}
SystemLog.logger(ex.Message);
return -2;
}
}
public static int DownloadFtp(string filename)
{
FtpWebRequest reqFTP;
string url;
try
{
url = "ftp://" + serverIP + "/" + Path.GetFileName(filename);
FileStream outputStream = new FileStream(filename, FileMode.Create);
reqFTP = (FtpWebRequest)FtpWebRequest.Create(new Uri(url));
reqFTP.Method = WebRequestMethods.Ftp.DownloadFile;
reqFTP.UseBinary = true;
reqFTP.KeepAlive = false;
reqFTP.Credentials = new NetworkCredential(userName, password);
FtpWebResponse response = (FtpWebResponse)reqFTP.GetResponse();
Stream ftpStream = response.GetResponseStream();
long cl = response.ContentLength;
int bufferSize = 2048;
int readCount;
byte[] buffer = new byte[bufferSize];
readCount = ftpStream.Read(buffer, 0, bufferSize);
while (readCount > 0)
{
outputStream.Write(buffer, 0, readCount);
readCount = ftpStream.Read(buffer, 0, bufferSize);
}
ftpStream.Close();
outputStream.Close();
response.Close();
return 0;
}
catch (Exception ex)
{
SystemLog.logger(ex.Message);
return -2;
}
}
public class SystemLog
{
public static bool logger(string message)
{
try
{
DateTime timeNow = DateTime.Now;
string filename = "";
string logSwitch = "";
if (logSwitch == "1")
{
Encoding encoding = Encoding.GetEncoding("gb2312");
byte[] info = encoding.GetBytes("[ " + timeNow.ToString("yyyy-MM-dd HH:mm:ss") + " ] " + message + "\n"); //转换编码成字节串
if (!filename.EndsWith(Path.DirectorySeparatorChar.ToString()))
{
filename = filename + Path.DirectorySeparatorChar.ToString();
}
using (FileStream fs = System.IO.File.Open(filename + timeNow.ToString("yyyy_MM_dd") + ".txt", FileMode.Append, FileAccess.Write, FileShare.ReadWrite))
{
fs.Write(info, 0, info.Length);
//以ASCII方式编写
using (StreamWriter w = new StreamWriter(fs, Encoding.ASCII))
{
w.Flush();
w.Close();
}
fs.Close();
}
}
return true;
}
catch (Exception e)
{
return false;
}
}
}
}