




已阅读5页,还剩15页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
基于TCP协议的网络通信系统的设计与实现摘要:网络通信,由于其具有实时性、跨平台性、成本低、效率高等优点而受到广泛的使用。设计并实现一个能够处理多用户进行实时、安全的即时通信系统具有较强的现实意义。即时通信的底层通信是通过SOCKET套接字接口实现的。当前的主流UNIX系统和微软的WINDOWS系统都在内核提供了对SOCKET字接口的支持。使用这个统一的接口,可以编写一个可移植的TCP/IP通信程序。使信息能够在INTERNET上可靠的传输。 本文设计并实现了基于局域网内的简单即时通信系统,系统采用C/S模式,底层通信通过SOCKET套接字接口实现,服务器负责客户端的登录验证,好友信息的保存和心跳报文的发送。客户端采用P2P方式实现消息传递,并能实现文件的传输。本文首先讨论了同步套接字,异步套接字,多线程并发执行任务等;然后阐述了客户端、服务器如何使用XML序列化的消息进行通信。关键词:即时通信;文件传输;套接字;TCP协议Abstract:Instantmessageshaveseveraladvantagessuchasreal-time,cross-platform,cheapandefficient.TodesignaMulti-userIM(instantmessage)architectureisveryimportantinboththeoryandrealism.InstantmessagebasedonTCP/IPprotocolthatisrealizedbysocketinterface.AlmostallUNIXoperationsystemsandMicrosoftswindowsoperationsystemsprovidesupportofsocketinthekernel.Usingtheuniforminterface,wecandevelopaportableprogramofTCP/IP,whichhelpustransferinformationinInternetsafelyandcredibly.Thesystemusestheclient/server(C/S)mode.Theservertakestheresponsibilityoftheloginmessageofclient,thesavingoffriendmessageandMessageheartbeat.ThetransmissionofthebasicmessagesofthecustomerendwillbedesignedonP2Parchitecture.ThisthesisexplainshowtheclientandservercommunicateviaserializingXMLmessage.Keywords:InstantMessage;FileTransfer;Socket;TCPprotocol 引言1.1课题背景 即时通信是一个终端连往一个即时通信网路的服务。即时通信不同于e-mail在于它的交谈是实时的。大部分的即时通信服务提供了presenceawareness的特性显示联络人名单,联络人是否在在线与能否与联络人交谈。 最早的即时通信软件是ICQ,ICQ是英文中Iseekyou的谐音,意思是我找你。四名以色列青年于1996年7月成立Mirabilis公司,并在11月份发布了最初的ICQ版本,在六个月内有85万用户注册使用。 在因特网上受欢迎的即时通信服务包含了MSNMessenger、AOLInstantMessenger、Yahoo!Messenger、NETMessengerService、Jabber、ICQ与QQ。这些服务有赖于许多想法更久的(与普遍)的在线聊天媒介,如InternetRelayChat一样知名。 1970年代早期,一种更早的即时通信形式是柏拉图系统(PLATOsystem)。之后在1980年代,UNIX/Linux的交谈实时信息被广泛的使用于工程师与学术界,1990年代即时通信更跨越了因特网交流。1996年11月,ICQ是首个广泛被非UNIX/Linux使用者用于因特网的即时通信软件。在ICQ的介绍之后,同时在许多地方有一定数量的即时通信方式发展,且各式的即时通信程序有独立的协议,无法彼此互通。这引导使用者同时执行两个以上的即时通信软件,或者他们可以使用支持多协议的终端软件,如Gaim、Trillian或Jabber。1.2国内外研究现状1.2.1国外研究现状当今,国际上对网络通信系统研究的较好的公司有,思科,Sun,Ms等公司,思科主要研究的是底层的传输;MS,Sun公司研究的是应用层。其中ms公司凭借其在操作系统的垄断地位,为了在网络的发展中取得先机,采用了各种各样的手段。但是,其捆绑的msn,无论从功能上,还是技术上来说,都不算是非常先进的。当然,ie,同样也不是很受人青睐,这让人想起了,当年的网景公司,网景只是生不逢时。MS不择手段的想打跨网景,可见其对网络的重视。如今,Sun公司在网络应用上捷足先登,凭借着Java,Sun在网络的应用上领先于MS。微软,想用同样的办法搞跨对手,因此它拿出了Visualc#,来对抗Java。这些都是在应用层面的开发工具。应用层上的产品就更显种类繁多。ICQ几乎是国际上通用的即时通信工具,由于在我国它的应用不是很广,所以,其原理也很少被介绍。msn,是MS的产品,同样在国内没什么市场,所以,对其原理,也很少被讨论过。至于ie,是在Visualc+下开发的产品,虽然有严重的安全隐患,不过,至少能在某种程度上代表当今国际研究的水平。此外,国际上最近出先了新的浏览器Firefox,其性能据说是远高于ie,也许在网络的天下,Ms又有了更强劲的对手。1.2.2国内研究现状国内在应用层上的网络应用软件目前发展异常的火爆,因为我国有着网络应用的最大的市场,现在国内网络的基础性建设发展迅速,应用软件也层出不穷,其中,在游戏的领域中,网络通信的工作做的不错,如联众游戏平台,还有其他的一些平台,这些平台基本上都是基于VC+的,用的都是Socket通信,但是为了效率,这些平台没有用MFC提供的CSocket类,而是直接用Socket进行通信。所以效率上不错。此外,tencent的即时通信,也是做的很好的,从某中程度上来说,代表了国内最高的水平。1.3本课题的研究方法 本系统采用C/S(Client/Server)结构进行设计,使用SQLServer2000构建数据库,并在.NET环境下使用VisualC#.net语言和SOCKET套接字开发一个基于TCP协议的简单即时通信软件,实现简单的即时聊天,文件传输等功能。2相关技术介绍2.1.NET开发平台及C.NET开发语言 NET框架是Microsoft公司推出的一种全新的开发平台,提供了统一的、面向对象并且可以扩展的编程类库和完善的集成开发环境,大大简化了应用程序的开发过程,并且具有良好的移植性和安全性。 微软为了推行.NET战略,特别为.NET平台设计了一种语言C#。C#是由C和C+派生而来的一种“简单、流行、面向对象、类型安全”的程序设计语言,其综合了Visualbasic的高效率和C+的强大功能,然而更多的人感觉C#更类似JAVA。2.2TCP协议2.2.1TCP/IP网络协议 协议是对等的网络实体之间通信的规则,可以简单地理解为网络上各计算机彼此交流的一种“语言”。网络通信协议设计的基本原则是层次化,层和协议的集合被称为网络体系结构。相邻层之间的接口定义了下层向上层提供的基本操作和服务,下层向上层提供的服务分两种形式:面向连接的服务和无连接的服务。 计算机网络中已经形成的网络体系结构主要有两个:OSI参考模型和TCP/IP参考模型。TCP/IP参考模型是因特网(Internet)的基础。和OSI的7层协议相比,TCP/IP协议只有4个层次。通常说的TCP/IP是一组协议的总称,TCP/IP实际上是一个协议族,包括100多个相互关联的协议,其中IP(InternetProtocol,网际协议)是网络层最主要的协议;TCP(TransmissionControlProtocol,传输控制协议)和UDP(UserDatagramProtocol,用户数据报协议是传输层中最主要的协议),一般认为IP、TCP、UDP是最根本的三种协议,是其他协议的基础。2.2.2TCP传输控制协议:面向连接的通信可以使用可靠通信,在这时候,第四层协议发送数据接收方的确认,如果未收到数据或者数据被损坏,则请求重新传输。TCP协议就使用这种可靠通信。使用TCP协议的应用层协议包括HTTP、FTP、SMTP和Telnet等。 现在可以发送和接收消息了。接收消息后,总是返回ACK消息。如果在收到ACK之前发送方已经超时,则消息将被放到重发队列中以再次发送。 由于它的握手机制,所以TCP协议比较复杂并且费时,但此协议在处理数据时对数据包的传送有保障,从而使得在应用程序协议中不需要再包括该功能。2.3套接字 套接字这个术语并没有定义某个协议:它具有两层含义,但两者都与一个协议相关。第一个含义是套接字编程API,它最初由伯克利大学为BSDUNIX而创建。BSD套接字在经过修改后被用作Windows环境的编程接口(并且被命名为WinSock)。WinSockAPI被包装在System.Net.sockets命名空间的.NET类中。WindowsSockets是一个独立于协议的编程接口,用于编写网络应用程序。2.4流2.4.1流的基本概念流的概念已经存在很长时间了。流是一个用于传输数据的对象。数据的传输有两个方向:1)如果数据从外部源传输到程序中,这就是读取流。 2)如果数据从程序传输到外部源,这就是写入流。外部源常常是一个文件,但也不完全都是文件,它还可以是: 1)网络,使用一定的网络协议与网络上其它计算机或终端交换数据。 2)一个指定的管道。 3)一块内存区域。2.5同步、异步、阻塞和非阻塞 同步(synchronous):所谓同步方式,就是发送方发送数据包以后,不等接受方响应,就接着发送下一个数据包。 异步(asynchronous):异步方式就是当发送方发送一个数据包以后,一直等到接受方响应后,才接着发送下一个数据包。 阻塞(Block):指执行此套接字的网络调用时,直到调用成功才返回,否则此套节字就一直阻塞在网络调用上,比如调用StreamReader类的Readlin()方法读取网络缓冲区中的数据,如果调用的时候没有数据到达,那么此Readlin()方法将一直挂在调用上,直到读到一些数据,此函数调用才返回。 非阻塞(Unblock):指在执行此套接字的网络调用时,不管是否执行成功,都立即返回。同样调用StreamReader类的Readlin()方法读取网络缓冲区中数据,不管是否读到数据都立即返回,而不会一直挂在此函数调用上。 在Windows网络通信软件开发中,最为常用的方法就是异步非阻塞套接字。平常所说的C/S(客户端/服务器)结构的软件采用的方式就是异步非阻塞模式的。 其实在用C进行网络编程中,我们并不需要了解什么同步、异步、阻塞和非阻塞的原理和工作机制,因为在.NetFrameWrokSDK中已经已经把这些机制给封装好了。3.系统总体设计3.1需求分析 软件针对局域网内部用户,实现用户间的即时通信。需要分别实现服务器端和客户端的软件设计。 服务器端负责监听用户连接请求,负责连接数据库存储用户信息,负责发送给用户好友信息,负责发送心跳报文检查用户在线状态并即时让用户更新好友在新信息。 客户端发起主动连接,向服务器请求登录或者注册。客户端可以修改昵称,可以加已知用户为好友(类似于MSN的好友添加功能)。客户端之间可以发起P2P模式的聊天,可以传送文件。3.2系统基本架构 基于C/S架构的即时通信软件便于对用户信息进行统一管理和保存,面向特定的用户,对信息的安全控制能力很强。为了减轻服务器负担,客户端之间的信息传递是采用P2P模式的,服务器只负责用户的注册,登录和用户在线状态的检验。基本结构如图: 3.3功能模块设计CLIENT:1.注册:(1)可以完成客户端注册,客户端可以通过填写信息进行注册,信息被发送到服务器端。2.登录:(1)客户可以输入账号和密码进行登录,客户端会发送登录信息等待服务器响应,登录成功后会发出登录成功信息并刷新好友列表。3.修改:(1)密码修改:应该有密码修改功能(2)信息修改:可以更改一些注册信息4.通信: (1)即时聊天模块:客户端与客户端之间建立线程进行即时聊天,也包含有简单的对称加解密算法功能。 (2)好友列表:可以对好友列表进行添加删除等动作。 5.文件传输: (1)文件传输:文件传输功能SERVER:1. 注册回应: 对客户端传送的注册信息进行判断。 (1)HASH加密:对用户的账号和密码信息进行HASH加密 (2)重复用户检查:将加密后信息与已存在账号进行比较,检查是否账号已存在,如果存在就返回错误信息(3)注册成功:将可成功注册的用户账号和密码写入数据库内,并向客户端返回成功信息2.修改回应:(1)对密码和信息修改请求进行判断,执行和返回修改成功信息。3.登录回应:(1)对登录的账号和密码进行加密检查后发回正确或错误情况,并记录上线信息。(2)好友列表发送:给成功登录的账号发送好友列表及好友上线信息。(3)上线信息发送:给成功登录的账号的好友发送在线信息(包括IP,端口等等信息)。4.在线情况:(1)对登录,在线,离线的用户情况进行统计,记录和通知(2)心跳测试:每隔一段时间发送报文测试用户是否因意外原因离线(3)情况记录:将用户登录时间,IP,下线时间等信息记录入数据库3.4逻辑图:3.5数据库设计3.5.1实体关系图服务器是作为记录和读取数据库信息的载体,与客户端关系并不复杂,这里需要重点考虑客户端之间的关系。用户与用户之间的关系是较为特殊的递归关系,即描述发生在两个相同实体上的关系。4系统实现4.1使用XML定义的即时通信协议4.1.1信息结构MESSAGE.CS&UMESSAGE.CS这两个C#类定义了包括服务器信息,状态信息,注册信息,登录信息,聊天信息或者请求文件传输信息的函数,服务器和客户端通过将它们实例化和序列化再转换成流在网络上进行传输。UMESSAGE.CS主要代码如下:SerializablepublicclassUMessagepublicUMessage()privatestring_nickname;privatestring_password;privatestring_accounts;privatestring_email;privateint_info;/表示注册或者登录信息,客户端信息0为注册,1为登录;服务器返回信息0为用户已存在,1为注册成功,2为服务器未知错误,3为CLIENT在线检查,10为登录失败,11为登录成功privateFriend_friend;privateint_fn;privatestring_fg;publicstringNicknamegetreturn_nickname; set_nickname=value;publicstringPasswordgetreturn_password; set_password=value;publicstringAccountsgetreturn_accounts; set_accounts=value;publicstringEmailgetreturn_email; set_email=value;publicintInfogetreturn_info;set_info=value;publicFriendFrigetreturn_friend; set_friend=value;publicintFngetreturn_fn; set_fn=value;publicstringFggetreturn_fg; set_fg=value; 由于MESSAGE.CS与UMESSAGE.CS类似,在此不再详述。服务器和客户端都可以通过相同的代码对UMESSAGE赋值,再通过XmlSerializer方法进行将UMESSAGE序列化为XML文档,最后将XML文档转化为网络流进行传输。代码如下:#region将登录信息转为UMessage privatevoidTraslator() _message.Accounts=this.TextBox1.Text; _message.Nickname=;_message.Password=this.TextBox2.Text; _message.Email=; _message.Info=1; _message.Fri=null; #endregion4.1.2数据结构FriendStruct服务器如果保存和传递用户的好友信息是难点之一。数据库的设计和信息的传递辨别都是比较难实现的。在数据库方面,每个用户拥有各自的好友分组信息(UserFav),分组中间使用“,”分隔,在TCP_FriendInfo表中则分别保存了用户ID和好友ID,使用一个INT字段保存分组信息。数据库以用户ID为标准对好友ID和分组信息进行内连接查询,就可以得到基本的好友信息了。代码如下:select*fromTCP_UserInfojoinTCP_FriendInfoonTCP_FriendInfo.UserID=+uid+andTCP_UserInfo.UserID=TCP_FriendInfo.FriendID在好友信息的传输方面,首先定义一个FriendStruct数据结构(当然也可以用枚举完成)如下:usingSystem;usingSystem.Collections.Generic;usingSystem.Text;namespaceTCPpublicclassFriendStruct publicstructFileInfo publicintfilere;/接收和拒绝信息,1为接收,2为拒绝,3为取消 publicstringfilename; publiclongfilelength;publicstructFriendpublicstringaccount; publicstringnickname; publicstringIP;publicstringstatus;publicstringfg;/好友分组在MESSAGE.CS或者UMESSAGE.CS中,我们则定义了FriendStruct的数组。在C#中使用DATAREADER语句可以逐句读取数据库查询的结果,再依次将结果赋值FriendStruct数组元素,就得到了便于发送和读取的存放好友信息的数组。赋值代码如下:while(getf.Read()/getf即是以上的数据库查询的datareader语句 ffi.account=getfUserAccount.ToString(); ffi.IP=getfUserIP.ToString();ffi.nickname=getfUserNickname.ToString(); ffi.status=getfUserOnline.ToString(); ffi.fg=getfFriendGroup.ToString(); i+;getf.Close();4.2数据库连接类实现一个快捷简单的数据库连接的相关代码是非常有必要的。实现的途径也多种多样,鉴于安全性和复杂性的需求不同,实现方法有简有繁。本设计使用了一个简单的类(UserData.CS)实现了简单快捷的数据库连接和读取。主要代码如下:publicstaticSqlConnectionconnStr=newSqlConnection(Server=D96B85DD938A465.;uid=sa;pwd=change;database=TCPDB);publicstaticSqlDataReaderSqlReader(stringsql,SqlConnectionconnstr) SqlDataReadersqldr=null;SqlCommandcmd=newSqlCommand(sql,connstr);if(cmd.Connection.State.ToString()=Closed)cmd.Connection.Open(); trysqldr=cmd.ExecuteReader();catch(Exceptione) catch(Exceptione)if(e!=null)sqldr=null;returnsqldr;/数据库操作连接publicstaticstringSqlCmd(stringsql,SqlConnectionconnstr)stringerrorstr=null;SqlCommandsqlcmd=newSqlCommand(sql,connstr); if(sqlcmd.Connection.State.ToString()=Open)sqlcmd.Connection.Close();sqlcmd.Connection.Open(); try sqlcmd.ExecuteNonQuery(); catch(Exceptione) if(e!=null)errorstr=e.ToString(); sqlcmd.Connection.Close(); returnerrorstr;在UserData.CS的基础上,主程序可以更方便地实现数据库连接操作,对数据库进行读写和更新,在此不再详述。 4.3服务器端服务器端的界面设计是基于便于测试的目的而实现的。如下图: 4.3.1同步套接字网络监听基于同步套接字的网络监听器对服务器来说并不是最好的解决方案,但是仍然可行并且实现简单。主要代码如下:开启监听端口:publicvoidServe()intport=8888;ServerIPEP=newIPEndPoint(IPAddress.Any,port);s=newSocket(ServerIPEP.AddressFamily,SocketType.Stream,ProtocolType.Tcp);s.Bind(EndPoint)ServerIPEP); s.Listen(10);alSock=newArrayList();以下代码读取连入的连接,依次将连接加入可变长数组alsock,并且读取传入的信息,进行反串行化:while(true)tryuc=s.Accept(); alSock.Add(uc);this.tb_states.AppendText(System.Convert.ToString(uc); bytedata=newbyte2048; intrect=uc.Receive(data); bytechat=newbyterect;Buffer.BlockCopy(data,0,chat,0,rect);UMessageumessage=(UMessage)_translator.Deserialize(newMemoryStream(chat);intinfo=umessage.Info; 对反串行化后的信息进行处理,通过info参数辨认客户端行为(注册或者登录),对注册的信息进行数据库查询,注册信息可插入,则将用户信息插入数据库,否则返回客户端“注册出错”的信息: #region处理用户注册信息if(info=0)/分辨出用户发送的是注册信息stringAccounts=umessage.Accounts;SqlDataReaderusdr=FPara.SqlReader(select*fromTCP_UserInfowhereUserAccount=+Accounts+,FPara.connStr); if(usdr!=null) if(usdr.Read() #region此处写入返回注册失败的代码 Socketsc=(Socket)alSockalSock.IndexOf(uc,0); sc.Send(chat); #endregion else #region此处写入插入数据库用户注册信息的代码 Streamms=newMemoryStream();Socketsc=(Socket)alSockalSock.IndexOf(uc,0);if(FPara.SqlCmd(insertintoTCP_UserInfo(UserAccount,UserNickname,UserEmail,JoinDate,UserIP,UserPassword)values(+umessage.Accounts+,+umessage.Nickname+,+umessage.Email+,+System.DateTime.Now.ToString()+,+(IPEndPoint)uc.RemoteEndPoint).Address.ToString()+,+umessage.Password+),FPara.connStr)=null)umessage.Info=1;_translator.Serialize(ms,umessage); byted=newbytems.Length; ms.Seek(0,SeekOrigin.Begin); ms.Read(d,0,d.Length); sc.Send(d);elseumessage.Info=2;_translator.Serialize(ms,umessage); byted=newbytems.Length; ms.Seek(0,SeekOrigin.Begin); ms.Read(d,0,d.Length); sc.Send(d); #endregion usdr.Close(); #endregion 如果发现用户发送的是登录信息,就根据登录信息中的用户名和密码判断是否存在用户,密码是否正确,成功后再查询出用户的好友信息并且赋值给FriendStruct,再将信息返回给客户端:#region处理用户登录信息elseif(info=1)/分辨出用户发送的是登录信息 stringAccounts=umessage.Accounts; stringPassword=umessage.Password; SqlDataReaderusdr=FPara.SqlReader(select*fromTCP_UserInfowhereUserAccount=+Accounts+andUserPassword=+Password+,FPara.connStr);if(usdr!=null) if(usdr.Read() stringuid=usdrUserID.ToString();umessage.Fg=usdrUserFav.ToString(); usdr.Close();SqlDataAdaptersdr=newSqlDataAdapter(select*fromTCP_UserInfojoinTCP_FriendInfoonTCP_FriendInfo.UserID=+uid+andTCP_UserInfo.UserID=TCP_FriendInfo.FriendID,FPara.connStr); DataSetds=newDataSet(); sdr.Fill(ds,find);intxxx=ds.Tablesfind.Rows.Count; FPara.SqlCmd(updateTCP_UserInfosetUserIP=+(IPEndPoint)uc.RemoteEndPoint).Ad
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 有机硅耐热漆项目可行性研究报告
- 基因相关精准治疗生殖内分泌疾病-洞察及研究
- 部队军人忠诚课件
- 河北省保定市易县2024-2025学年八年级下学期期末语文试题(含答案)
- 基于数字孪生技术的剪刀挡板实时应力监测与维护决策模型构建
- 基于区块链技术的投标过程溯源与知识产权保护机制创新实践
- 反射金相显微镜与同步辐射光源联用的高通量材料失效分析瓶颈
- 反光蓝背心在元宇宙虚拟空间中的数字孪生技术映射研究
- 双碳目标下氟利昂替代品与压缩机效率的协同平衡难题
- 卡箍连接节点在极端振动环境下的电磁兼容性隐患研究
- 地下水污染的控制与修复课件
- 设备设施管理培训课件
- 急诊科护士的病人家属安抚与沟通
- 单位就业人员登记表
- 原始社会的解体和阶级社会的演进统编版高中政治必修1
- 万人计划青年人才答辩万人计划青年拔尖人才课件
- 干部人事档案审核情况登记表
- 【课件】什么是美术作品+课件-2023-2024学年高中美术湘美版(2019)美术鉴赏
- 村级民主议事制度
- 离婚协议书下载电子版完整离婚协议书下载
- GB/T 3098.6-2023紧固件机械性能不锈钢螺栓、螺钉和螺柱
评论
0/150
提交评论