最近一个项目要用到点对点文件传输,俺就到处找资料写程序,最后终于完成了,为了让别人少走些弯路,俺决定将俺程序中最重要的部分贡献出来,希望对大家有所帮助。俺的程序分三部分,包括发送部分、接受部分和一个两者共享的通讯基类,这个基类才是俺心血的结晶:) 一、通讯基类using System;using System.Net.Sockets;using System.Net ;using System.IO ;using System.Windows.Forms;using System.Text; namespace BaseClass{ /// <summary> /// 传送信息的格式为 给定长度的命令部分+给定长度的命令注释部分+可变长度的长度信息+可变长度的信息部分 /// </summary> public class CommunClass { public CommunClass() { // // TODO: 在此处添加构造函数逻辑 // } /// <summary> /// 命令部分的长度 /// </summary> private static readonly int CMDLEN = 50 ; /// <summary> /// 命令注释部分的长度 /// </summary> private static readonly int DESCLEN = 100 ; /// <summary> /// 可变长度的长度信息部分所占的字节数 /// </summary> private static readonly int DYNAMICLENGTHLEN = 10 ; /// <summary> /// 每次处理可变信息部分的长度 /// </summary> private static readonly int DEALLEN = 1024 ; /// <summary> /// /应答的最大长度 /// </summary> private static readonly int RESPONLEN = 20 ; /// <summary> /// 用于填充命令或注释不足长度部分的字符 /// </summary> private static readonly char FILLCHAR = '^' ; /// <summary> /// 成功发送一部分数据后的回调方法(也可以认为是触发的事件,但严格来说还不是) /// </summary> public delegate void OnSend(int iTotal,int iSending) ; /// <summary> /// 根据给定的服务器和端口号建立连接 /// </summary> /// <param name="strHost">服务器名</param> /// <param name="iPort">端口号</param> /// <returns></returns> public static Socket ConnectToServer(string strHost,int iPort) { try { IPAddress ipAddress = Dns.Resolve(strHost).AddressList[0]; IPEndPoint ipPoint = new IPEndPoint(ipAddress,iPort) ; Socket s = new Socket(AddressFamily.InterNetwork,SocketType.Stream,ProtocolType.Tcp) ; s.Connect(ipPoint) ; return s ; } catch (Exception e) { throw (new Exception("建立到服务器的连接出错" + e.Message)) ; } } /// <summary> /// 将文本写到Socket中 /// </summary> /// <param name="s">要发送信息的Socket</param> /// <param name="strInfo">要发送的信息</param> /// <returns>是否成功</returns> public static bool WriteTextToSocket(Socket s,string strInfo) { byte [] buf = Encoding.UTF8.GetBytes(strInfo) ; try { s.Send(buf,0,buf.Length,SocketFlags.None) ; return true ; } catch(Exception err) { MessageBox.Show("发送文本失败!"+err.Message) ; return false ; } } /// <summary> /// 将命令文本写到Socket中 /// </summary> /// <param name="s">要发送命令文本的Socket</param> /// <param name="strInfo">要发送的命令文本</param> /// <returns>是否成功</returns> public static bool WriteCommandToSocket(Socket s,string strCmd) { if (strCmd == "") strCmd = "NOP" ; strCmd = strCmd.PadRight(CMDLEN,FILLCHAR) ; return WriteTextToSocket(s,strCmd) ; } /// <summary> /// 将命令注释写到Socket中 /// </summary> /// <param name="s">要发送命令注释的Socket</param> /// <param name="strInfo">要发送的命令注释</param> /// <returns>是否成功</returns> public static bool WriteCommandDescToSocket(Socket s,string strDesc) { if (strDesc == "") strDesc = "0" ; strDesc = strDesc.PadRight(DESCLEN,FILLCHAR) ; return WriteTextToSocket(s,strDesc) ; } /// <summary> /// 发送可变信息的字节数 /// </summary> /// <param name="s">要发送字节数的Socket</param> /// <param name="iLen">字节数</param> /// <returns>是否成功</returns> public static bool WriteDynamicLenToSocket(Socket s,int iLen) { string strLen = iLen.ToString().PadRight(DYNAMICLENGTHLEN,FILLCHAR) ; return WriteTextToSocket(s,strLen) ; } /// <summary> /// 将缓存的指定部分发送到Socket /// </summary> /// <param name="s">要发送缓存的Socket</param> /// <param name="buf">要发送的缓存</param> /// <param name="iStart">要发送缓存的起始位置</param> /// <param name="iCount">要发送缓存的字节数</param> /// <param name="iBlock">每次发送的字节说</param> /// <param name="SendSuccess">每次发送成功后的回调函数</param> /// <returns>是否发送成功</returns> public static bool WriteBufToSocket(Socket s,byte [] buf,int iStart,int iCount,int iBlock,OnSend SendSuccess) { int iSended = 0 ; int iSending = 0 ; while(iSended<iCount) { if (iSended + iBlock <= iCount) iSending = iBlock ; else iSending = iCount - iSended ; s.Send(buf,iStart+iSended,iSending,SocketFlags.None) ; iSended += iSending ; if (ReadResponsionFromSocket(s)=="OK") if (SendSuccess != null) SendSuccess(iCount,iSended) ; else return false; } return true ; } /// <summary> /// 将长度不固定文本发送到socket /// </summary> /// <param name="s">要发送文本的Socket</param> /// <param name="strText">要发送的文本</param> /// <param name="OnSendText">成功发送一部分文本后的回调函数</param> /// <param name="settextlen">得到文本长度的回调函数</param> /// <returns></returns> public static bool WriteDynamicTextToSocket(Socket s,string strText, OnSend OnSendText) { byte [] buf = Encoding.UTF8.GetBytes(strText) ; int iLen = buf.Length ; try { WriteDynamicLenToSocket(s,iLen) ; return WriteBufToSocket(s,buf,0,iLen,DEALLEN,OnSendText) ; } catch(Exception err) { MessageBox.Show("发送文本失败!"+err.Message) ; return false ; } } /// <summary> /// 将文件写到Socket /// </summary> /// <param name="s">要发送文件的Socket</param> /// <param name="strFile">要发送的文件</param> /// <returns>是否成功</returns> public static bool WriteFileToSocket(Socket s,string strFile, OnSend OnSendFile) { FileStream fs = new FileStream(strFile,FileMode.Open,FileAccess.Read,FileShare.Read) ; int iLen = (int)fs.Length ; WriteDynamicLenToSocket(s,iLen) ; byte [] buf = new byte[iLen] ; try { fs.Read(buf,0,iLen) ; return WriteBufToSocket(s,buf,0,iLen,DEALLEN,OnSendFile) ; } catch(Exception err) { MessageBox.Show("发送文件失败!"+err.Message) ; return false ; } finally { fs.Close() ; } } /// <summary> /// 对方对自己消息的简单回应 /// </summary> /// <param name="s"></param> /// <returns></returns> public static string ReadResponsionFromSocket( Socket s) { byte [] bufCmd = new byte[RESPONLEN] ; int iCount = s.Receive(bufCmd) ; string strRespon = Encoding.UTF8.GetString(bufCmd,0,iCount) ; return strRespon ; } /// <summary> /// 从Socket读取命令 /// </summary> /// <param name="s">要读取命令的Socket</param> /// <returns>读取的命令</returns> public static string ReadCommandFromSocket( Socket s) { byte [] bufCmd = new byte[CMDLEN] ; int iCount = s.Receive(bufCmd,0,CMDLEN,SocketFlags.Partial) ; string strCommand = Encoding.UTF8.GetString(bufCmd,0,CMDLEN) ; return strCommand = strCommand.TrimEnd(FILLCHAR) ; } /// <summary> /// 读取命令注释 /// </summary> /// <param name="s">要读取命令注释的Socket</param> /// <returns>读取的命令注释</returns> public static string ReadCommandDescFromSocket( Socket s) { byte [] bufCmd = new byte[DESCLEN] ; int iCount = s.Receive(bufCmd,0,DESCLEN,SocketFlags.Partial) ; string strCommand = Encoding.UTF8.GetString(bufCmd,0,DESCLEN) ; return strCommand = strCommand.TrimEnd(FILLCHAR) ; } /// <summary> /// 读取可变部分的长度 /// </summary> /// <param name="s">要读取可变部分长度的Socket</param> /// <returns>读取的可变部分的长度</returns> public static int ReadDynamicLenFromSocket( Socket s) { byte [] bufCmd = new byte[DYNAMICLENGTHLEN] ; int iCount = s.Receive(bufCmd,0,DYNAMICLENGTHLEN,SocketFlags.Partial) ; string strCommand = Encoding.UTF8.GetString(bufCmd,0,DYNAMICLENGTHLEN) ; return int.Parse(strCommand.TrimEnd(FILLCHAR)) ; } /// <summary> /// 读取文本形式的可变信息 /// </summary> /// <param name="s">要读取可变信息的Socket</param> /// <returns>读取的可变信息</returns> public static string ReadDynamicTextFromSocket( Socket s) { int iLen = ReadDynamicLenFromSocket(s) ; byte [] buf = new byte[iLen] ; string strInfo = "" ; int iReceiveded = 0 ; int iReceiveing = 0 ; while(iReceiveded<iLen) { if (iReceiveded + DEALLEN <= iLen) iReceiveing = DEALLEN ; else iReceiveing = iLen - iReceiveded ; s.Receive(buf,iReceiveded,iReceiveing,SocketFlags.None) ; CommunClass.WriteTextToSocket(s,"OK") ; iReceiveded+= iReceiveing ; } strInfo = Encoding.UTF8.GetString(buf,0,iLen) ; return strInfo ; } /// <summary> /// 读取文件形式的可变信息 /// </summary> /// <param name="s">要读取可变信息的Socket</param> /// <param name="strFile">读出后的文件保存位置</param> /// <returns>是否读取成功</returns> public static bool ReadDynamicFileFromSocket( Socket s,string strFile) { int iLen = ReadDynamicLenFromSocket(s) ; byte [] buf = new byte[iLen] ; FileStream fs = new FileStream(strFile,FileMode.Create,FileAccess.Write) ; try { int iReceiveded = 0 ; int iReceiveing = 0 ; while(iReceiveded<iLen) { if (iReceiveded + DEALLEN <= iLen) iReceiveing = DEALLEN ; else iReceiveing = iLen - iReceiveded ; , ; s.Receive(buf,iReceiveded,iReceiveing,SocketFlags.None) ; CommunClass.WriteTextToSocket(s,"OK") ; iReceiveded+= iReceiveing ; } fs.Write(buf,0,iLen) ; return true ; } catch(Exception err) { MessageBox.Show("接收文件失败"+err.Message) ; return false ; } finally { fs.Close() ; } } }//end class}//end namespace上面是俺的通讯基础类,有了这个类,再进行发送接受还不是小菜一碟吗?)< DIV ICOUNT)< ILEN)<>posted on 2004年08月06日 3:00 PM
使用C#进行点对点通讯和文件传输(通讯基类部分) (From 阿赖的个性空间)
时间: 2024-08-31 07:57:21
使用C#进行点对点通讯和文件传输(通讯基类部分) (From 阿赖的个性空间)的相关文章
使用C#进行点对点通讯和文件传输(发送接收部分) (From 阿赖的个性空间)
上面介绍了通讯的基类,下面就是使用那个类进行发送和接收的部分:二.发送部分:发送咱们使用了多线程,可以同时进行多个任务,比如发送文件.发送文本等,互不影响:发送文本方法:private void StartSendText(string strHost,int iPort,string strInfo) { SendText stText = new SendText(strHost,iPort,strInfo,new CommunClass.OnSend(OnSe
即时通讯-音频文件传输 dialog engine
问题描述 音频文件传输 dialog engine 想做一个实时语音通讯系统,听人介绍了一个dialog engine的东西,网上却没查到相关 信息,希望大牛指点. 或者有相关经验者分享一下实时语音通讯技术.
点对点-FTP文件传输如何用C语言实现
问题描述 FTP文件传输如何用C语言实现 FTP文件传输如何用C语言实现 用于文件传输 系统文件更新 急用 点对点 解决方案 1.了解下ftp的原理 基本的指令操作 2.熟悉socket,ftp会有2个socket传输,一个用于指令传输,一个用于数据传输 3.实现基本的ftp传输后,可以考虑文件更新机制,基本的文件读写 解决方案二: 用socket就可以实现呀,ftp只是文件传输协议.你上网搜一下,应该有很多源代码.不要使用封装后的socket,直接使用原始的socket就可以了. 解决方案三:
用Socket实现点对点的文件传输
System.Sockes命名空间了实现 Berkeley 套接字接口.通过这个类,我们可以实现网络计算机之间的消息传输和发送.而在我下面要讨论的这个议题里,我们将讨论的是用套节子实现文件的传输.这种方法有别于FTP协议实现的的文件传输方法,利用ftp的方法需要一个专门的服务器和客户端,无疑于我们要实现的点对点的文件传输太为复杂了一些.在这里,我们实现一个轻量级的方法来实现点对点的文件传输,这样就达到了intenet上任何两个计算机的文件共享.在两台计算机传输文件之前,必需得先有一台计算机建立套
你不知道的5种另类文件传输服务
提起文件传输,你肯定会想起通过U盘或是各种IM.蓝牙等传输分享.移动互联时代,抛弃这些老套繁琐的传输方法吧!你可以让iPhone"扔"文 件,也可以让iPhone通过唱唱歌就能实现文件传输分享--今天小编就给您推荐几款你不知道的另类个性传输服务,集体上眼这里:用Hoccer把你手机中的文件"扔"给我Hoccer这款基于地理位置的手机数据共享应用,通过"投掷"或"拖拽"的方式毫不费力的帮我们实现了一对一或一对多手机间图片.文档.
标准C实现基于TCP/IP协议的文件传输
TCP/IP编程实现远程文件传输在LUNIX中一般都采用套接字(socket)系统调用. 采用客户/服务器模式,其程序编写步骤如下: 1.Socket系统调用 为了进行网络I/O,服务器和客户机两端的UNIX进程要做的第一件事是调用socket()系统调用,建立软插座,指明合适的通讯协议.格式为: 1 2 3 #include >sys/types.h> #include >sys/socket.h> int socket(int family,int type,int
用C#实现HTTP协议下的多线程文件传输
多线程 很多人都有过使用网络蚂蚁或网络快车软件下载互联网文件的经历,这些软件的使用可以大大加速互联网上文件的传输速度,减少文件传输的时间.这些软件为什么有如此大的魔力呢?其主要原因是这些软件都采用了多线程下载和断点续传技术.如果我们自己来编写一个类似这样的程序,也能够快速的在互联网上下载文件,那一定是非常愉快的事情.下面我就讲一讲如何利用C#语言编写一个支持多线程下载文件的程序,你会看到利用C#语言编写网络应程序是多么的容易,从中也能体会到C#语言中强大的网络功能. 首先介绍一下HTTP协议,H
C#文件传输
System.Sockes命名空间了实现 Berkeley 套接字接口.通过这个类,我们可以实现网络计算机之间的消息传输和发送.而在我下面要讨论的这个议题里,我们将讨论的是用套节子实现文件的传输.这种方法有别于FTP协议实现的的文件传输方法,利用ftp的方法需要一个专门的服务器和客户端,无疑于我们要实现的点对点的文件传输太为复杂了一些.在这里,我们实现一个轻量级的方法来实现点对点的文件传输,这样就达到了intenet上任何两个计算机的文件共享. 在两台计算机传输文件之前,必需得先有一台计算机建立
C#实现HTTP协议下的多线程文件传输
多线程 很多人都有过使用网络蚂蚁或网络快车软件下载互联网文件的经历,这些软件的使用可以大大加速互联网上文件的传输速度,减少文件传输的时间.这些软件为什么有如此大的魔力呢?其主要原因是这些软件都采用了多线程下载和断点续传技术.如果我们自己来编写一个类似这样的程序,也能够快速的在互联网上下载文件,那一定是非常愉快的事情.下面我就讲一讲如何利用C#语言编写一个支持多线程下载文件的程序,你会看到利用C#语言编写网络应程序是多么的容易,从中也能体会到C#语言中强大的网络功能. 首先介绍一下HTTP协议,H