- 浏览: 357665 次
- 性别:
- 来自: 广州
文章分类
最新评论
-
tianshawang:
楼主你好偏心啊,把代码给谷歌不给这里
java 实现windows资源管理器 -
tianshawang:
其实我是也想要资源管理器的代码来的。。
java 实现windows资源管理器 -
hcmfys:
lonuery 写道open file 是获取要进行复制的文件 ...
JAVA 复制 带进度条 时间 百分比 -
qq657052171:
怎么没有代码呢?
java 实现windows资源管理器 -
IT女民工:
楼主,求资源管理器代码~~~~
java 实现windows资源管理器
using System; using System.Net; using System.IO; using System.Text; using System.Net.Sockets; namespace FtpLib { public class FTPFactory { 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() { remoteHost = "localhost"; remotePath = "."; remoteUser = "anonymous"; remotePass = "ftpclient@ospreyindia.com"; remotePort = 21; debug = false; logined = false; } public void setRemoteHost(string remoteHost) { this.remoteHost = remoteHost; } public string getRemoteHost() { return remoteHost; } public void setRemotePort(int remotePort) { this.remotePort = remotePort; } public int getRemotePort() { return remotePort; } public void setRemotePath(string remotePath) { this.remotePath = remotePath; } public string getRemotePath() { return remotePath; } public void setRemoteUser(string remoteUser) { this.remoteUser = remoteUser; } public void setRemotePass(string remotePass) { this.remotePass = remotePass; } 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 = ""; while (true) { int bytes = cSocket.Receive(buffer, buffer.Length, 0); mes += ASCII.GetString(buffer, 0, bytes); if (bytes < buffer.Length) { break; } } char[] seperator = { '\n' }; string[] mess = mes.Split(seperator); cSocket.Close(); readReply(); if (retValue != 226) { throw new IOException(reply.Substring(4)); } return mess; } public long getFileSize(string fileName) { if (!logined) { login(); } sendCommand("SIZE " + fileName); long size = 0; if (retValue == 213) { size = reply.Substring(4).ToInt64(); } else { throw new IOException(reply.Substring(4)); } return size; } public void login() { clientSocket = new Socket(AddressFamily.AfINet, SocketType.SockStream, ProtocolType.ProtTCP); IPEndPoint ep = new IPEndPoint(DNS.Resolve(remoteHost), remotePort); int i = clientSocket.Connect(ep); if (i != 0) { 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); } public void setBinaryMode(Boolean mode) { if (mode) { sendCommand("TYPE I"); } else { sendCommand("TYPE A"); } if (retValue != 200) { throw new IOException(reply.Substring(4)); } } public void download(string fileName) { download(fileName, false); } public void download(string fileName, Boolean resume) { if (!logined) { login(); } setBinaryMode(true); long totalSize = 0; try { totalSize = getFileSize(fileName); } catch (Exception) { throw new Exception("File Not Found " + fileName); } Console.WriteLine("Downloading file " + fileName + " from " + remoteHost + "/" + remotePath); if (!File.FileExists(fileName)) { Stream st = File.Create(fileName); st.Close(); } FileStream output = new FileStream(fileName, FileMode.Open); Socket cSocket = createDataSocket(); long offset = 0; if (resume) { offset = output.Length; if (offset > 0) { sendCommand("REST " + offset); if (retValue != 350) { //throw new IOException(reply.Substring(4)); //Server 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 " + fileName); if (!(retValue == 150 || retValue == 125)) { throw new IOException(reply.Substring(4)); } float iCnt = 0; float per = 0, oldPer = 1; while (true) { bytes = cSocket.Receive(buffer, buffer.Length, 0); output.Write(buffer, 0, bytes); // Showing the progress. 1..50 iCnt += bytes; per = (int)((iCnt / totalSize) * 100); if (per != oldPer && per % 2 == 0) { Console.Write("."); oldPer = per; } if (bytes < buffer.Length) { break; } } output.Close(); cSocket.Close(); Console.WriteLine(""); readReply(); if (!(retValue == 226 || retValue == 250)) { throw new IOException(reply.Substring(4)); } } public void upload(string fileName) { upload(fileName, false); } 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 " + 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); } //for progress bar long totalSize = input.Length - offset; float iCnt = 0; int per = 0, oldPer = 1; Console.WriteLine("Uploading file " + fileName + " to " + remotePath); while ((bytes = input.Read(buffer, 0, buffer.Length)) > 0) { cSocket.Send(buffer, bytes, 0); // Showing the progress. 1..50 iCnt += bytes; per = (int)((iCnt / totalSize) * 100); if (per != oldPer && per % 2 == 0) { Console.Write("."); oldPer = per; } } input.Close(); Console.WriteLine(""); cSocket.Close(); readReply(); if (!(retValue == 226 || retValue == 250)) { throw new IOException(reply.Substring(4)); } } public void deleteRemoteFile(string fileName) { if (!logined) { login(); } sendCommand("DELE " + fileName); if (retValue != 250) { throw new IOException(reply.Substring(4)); } } 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)); } } public void mkdir(string dirName) { if (!logined) { login(); } sendCommand("MKD " + dirName); if (retValue != 250) { throw new IOException(reply.Substring(4)); } } public void rmdir(string dirName) { if (!logined) { login(); } sendCommand("RMD " + dirName); if (retValue != 250) { throw new IOException(reply.Substring(4)); } } 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); } public void close() { if (clientSocket != null) { sendCommand("QUIT"); } cleanup(); Console.WriteLine("Closing..."); } public void setDebug(Boolean debug) { this.debug = debug; } private void readReply() { mes = ""; reply = readLine(); retValue = reply.Substring(0, 3).ToInt32(); } 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 = ipData.Substring(i, 1).ToChar(); if (Char.IsDigit(ch)) buf += ch; else if (ch != ',') { throw new IOException("Malformed PASV reply: " + reply); } if (ch == ',' || i + 1 == len) { try { parts[partCount++] = buf.ToInt32(); 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.AfINet, SocketType.SockStream, ProtocolType.ProtTCP); IPEndPoint ep = new IPEndPoint(DNS.Resolve(ipAddress), port); int sucess = s.Connect(ep); if (sucess != 0) { throw new IOException("Can't connect to remote server"); } return s; } } } public class Test { public static void Main() { try { Console.WriteLine("Starting..."); FTPFactory ff = new FTPFactory(); ff.setDebug(true); ff.setRemoteHost("192.168.10.19"); ff.setRemoteUser("jaimon"); ff.setRemotePass("mathew"); ff.login(); string[] fileNames = ff.getFileList("*.*"); for (int i = 0; i < fileNames.Length; i++) { Console.WriteLine(fileNames[i]); } ff.download("Readme.zip", true); ff.close(); } catch (Exception e) { Console.WriteLine("Caught Error :" + e.Message); } } }
发表评论
-
单线程 文件查找
2010-02-06 17:14 859using System; using System.Col ... -
多线程 多线程文件查找
2010-02-06 17:13 1207using System; using System.Col ... -
c# 生成小图
2008-05-22 11:39 969/// <summary> /// ... -
c#.net常用函数和方法集
2008-05-27 11:43 805、DateTime 数字型 System.DateTime ... -
ASP.net防止SQL注入方法
2008-07-11 15:22 9091、sql注入比较难防,需 ... -
c# Dos Tree
2008-09-15 18:31 894用法DOS 命令 发现 Tree 命令很有趣 就用C# 写了 ... -
ASP.Net中自定义Http处理及应用之HttpModule篇 (转载)
2008-09-17 16:14 1010HttpHandler实现了类似于ISAPI Extenti ... -
代码格式化 JAVA c# CodeFormat
2008-11-11 17:50 1093using System; using System.Coll ... -
c++ point
2009-05-06 12:15 1143介绍 曾碰到过让您迷 ... -
c# 屏幕截屏工具
2009-09-03 16:19 2314最近没事,开发了个截屏工具 模仿qq截屏功能!!下载地址 / ... -
C# 版芊芊静听
2009-09-11 15:05 881/Files/hcmfys/csttplayer.rar -
C# BCD编码解码
2010-01-13 15:21 3290(1)BCD码(二到十进制编码) 人们通常习惯使用十进制数,而 ... -
chm
2009-12-24 09:10 1132经常碰到一些 CHM 格 ... -
mapInfo
2009-12-04 17:57 848mapINfo 2005 -
Asp.Net中Excel操作权限的问题
2009-12-03 20:58 1743原创 Asp.Net中Excel操作权限的问题 收藏 提 ... -
How to configure Office applications to run under the interactive user account
2009-12-03 20:48 3773We do not recommend or support ... -
c# 操作Excel 权限问题
2009-12-03 20:46 3919Web.config上添加了“<identity i ... -
C#操作excel sheet
2009-12-01 20:58 3363C#操作excel sheet 这里有个VB.NET利用数 ... -
C# 对Excel表格的操作
2009-12-01 20:52 1618using Excel; using System.Refl ...
相关推荐
在C#编程中,自动生成.cs文件是一种常见的需求,它可以帮助开发者提高效率,减少重复劳动,尤其是在处理大量相似代码或需要遵循特定模板时。本文将深入探讨如何在C#环境中自动生成.cs文件,并涵盖相关技术点。 首先...
在ASP.NET WebForm开发中,`.designer.cs`文件是一个非常关键的部分,它与`.aspx`页面对应,用于存储自动生成的控件声明和事件处理程序。当你删除了`.designer.cs`文件,需要手动恢复这个文件并重新设计及绑定服务端...
在`MsSqlHelper.cs`文件中,这些方法通常会包含以下步骤: - 连接字符串的获取:通过配置文件或者硬编码来获取数据库连接字符串。 - SqlConnection对象的创建:使用连接字符串初始化数据库连接。 - SqlCommand对象的...
BarCodeToHTML.cs CacheHelper.cs Captcha.cs CNDate.cs ConvertJson.cs CsvHelper.cs EcanConvertToCh.cs Encrypt.cs ExcelHelper.cs FileDown.cs FileManager.cs FileUp.cs FTPClient.cs FTPHelper....
SqlHelper.cs 微软官方版本 ===========================================================================
IniConfig.cs(C# INI文件读写,自动生成配置文件,实际内容根据项目自定义)
edu.stanford.cs106_2.0.1.201603271702.jar stanford公开课使用eclipse需要的插件
.NET 中 JavaScript 帮助类
DataHelper.cs 完全 DataHelper.cs 完全 DataHelper.cs 完全 DataHelper.cs 完全 DataHelper.cs 完全 DataHelper.cs 完全
最新的雷赛运动控制卡SDK,LTDMC.cs带中文注释
海康威视下载视频方法需要的CHCNetSDK_X64.cs配置文件,海康威视下载图片方法需要的CHCNetSDK_X64.cs配置文件。
作C#桌面程序时,有时我们会遇到很复杂的功能,如果所有功能的实现都写在一个.cs文件中,会让这个.cs文件显得很臃肿,而且不便于以后管理。本程序提供一种方法,可以将不同功能分写在不同的.cs文件文件中。即能将很...
mssqlhelper.cs和jshelper.cs的jshelper.cs
mssqlhelper.cs和jshelper.cs 的mssqlhelper.cs
C#数据库连接类库DbHelp.cs DbHelp.cs是一个C#数据库连接类库,用于实现数据库的连接、插入、更新和删除操作。该类库提供了多个方法来执行SQL语句,包括插入、更新和删除操作。下面是DbHelp.cs类库的详细知识点: ...
C#通过s7通讯,读写plc内部寄存器数值,可做上位机通讯
Properties.Resources.Designer.cs.dll
《IK Multimedia T-RackS CS Complete v4.10 - 音频处理的恐龙级工具》 IK Multimedia的T-RackS CS Complete v4.10是一款备受推崇的专业级音频处理软件,被誉为“恐龙级”的音频插件。这款强大的工具集涵盖了混音、...
xna VideoPlayer.cs xna VideoPlayer.cs xna VideoPlayer.cs
http://www.cs.waikato.ac.nz/ml/weka/ weka主页