您好,欢迎访问三七文档
当前位置:首页 > 商业/管理/HR > 销售管理 > UDP服务器设计-课程设计
四川理工学院课程设计书学院计算机学院专业计算机科学与技术班级实验二班题目UDP的服务器设计教师学生1目录组员分工情况............................2一课程设计的目的和意义.................3目的:设计一个基于UDP的服务器.........3二、课程设计的内容和要求................3三、课程设计的相关技术..................4四、课程设计过程........................54.1设计思路................................................54.2服务器的主要工作流程........................64.3主要功能模块........................................74.4程序实现部分......................................164.5程序运行结果截图.............................204.5.1Dos下的测试运行情况.................204.5.2MFC的界面情况...........................22五、课程设计小结.......................23参考书目...............................242组员分工情况小组成员负责任务钟寒梅发送部分代码编写及注释,DOS下运行的服务器,客户端实现张俊威接收部分代码编写及注释,相关资料整理,MFC的客户端实现张泽泉数据处理部分代码编写及注释,MFC的服务器实现,实验报告的编写3一课程设计的目的和意义目的:设计一个基于UDP的服务器意义:UDP是TCP/IP协议族为传输层设计的两个协议之一,它在进程与进程的通信过程中,提供了有限的差错校验功能,是一种无连接的,不可靠的协议。UDP在一个较低的水平上完成进程之间的通信,在收到分组的时候没有流量控制机制也没有确认机制,适用于可靠性比较高的局域网。由于UDP采取了无连接的方式,因此协议简单,在一些特定的应用中协议运行效率高。UDP适合一些实时的应用,如IP电话,视频会议,它们要求源主机以恒定的速率发送数据,并且在网络出现拥塞时,可以丢失一些数据,但是延迟不能太大。基于这些特点,流式多媒体通信、多播等应用在传输层采用的就是UDP协议。因为UDP具有TCP所望尘莫及的速度优势。虽然TCP协议中植入了各种安全保障功能,但是在实际执行的过程中会占用大量的系统开销,无疑使速度受到严重的影响。反观UDP由于排除了信息可靠传递机制,将安全和排序等功能移交给上层应用来完成,极大降低了执行时间,使速度得到了保证。二、课程设计的内容和要求编写程序,设计UDP服务器。因为考虑到实时性,所以选择UDP为主要的网络通信技术。(1)程序能流畅地完成信息内容的传输和接收。4(2)要能对多个客服端进行管理。需要通过UDP模拟多个客服端连接验证的情况。(3)操作系统、使用语言和编译环境不限,但在作业中必须注明。三、课程设计的相关技术(1)UDP协议技术UDP是一个无连接协议,传输数据之前源端和终端不建立连接,当它想传送时就简单地去抓取来自应用程序的数据,并尽可能快地把它扔到网络上。在发送端,UDP传送数据的速度仅仅是受应用程序生成数据的速度、计算机的能力和传输带宽的限制;在接收端,UDP把每个消息段放在队列中,应用程序每次从队列中读一个消息段。(2)C++编程技术(3)TCP/IP协议技术在TCP/IP协议族中,有两个互不相同的传输协议:TCP(传输控制协议)和UDP(用户数据报协议)。TCP为两台主机提供高可靠性的数据通信。它所做的工作包括把应用程序交给它的数据分成合适的小块交给下面的网络层,确认接收到的分组,设置发送最后确认分组的超时时钟等。由于运输层提供了高可靠性的端到端的通信,因此应用层可以忽略所有这些细节。而另一5方面,UDP则为应用层提供一种非常简单的服务。它只是把称作数据报的分组从一台主机发送到另一台主机,但并不保证该数据报能到达另一端。任何必需的可靠性必须由应用层来提供。(4)TCP/IP协议与Winsock网络编程接口Winsock规范不是一种网络协议,而是一套开放的、支持多种协议的Windows写的网络编程接口。Winsock可以访问很多种网络协议,可以把它当作一种协议的封装。现在的Winsock已经基本上实现了与协议无关,可以使用Winsock来调用协议的功能(5)WinsockAPI的使用下面给出了使用Winsock进行编程时涉及的主要函数:WSAStartup函数、WSACleanup函数、socket函数、closesocket函数、send函数、recv函数、bind函数、listen函数、accept函数、connect函数四、课程设计过程4.1设计思路设计UDP服务器的过程如下所示。首先,创建又一个Socket并监听。然后启动线程接收数据。用一个链表保存所有连上的客户,并通知连接成功。这样,客户就有机会处理这一事件并作一些动作。最后,6当客户断开时,向服务器发送一个事件,服务器就可以做一些收尾工作。其中最关键的部分是收发部分和数据处理部分。4.2服务器的主要工作流程如图1所示:Bind()Socket()Readfrom()等待客户请求处理服务请求Sendto()Close()Socket()Bind()Sendto()Readfrom()Close()服务请求服务应答服务器客户机图1服务器工作流程7客户机一方的工作流程如下:(1)打开通信信道(申请一个套接字),并连接到服务器在主机的保留端口,该端口对应服务器的UDP进程。(2)向服务器发出请求报文,等待接收应答。(3)从服务器方收到最终应答结果,或在不再请求时关闭信道并终止客户机进程。服务器一方的工作流程如下:(1)打开通信信道(申请一个套接字),通知本地主机在某一保留端口接收客户机请求。(2)等待客户机请求到达指定端口。(3)接收到请求,启动一个新进程处理用户请求,同时释放旧进程以响应新的客户请求,一旦服务完成,关闭新进程与客户的通信链路。(4)继续等待客户机请求。(5)如果不想响应客户机请求,关闭服务器进程。4.3主要功能模块如下:(1)发送BOOLCUdpSock::SendBuffer(char*buff,DWORDdwBufSize,structsockaddrFAR*lpTo){m_lock.Lock();//锁定WSABUFwsabuf;//建立结构体8WSAOVERLAPPEDover;//建立结构体DWORDdwrecv;//定义DWORDdwFlags=0;//定义DWORDdwRet;//定义BOOLfPending;//定义intnRet;//定义////建立WSABUF和WSAOVERLAPPED两个结构体//memset(&over,0,sizeof(WSAOVERLAPPED));//用给定字符填充缓冲区wsabuf.buf=buff;//缓冲区赋值wsabuf.len=dwBufSize;//长度赋值over.hEvent=WSACreateEvent();//创建事件fPending=FALSE;nRet=WSASendTo(m_Socket,//套接字&wsabuf,//结构体1,//缓冲池参数&dwRecv,//接受的字节数dwFlags,//标记lpTo,sizeof(sockaddr),&over,//结构体NULL);//函数完成if(nRet!=0){interro=WSAGetLastError();9if(erro==WSA_IO_PENDING)fPending=TRUE;//检测是否是因为传输未完成而造成的错误else{TRACE1(CUdpSock::SendBuffererro%d\n,erro);//给出出错信息CloseHandle(over.hEvent);returnFALSE;}}////如果是I/O未完成//if(fPending){////等待完成请求或结束事件//dwRet=WaitForSingleObject(over.hEvent,60000);////判断是否是接收方发出的信号//if(dwRet==WAIT_TIMEOUT)//WAIT_OBJECT_0/WAIT_TIMEOUT{CloseHandle(over.hEvent);//关闭一个内核对象TRACE(WAIT_TIMEOUT发送失败\n,NULL);//提示发送失败returnFALSE;//返回}if(dwRet!=WAIT_OBJECT_0)//WAIT_OBJECT_0/WAIT_TIMEOUT{CloseHandle(over.hEvent);//关闭一个内核对象TRACE(发送失败\n,NULL);//提示发送失败returnFALSE;//返回10}////查看I/O信息//if(!WSAGetOverlappedResult(m_Socket,//套接字&over,&dwRecv,FALSE,&dwFlags)){CloseHandle(over.hEvent);//关闭一个内核对象TRACE(WSAGetOverlappedResult发送失败\n,NULL);//提示发送失败returnFALSE;//返回}}CloseHandle(over.hEvent);//关闭一个内核对象TRACE(发送成功\n,NULL);//提示发送成功m_lock.Unlock();//解除锁定returnTRUE;//返回}(2)接收BOOLCUdpSock::RecvRequest(LPBYTEpBuf,DWORDdwBufSize,structsockaddrFAR*lpFrom){//清空接收缓冲区memset(pBuf,0,dwBufSize);//建立WSABUF和WSAOVERLAPPED两个结构体wsabuf.buf=(char*)pBuf;wsabuf.len=dwBufSize;11memset(&over,0,sizeof(WSAOVERLAPPED));//用给定的字符串填充缓冲区over.hEvent=m_hEventSock;dwFlags=0;fPending=FALSE;intsizeAddr=sizeof(sockaddr_in);//返回参数所占的字节数nRet=WSARecvFrom(//接受数据m_Socket,&wsabuf,1,&dwRecv,&dwFlags,lpFrom,&sizeAddr,&over,NULL);if(nRet!=0){//判断传输是否正常完成if(WSAGetLastError()!=WSA_IO_PENDING){returnFALSE;}elsefPending=TRUE;}//如果完成if(fPending){//等待结束请求或退出事件hEvents[0]=over.hEvent;hEvents[1]=m_hEventExit;dwRet=WaitForMultipleObjects(2,hEvents,FALSE,12INFINITE);////判断是否是接收方发出的信号//if(dwRet!=0){returnFALSE;}if(!WSAGetOverlappedResult(m_Socket,&over,&dwRecv,FALSE,&dwFlags))returnFALSE;}////接收结束//m_translate=dwRecv;returnTRUE;}}(3)数据处理部分BOOLCUdpSock::DelWithResData(structsockaddrFAR*lpFrom){DWORDlenPag=sizeof(PackHead);DWORDstart=0;DWORDonePagLeft=0;SockPagspags;if(m_b
本文标题:UDP服务器设计-课程设计
链接地址:https://www.777doc.com/doc-6572560 .html