基于Socket的网络即时通信系统报告.docx
- 文档编号:2881000
- 上传时间:2022-11-16
- 格式:DOCX
- 页数:25
- 大小:482.96KB
基于Socket的网络即时通信系统报告.docx
《基于Socket的网络即时通信系统报告.docx》由会员分享,可在线阅读,更多相关《基于Socket的网络即时通信系统报告.docx(25页珍藏版)》请在冰豆网上搜索。
基于Socket的网络即时通信系统报告
网络信息处理课程
设计报告
题目:
基于Socket的网络即时通信系统
班级:
小组成员:
指导教师:
中国矿业大学计算机学院
2013年6月
1.需求分析
1.1开发背景
即时通信系统是基于Internet网络及其它有线、无线网络的一种非常流行的实时通信方式,是一种非常便捷的网络通讯技术,它用互联网通过通信系统建立起网络虚拟环境,通过计算机键盘或无线设备在网络上进行实时交换,成为一种提供公共通讯、商务通讯及商务合作的新媒介,也弥补了传统通讯形式的不足,尤其是电子及语音通信方面。
随着即时通信普及,全球即时通信用户的数量也不断增长。
微软公司的MSN、腾迅公司QQ、网易公司的网易泡泡等通信系统都是家喻户晓的。
除了最基本的单纯的文本交流,即时通信业务增加了视频、音频交流等多种宽带应用元素,如提供视频、语音通信服务、交流共享、短信收发、数据传输等服务项目。
即时通信业务的承载设备也将趋向于多元化。
用户可以通过手机、个人计算机、PDA等工具使用即时通信,宽带、网络业务也逐渐在即时通信的软件上实现功能。
本文所介绍的网络即时通信系统是基于开放的JAVA应用程序开发设计的,其主要特性是能动态、实时的完成信息的传递,且具有高效的交互性。
该设计有一个服务器和若干个客户端,服务器、客户端和客户端、客户端之间可以实现群聊与私聊,客户端之间可以进行文件传输。
该设计可以应用于公司或者学校,因为是自己提供服务器,方便管理各个用户。
1.2系统目标
该系统目标是提供信息交互等基础服务,它既可以用TCP可靠的运输服务,也可以使用UDP运输服务。
这个即时通信系统是一个类似QQ的聊天系统,有客户端和服务器端。
服务器端记录当前在线客户列表,把客户列表发送给每一个在线客户,并实时刷新。
任一个客户可以和任意其它的客户进行交互,即从在线客户列表中选择一个或一组其它客户通过服务器转发彼此进行交互,包括信息交互,文件交互。
本系统是基于Socket进行通信,要求有两台或两台以上的能正常进行网络通信的计算机,并且已经接入了同一个网络,每一台电脑都有一个固定且在网络中唯一的IP地址。
1.3主要思路和操作流程
(1)设计服务器端和客户端的界面
服务器的界面设置启动服务器和关闭服务器的按钮,用户列表框来显示当前已登录的用户,用来发送系统消息的文本框,用来发送系统消息的按钮,和一个文本框来显示各种信息,比如显示系统信息,以及用户登录信息,服务器开启或关闭的信息。
客户端界面设置一个菜单栏,菜单栏里有操作,设置,和发送文件三个主菜单。
操作主菜单应该包括登录、注销和退出三个子菜单;设置包括用户名(用来设置用户名),连接两个子菜单(用来与服务器进行连接);发送文件主菜单有一个发送文件的子菜单(用来发送文件);客户端还用来设置用户名,与服务器建立连接,登录服务器,注销,文件接收和发送消息六个按钮,还设置一个下拉列表框来显示所有已经登录的用户名及其IP(这里设置IP的目的是为了实现文件的传输),一个用来显示用户头像的标签(所有用户的头像设置为同一图片),一个用来发送消息的文本框,一个用来接收信息的文本框。
(2)设计消息传送的协议
对消息的传送,分为服务器端和客户端两部分:
服务器端,发的消息为系统消息,客户端发送的消息根据消息接收对象的个数的不同又分为私聊信息和群聊信息。
(3)设计文件传送的协议
首先,发送端从服务器获得接受端的IP,接着发送端和客户端建立连接,传送文件。
1.4相关技术
1.4.1JAVA语言
Java是一种简单、多线程、安全、容易适用、可移置、面向对象、高性能的语言。
它具有如下特点:
1.面向对象:
面向对象技术是一次革新,它可以提高模块化程度和重复适用率,缩短软件开发时间,减低开发成本。
2.安全性:
Java提供了许多安全机制,是能用在网路和分布环境下的程序设计语言。
3.多线程:
Java具备建的多线程功能,使各线程并发、独立执行,提高系统的运行效率。
4.平台独立:
平台独立是指程序不受操作平台限制,可以应用于各种平台。
Java源程序经过编译后能够生成字节码文件,字节码和具体的计算机无关。
计算机安装能解释执行字节码的JVM,就能执行字节码文件,实现了Java的平台独立性。
5.执行效率:
字节码要经过JVM解释成机器码才能执行,所以速度较慢。
1.4.2TCP/IP协议
TCP协议是网络通信的基石。
Java专门提供了Socket的类库,抽象出TCP协议通信中的常用方法:
TCP协议与三次握手:
(1)客户端,首先发送TCP请求,客户端是服务(如数据查询服务)的请求者。
(2)服务器,接收到客户端的请求后,服务器向客户端提供服务。
服务器是服务的执行者,返回服务执行的结果给向客户端。
主机A主机B
图1-1握手协议
首先客户端发送一个数据包SYN。
如果服务器收到SYN,它会发回一个数据包SYN+ACK。
客户端为了表示收到SYN+ACK信息,向服务器发送一个最终确认信息ACK。
SYN,SYN+ACK,ACK步骤被称为“三次握手”,这样,连接就建立好了,并将一直保持活动状态,直到其中一方发出FIN(结束)信号或者超时。
这种通信模式也被叫做客户端/服务器(C/S)模式。
1.4.3Socket通信
图1-2Socket实现原理图
从概念上理解,Socket是网络编程中最常见的客户/服务器模式,也是本系统的基础。
以该模式编程时,服务器端有一个进程或多个进程在指定的端口等待客户来连接,一旦连接成功,便按设计的数据交换方法和格式进行数据传输。
客户端向服务器端提出连接请求,连接之后进行通信。
Socket是一种用于表达两台机器上都有一个Socket,可以想象一条虚拟的电缆工作在两台机器之间,电缆插在两台机器的Socket上。
简单的说,一台计算机上的Socket同另一台计算机通话创建一个通信信道,我们可以用这个信道在两台机器之间发送数据。
如图2-2Socket实现原理图。
1.5开发工具与开发平台
本次开发是基于操作系统MicrosoftWindows7,开发工具为JDK,开发平台为eclipse。
2.概要设计
2.1系统功能描述
我们的程序功能分为两个部分,即发送消息部分和发送文件部分
(1)发送消息:
首先开启服务器端,并且在服务器端开启服务,然后在客户端设置服务器端的IP地址和自己的用户名,以便于与服务器端的连接与用户的识别,然后登录服务器并建立连接,在自己的客户端中的下拉列表框中选择选择要发送消息的对象或者是默认选择发送消息至所有人,最后点击发送。
由于我们的聊天程序是基于服务器端的消息转发机制,所以如果用户选择发消息给自己的时候,就会显示2条信息,第一条是自己的客户端输出到聊天的文本框中的,第二条是服务器把消息转发给我自己的客户端然后输出到聊天的文本框中的。
当然,我们在服务器端也是可以发消息的,在客户端收到的消息都会显示为系统消息加上你在服务器端输入的消息。
(2)发送文件:
在与服务器端建立连接的条件下,客户端从服务器端获得所要发送文件的对象的IP地址,然后通过原有的发送消息的机制,把我要发送文件的消息发给服务器进行转发,当另外一个客户端收到对方要发送文件的信息后也通过原有的发送消息的机制,把我接收文件的消息仍然交给服务器进行转发,并且从服务器端获得要发送文件的那个用户的IP地址。
当双方都收到消息后,即可建立连接发送文件,在文件发送完毕,在这两个客户端都实时显示文件发送完毕的信息。
2.2系统架构
图1中的是我们在两个用户的情况下整个聊天程序的系统架构,并且这两个用户是有传输件的需求的。
我们的聊天程序是多个用户的连接,我们的聊天程序是基于消息的服务器转发机制,即将所有要发送的消息都提交到服务器,然后由服务器转发,然后由服务器进行识别是多人聊天的信息还是私人聊天的信息。
如果是多人聊天,即转发到所有的用户,如果是私人聊天,转发到要发送的用户的客户端去。
图1
考虑到传输效率方面的问题,以及隐私方面的问题,我们的文件传输机制没有用基于服务器转发机制实现,而是利用消息转发机制进行协议的控制,而后用一个新的端口号,建立双方的TCP连接直接传输文件。
文件传输完毕后,双方都关闭各自的传输文件的socket。
2.3模块划分
2.3.1客户端模块
我们的模块划分为服务器端以及客户端的发送消息部分和客户端的发送文件部分。
由于服务器端只是负责建立多方之间的连接以及消息的转发,所以做成一个单独的模块,而客户端有发送文件或者是发送消息的需求,所以这两个分别做成客户端的两个线程,形成客户端模块(如图2)。
图2客户端模块
2.3.2服务器端模
图3为服务端模块,服务器对客户端进行解析信息,以及对各客户端传来的信息进行判断传递同时判断各客户端传来的信息是什么类型,需要传输消息或者是文件。
图3服务器端模块
3.详细设计
3.1流程图
3.1.1系统总体流程图
3.1.2客户端流程图
3.2数据结构
3.2.1服务器端设计
(1)ChatServer.java
Public类主要功能是服务器端的界面设计,添加窗体中组件的事件侦听,响应相应事件处理。
并调用Listener类来实现对客户端用户的上线与下线的监听,和实现服务端对客户端的发送系统消息。
主要功能函数:
actinPerformed主要对于窗体按键的响应,实现服务器端的启动服务,停止服务,和服务端对在线用户的消息发送。
startService启动服务器的工作
stopService停止服务器的工作
sendStopToAll对所有客户端发送服务器停止工作的消息
sendMsgToAll对所有客户端发送服务器的系统消息
sendSystemMessage对单个的客户端发送系统消息
(2)ServerListen.java
Listener类主要功能是实现服务器端对于客户端的用户的上下线进行监听。
通过调用类(ServerReceive类)来实现。
当用户发生变化时会对服务端的主界面进行相应的修改。
主要功能函数:
run实现客户端的上线情况监听,并调用Receiver类来实现客户的更新和对于客户端到客户端的消息转发。
(3)UserLinkList.java
UserLinkList类是用户列表,用用户链表节点实现,该类通过构造用户链表,定义了添加用户,删除用户,换回用户数目,根据用户名查找用户。
主要功能函数:
addUser对用户链表添加新用户
delUser删除链表中的用户
getCount返回链表中记录的用户数量
findUser通过用户名称查找用户。
3.2.2客户端设计
(1)ChatClient.java
ChatClient类主要是实现客户端的界面,添加对于客户端界面的组件事件侦听与事件处理。
调用ClientRecieve类实现消息的收发。
主要功能函数:
actionPerformed响应窗体的组建事件,实现用户信息的配置,与服务器端的连接和断开连接,客户端的信息发送,以及客户端对客户端的点对点的文件传送。
Connect实现用户端与服务器的套接字连接,并创建ClientRecieve实例来实现从服务器端获得消息。
DisConnect关闭与服务器端的连接。
SendMessage实现客户端的对在线用户的发送消息。
(2)ClientReceive.java
ClientRecieve线程类主要是实现客户端对于服务器端的消息接收。
主要功能函数:
run线程体不断的监听端口消息信道,从中获得服务器端只能够发送的各种消息。
(3)FileSend.java
FileSend线程类,实现文件的发送,当用户需要点对点的文件传送,调用此类。
主要功能函数:
s
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 基于 Socket 网络 即时 通信 系统 报告