1、 目 录 基于 .NET 局域网聊天工具设计 . 2 1.局域网聊天工具概述 . 2 1.1 聊天工具开发的目标 意义 . 2 1.2 C/S 结构与 WINDOWS SOCKETS 网络编程 . 2 2.需求分析 . 3 2.1 用户需求 . 3 2.2 系统功能需求 . 3 2.3 性能要求 . 3 2.4 测试环境规定 . 4 2.5 可行性研究 . 4 2.5.1 成本可行性分析 . 4 2.5.2 技术可行性分析 . 4 3 系统设计 . 4 3.1 系统功能结构 . 4 3.2 系统功能需求 . 5 3.3 性能要求 . 5 4.系统模块详细设计 . 6 4.1 文本聊天模块实现
2、. 6 4.1.1 文本聊天流程 . 6 4.1.2 界面设计 . 7 4.2 文件传输模块实现 . 8 4.2.1 文件传输接收端工作 流程 . 8 4.2.3 文件传输发送界面设计 . 9 5.系统测试 . 9 5.1 系统测试概述 . 9 5.2 白盒测试 . 9 5.3 黑盒测试 . 10 6. 主要问题及解决 . 10 6.1 多线程问题 . 10 6.2 套接字异常 . 10 6.3 网络流异常 . 10 参考文献 . 11 Based on .Net LAN Chat Tool Design . 11 致 谢 . 12 基于 .NET局域网聊天工具 设计 摘要 : 随着计算机网络
3、技术的发展,各种各样基于网络的应用也随之诞生 ,比如基于互联网的信息发布,通信,数据共享等等。局域网的发展也同样迅速。很多政府机构,企业,学校,都是先以 一个统一的局域网联结在一起,再分别接入 INTERNET。因此基于局域网的即时通信工具,就这样应运而生了。本文提出了一个局域网聊天工具的设计,并在 WINDOWS平台上加以了实现。本设计将文本聊天和文件传输等功能综合在一个客户端程序之内,使用C#语言进行网络编程,并进行了人性化的界面设计,使用起来简单方便,并且功能十分合理,又易于扩展以及个性化定制。 关键词 : 局域网; C/S 体系结构 ; 文本聊天;文件传输 引言 1.局域网聊天工具概述
4、 1.1 聊天工具开发的目标 意义 本设计的主要工作是设计一个基于 WINDOWS 平 台的局域网即时聊天工具,具体是采用CS模式实现用户之间的通信,然后阐述本软件的功能、特点及使用方法,并详细阐述开发本软件所用的相关技术,具体分析本软件的各个模块的功能及实现方法,说明本软件的设计思想及方法。 局域网聊天工具,是在局域网内部使用的,用户之间用来交流的一个工具,一般都具有文本聊天和文件传输功能。局域网聊天软件因其使用简单,系统资源消耗少等优点,成为各企事业单位等的局域网内广泛应用的软件之一。 1.2 C/S 结构与 WINDOWS SOCKETS 网络编程 通常的通信工具,都采用客户机 /服务器
5、 (C/S)体系结构, C/S 结构是这样的一种结构:它包括 客户机 ,一个服务器 ,客户机的作用是访问和处理远程服务器上的数据 ,服务器的作用是接收和处理客户机的数据请求。 Client/Server 结构是当前数据库应用程序中极为流行的一种方式。尤其是网络技术的发展 ,使得当前很多系统都采用这种方式进行构造 ,其最大的优点是将计算机工作任务分别由客户端和服务器端来共同完成 ,这样有利于充分合理的利用系统资源。另外它的服务器端还可以将信息集中起来,任何客户机都可以通过访问服务器而获得所需的信息。 Client/Server 模型最终可归结 为一种“请求 /应答”关系。一个请求总是首先被客户发
6、出 ,然后服务器总是被动地接收请求 ,返回客户需要的结果。在客户发出一个请求之前 ,服务进程一直处于休眠状态。一个客户提出请求后 ,服务进程被“唤醒”并且为客户提供服务 ,对客户的请求做出所需要的应答 。 2.需求分析 2.1 用户需求 随着中小型企事业的不断发展,在企业内部实现局域网通信是必不可少的。局域聊工具就是一个非常好的局域网通信软件,它可以在职工不移动位置的情况下进行在线聊天、文件传递。这样,可以大大提高企业的工作效率,便于企业内部职员的交流。根据用户对聊天工具的要求,可分为以下几点: 1. 操作简单方便、界面简洁美观。 2. 可以在局域网实现文字和文件的传输 。 3. 可以进行聊天
7、记录保存 。 4. 可以实现局域网聊天 。 5. 系统运行稳定、安全可靠 。 2.2 系统功能需求 1. 程序启动之后就能看到当前哪些机器在线,哪些可以与之进行对等通信。 2. 一旦有某个网内的机器上线了,要有即时通知,并能及时更新用户界面中的用户列表。 3. 当单击用户列表项的时候,直接在聊天对话框打字聊天, 发送的聊天信息 。 4. 当有远程用户向本机发送文件的时候,弹出一个消息提示,用户可 选择接收或者拒绝。 5. 为 用户提供一个简单的聊天记录保存功 能。 6. 文件传输过程中,应该有当前传输状态提示, 并 作为当前网络状态的一种反馈。 2.3 性能要求 首先要求程序要完全可靠,可以应
8、付各种由于系统问题产生的错误,比如初始网络失败,对方突然下线等。要求提前设想到类似的尽可能多的可能发生的事件,做出相应的应对措施,并向用户提交简单易懂清晰明白的提示信息。 程序要有良好的容错性,当用户进行非法操作时或者系统本身出现问题时要能以最好的方式退出程序,避免发生程序假死现象。 要求程序对所运行之系统的硬件条件要求尽可能低,运行时内存占用尽可能小,响应速度要尽可能快。并且不发生 内存泄漏之类影响系统运行的错误事件。并且要求易于维护及扩展。所以应该采用模块化开发,各个模块之间不要有太多的耦合,以免维护困难。 2.4 测试环境规定 在开发过程中由开发人员自己,随时进行内部部分白盒测试,在开发
9、完成以后,自己进行一个全面的白盒测试,然后请同学帮忙进行黑盒测试。 2.5 可行性研究 2.5.1 成本可行性分析 本软件只做开发学习使用,所以暂且不考虑经济成本及盈利问题。 2.5.2 技术可行性分析 开发所需要的软硬件平台已经搭建好,并进行了合理而完善的需求分析,做好了充分的前期准备工作,其次因为本 程序的平台将基于 WINDOWS,将要使用网络通信技术,而WINDOWS 有完善成熟的网络通信接口,以及与 C#开发环境的严密契合能力, 与 更大规模的INTERNET 通信工具产品也已有例在先,所以这个程序的开发在技术上是完全可行的。 3 系统设计 3.1 系统功能结构 本系统中主要包括两个
10、部分:服务器端和客户端。 1. 服务器端的功能包括:验证客户 登录、 添加新用户 、传输 用户信息。 2. 客户端的功能包括:用户登录 、 文本聊天 、 文件传输。 客户端功能结构如图 3-1 所示。 图 2-1 客户端功能结构 3.2 系统功能需求 这个程序要实 现的功能如下: 1. 程序启动之后就能看到当前哪些机器在线,哪些可以与之进行对等通信。 2. 一旦有某个网内的机器上线了,要有即时通知,并能及时更新用户界面中的用户列表。 3. 当单击用户列表项的时候,直接在聊天对话框打字聊天,可以在其中编辑要发送的聊天信息,并进行发送。 4. 聊天界面要人性化,下面是发送框,上面有已有聊天记录,并
11、借助滚动条看到当次所有的聊天记录。 5. 当有远程用户向本机发送文件的时候,要弹出一个消息提示,提示本机用户,可以选择接收或者拒绝。 6. 为 用户提供一个简单的聊天记录保存功能。 7. 文件传输过程中,应该有当前传输状态 提示, 并 作为当前网络状态的一种反馈。 3.3 性能要求 首先要求程序要完全可靠,可以应付各种由于系统问题产生的错误,比如初始网络失败,对方突然下线等。要求提前设想到类似的尽可能多的可能发生的事件,做出相应的应对措施,并向用户提交简单易懂清晰明白的提示信息。 程序要有良好的容错性,当用户进行非法操作时或者系统本身出现问题时要能以最好的方式退出程序,避免发生程序假死现象。
12、要求程序对所运行之系统的硬件条件要求尽可能低,运行时内存占用尽可能小,响应速度要尽可能快。并且不发生内存泄漏之类影响系统运行的错误事件。并且 要求易于维护及扩展。所以应该采用模块化开发,各个模块之间不要有太多的耦合,以免维护困难。 4.系统模块详细设计 4.1 文本聊天模块实现 4.1.1 文本聊天 流程 开启服务器,文本聊天窗体加载成功后,将启动监听线程,服务器主要是负责监听局域网内的用户的连接请求。收到客户发起的连接请求后,若服务器处于空闲状态,弹出消息提示框,对请求进行处理,服务器可以选择接受或者拒绝客户端的连接。若同意连接,则返回给客户端同意信号,开启服务器的接收信息线程,并置消息发送
13、事件为 Enable。客户端收到服务器返回的同意信号后,也 开启接收信息线程,并置消息发送事件为 Enable。通信双方就可以进行文字聊天了。若服务器端拒绝客户端的连接,则关闭 tcpconnect,并关闭网络流,继续执行监听。客户端得知服务器端关闭 tcpconnect 并关闭网络流之后,则释放本次 socket 和网络流。若已建立连接,当断开连接时,将向对方发送断开信号,然后将释放Socket 和网络流,不影响到下一次连接的接入。文本聊天服务器工作流程如图 5-1所示。客户端用来向服务器端发起一个连接,等待服务器的允许接入确认。若服务器端同意连接请求,接收到服务器的同意连接信号 后,开启接
14、收信息线程,并置消息发送事件为 Enable,通信双方就可以进行文本聊天了。若服务器端拒绝连接,则释放 Socket 连接并关闭网络流。若已建立连接,当断开连接时,将向对方发送断开信号,然后将释放 Socket 和网络流,不影响到下一次连接的发起。 如图: 图 4-1 文本聊天程序流程图 4.1.2 界面设计 如 图 4-2 客户端服务器界面 界面简洁明朗易于操作。 开启监听线程,监听端口 开始 开始 开始 发送拒绝信号 发送拒绝信号 是 是 是 否 是否 断开连接? 发送断开信号,关闭文本聊天 是 终止 否 连接服务器 连接服务器 4.2 文件传输模块实现 4.2.1 文件传输接收端工作 流
15、程 开启窗体后,接收端执行监听线 程。当接收到客户发起的文件传入请求后,弹出消息提示,提示用户对请求进行处理,同意或者拒绝接收。若同意接收,则弹出文件保存对话框,用户选择文件保存路径并确认后,发送接收信号给文件发送端,启动计时器开始接收文件流,将远程文件保存在本地,并在文件传输过程中对文件传输状态进行反馈,文件接收完毕后,关闭计时器,关闭文件流,并在状态栏上显示出完毕状态。若拒绝接收,则向发送端返回拒绝信号,继续执行监听线程,等待下一次的文件传入请求。文件传输接收端工作流程图如图 4-2 所示。 图 4-2 文件传输接收端程序流程图 文本传输界面请具体参考参考 图 4-3。 执行监听线程 同意
16、接收文件? 否 是 发送同意接收信号,启动计时器,接收文件流,反馈状态 终止 接收发送端的文件传入请求 关闭计时器,关闭文件流 将远程文件存储至本地文件 开始 发送拒绝信号 4.2.3 文件传输发送 界面设计 开启窗体后,发送端选择用户需要发送的文件,向接收端发起的文件传输请求,若接收端端同意接收,开启计时器,将本地文件通过网络发送给接收端,并在文件传输过程中对文件传输状态进行反馈,文件发送完毕,关闭计时器,关闭文件流,并在状态栏上显示出完毕状态。若接收端拒绝接受文件,则取消本次文件发送,等待用户的下一次文件发送事件。 如图 4-3 所示 :图 4-3 文件传输接收 图 5.系统测试 5.1
17、系统测试概述 测 试的目的是为了发现功能是否达到,或者是否有更多的缺陷 ; 测试只能证明缺陷 存在,而不能证明缺陷不存在 ; 测试有助于提高软件的质量,但是提高软件的质量不能依赖于测试 ; 关于测试人员的安排,由我本人做白盒测试,由同学帮助做黑盒测试。 5.2 白盒测试 正确性测试检查软件的功能是否符合规格说明。由于正确性是软件最重要的质量因素,所以其测试也最重要。 在集成 P2P文本聊天 程序退出时,常常发生错误,异常退出,造成表面上看程序已结束,但却仍然驻留在内存中的现象。经过反复分析代码,最终确定问题出在程序退出处理流程上,通过修改和调试 ,问题解决。 整个开发过程中,共历经多次相互断开
18、、连接测试, P2P文本聊天模块终于可以正常运行。借助在 P2P文本聊天模块开发过程中积累的经验,较顺利的完成了 P2P文件传输模块的开发。通过在总集成后的程序的各个流程中添加消息提示框显示程序内部数据、对象的状态,并插入断点进行单步跟踪发现各模块工作正常,数据也未发生异常现象。 5.3 黑盒测试 用两台或两台以上机器通过交换机等构成一个局域网,进行正确的网络配置,每台机器上都安装了 WINDOWS 操作系统 、 DirectX SDK 以及 .NET 2.0,并安装了本软件的 正确拷贝。 先在其中一台机器 A 上启动服务端软件,开启监听服务。当 A 机器和 B机器启动了客户端软件后,向服务器
19、进行登录操作,服务器端验证了用户的登录后,向局域网广播客户端的登录状态。 此时就在客户端与服务器上进行功能性测试。 最后对系统软件进行容错性测试。 容错性测试是检查软件在异常条件下的行为。容错性好的软件能确保系统不发生无法意料的事故。 6. 主要问题及解决 6.1 多线程问题 通过查阅资料,掌握了 C#中在 winform 关闭时需要进行的操作: 1、接收线程需要关闭; 2、监听需要关闭; 3、 Socket 需要关闭; 4、网络流 需要关闭; 5、如果是传文件的话还需要关闭流文件。在后来经过不断的修改和大量的测试,终于将这个 bug 解决了。 通过对这个问题的解决,掌握了 C#中的使用多线程时,线程的创建、相互协调和销毁等技术。 6.2 套接字异常 在文本聊天模块测试时,通过在两个用户间连续地连接、断开,出现 Socket 异常,因为 Socket 在使用时,一个 IPEndpoint 只能使用一次,如果本地在使用某个 IPEndpoint,远程主机断开连接后,本地并没有释放此 Socket,当远程主机再次尝试连接此 IPEndpoint时,将出现 Socket 异 常。解决的办法就是在断开连接的时候,向对方发送 “ 断开 ” 信号,对方接收到断开信号后,将其自身的 Socket 释放掉。 6.3 网络流异常