下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、班级:网络123学号: 4姓名:赵恒基于DES加密的可视化聊天程序设 计 与 实 现班级:网络 123学号: 4姓名:赵恒指导老师:孙飞显摘要本论文所设计的局域网聊天程序将采用软件工程学的设计流程,其所涉及专业技术主要包含socket 网络编程,Windows MFC程序设计技术,DES加密/解密机制。本程序将以VC6 .0 作为程序开发工具。此聊天程序将采用C/S 模式即客户端/ 服务器模式。客户端和服务器、之间采用UDP协议进行通信。客户端需手动输入服务器地址。关键词:局域网聊天:Socket( 套接字 ) ; DES加密 /解密机制;客户端 /服务器模式;MFC微软基础类(); UDP(
2、用户数据报协议)。23一、选题背景错误!未定义书签。 .二、设计目标错误!未定义书签。 .三、需求分析错误!未定义书签。 .3.1 可行性分析错误!未定义书签。.3.2 系统总体需求分析错误!未定义书签。.3.3 开发运行环境错误!未定义书签。.四、设计原理错误!未定义书签。 .4.1 C/S软件架构技术错误!未定义书签。4.2 VisualC+中的MFC 错误!未定义书签。4.3 加解密原理错误!未定义书签。.五、设计步骤错误!未定义书签。 .5.1 体系结构设计错误!未定义书签。.5.2 功能能模块设计错误!未定义书签。.5.3 界面设计与编码实现错误!未定义书签。5.3.1 服务器界面设
3、计错误!未定义书签。5.3.2 客户端界面设计错误!未定义书签。5.3.3 DES加密/解密函数错误!未定义书签。5.3.4 服务器中消息加密与解密错误!未定义书签。六、测试结果错误!未定义书签。 .七、参考文献错误!未定义书签。 .一、选题背景随着 IT 技术飞速发展,人们的日常生活越来越离不开互联网。各种基于网络的应用技术在人们的政治、经济、 生活等的各个方面都发挥着重要的作用。各种实时性的聊天娱乐软件也应运而生,而且为我们的即时通讯带来了众多的方便。例如QQ, MSN,飞信,微信等基于 Internet 的即时聊天工具。这些工具通过网络这个新兴的媒介进行信息交流相比其他传统媒介具有数据量
4、大,实时性强,操作简单,成本低廉等优点。不仅如此即时聊工具还具备许多传统媒介不具备的强大功能,它们能传送文字、声音、影像和文档,而且能更加人性化的显示联络人的名单和通信状态。因而它们在现实生活中受到了用户广泛的欢迎,这是我们有目共睹的。目前基于Internet 的即时聊天工具已经做的非常完美,然而基于局域网的即时加密聊天工具却不如人意。 因此, 我们也需要一个实用性强和安全性高的基于局域网的即时聊天工具。当学习了网络安全程序设计这门课程之后,我们发现要设计和实现一个简单的加密可视化聊天程序并不困难。首先, 我们已经学习了密码学原理与应用,对DES加密/解密机制已经比较熟悉。其次,我们也已经学习
5、过Windows程序设计(MFC语言),熟悉MFC语言, 做一个可视化的程序很容易。最后, 我们从 网络安全程序设计这门课也学习到了设计一个软件的具体步骤和方法。二、设计目标我认为本设计需要满足以下几个系统设计目标:(1) 实用性原则:对于用户有实际的工作服务,按照需求的轻重缓急,合理设计本系统。(2) 可靠性原则:必须为用户提供安全的服务,首先是要保证数据传输的稳定性,其次要保证数据的安全性。(3) 友好性原则:使用本系统的用户相当一部分对计算机知识了解很少, 所以系统操作上要求简单方便,系统使用过程中必须要有友好的的提示信息,这样才便于用户在短时间内熟悉本系统。(4) 可扩展性原则:采用开
6、放的标准和接口,便于系统向更大的规模和功能扩展,本系统有较好的扩展特性。三、需求分析3.1 可行性分析1)技术可行性:本系统以VC6.0 为开发环境,再结合网络通信中的UDP协议和Socket 编程及DES加密/解密技术。从技术可行性角度考虑技术完成成熟,因此本系统设计与实现是可行的。2)经济可行性:本系统开发成本极低,无须额外的人力资源、物力资源和财力资源。而且,本系统的经济效益会远大于开发成本,从经济可行性角度考虑是可行的。3)操作可行性:系统硬件为PC 机,操作系统为WindowsXp/Windows7/Windows8,而且编程环境Visual C+为专业程序员使用工具,比较易于使用,
7、可行。3.2 系统总体需求分析根据用户的需求,本系统实现的功能类似于用户之间的聊天。在设计系统时,系统布局应该简洁、流畅,在编制程序时应充分考虑这一点。同时,还应要保证数据传输的稳定、快捷、安全,给用户真正的 "简洁、高效、流畅、安全"使用环境。用户使用过程,首先打开本软件,客户端要输入服务器IP 地址。然后,服务器与客户端建立连接进行通信。3.3 开发运行环境开发此系统所需的基本软、硬件环境为:(1) .WindowsXP 或 Windows7 或 Windows8;(2) .Pentium100 及以上档次的PC 及其兼容机;(3) .128M 以上内存措施;(4) .
8、1G 以上可用硬盘空间;(5) .VGA 显示器 ; 以上的配置均要求为在同一局域网内的两台或两台以上。四、设计原理4.1 C/S 软件架构技术C/S( Client/Server )结构,即大家熟知的客户机/服务器结构。它是软件系统体系结构,通过它可以充分利用两端硬件环境的优势,将任务合理分配到Client 端和 Server 端来实现,降低了系统的通讯开销。 目前大多数应用软件系统都是Client/Server 形式的两层结构, 由于现在的软件应用系统正在向分布式的Web应用发展,Web和 Client/Server 应用都可以进行同样的业务处理,应用不同的模块共享逻辑组件;因此, 内部的
9、和外部的用户都可以访问新的和现有的应用系统,通过现有应用系统中的逻辑可以扩展出新的应用系统。这也就是目前应用系统的发展方向。传统的C S 体系结构虽然采用的是开放模式,但这只是系统开发一级的开放性,在特定的应用中无论是Client 端还是 Server 端都还需要特定的软件支持。由于没能提供用户真正期望的开放环境,C/S 结构的软件需要针对不同的 操作系 统系统开发不同版本的软件,加之产品的更新换代十分快,已经很难适应百台电脑以上局域网用户同时使用。4.2 VisualC+ 中的 MFCVisual C+ 是一个功能强大的可视化应用程序开发工具,用于Windows 环境下 32 位的应用程序的
10、开发,是计算机界公认的最优秀的应用开发工具之一。在提 供可视化的编程方式的同时,Visual C+也适用于编写直接对系统底层操作的程序,生成代码的质量也优于其它的开发工具。在Visual C+环境下,利用 Microsoft 的基本类库 MFC(Microsoft Foundation Class Library), 可以使用完全的面向对象的方法来进行Windows 95/98/NT 应用程序的开发,使得Windows 程序员从大量的复杂劳动中解救出来,体会到真正的程序语言的强大功能和良好的灵活性。Visual C+编程是一个面向对象的程序设计方法。同传统的结构化程序设计方法相比,它缩短软件的
11、研制时间,提高软件的开发效率,使程序员可以更好地理解和管理庞大而复杂的程序。面向对象的程序设计吸取了结构化程序设计的精华,它利用了人们根据对事物分类和抽象的倾向,引入了类和对象的概念,具有封装性(数据抽象)、继承和多态的特点。与结构化程序设计不同的是,面向对象程序设计是用类抽象代表现实的实体,用类之间的继承关系表示程序设计的抽象过程。函数只是对数据的操作, 没有数据的概念,而类是数据和数据操作的集合,由于面向对象的程序设计方法非常近现实,所以越来越流行。Visual C+中集成了大量的最新技术,如ActiveX 、 COM等技术,程序开发人员可以紧紧地把握住软件开发技术发展的方向,开发出功能强
12、大的应用程序。 Visual C+还提供了丰富的技术资源,MSDN(Microsoft DevelopNetwork) 提供 了强大的联机帮助支持,同时还可以通过访Microsoft的网上站点来获得最新的技术文档。( 1) Socket 及 Window Socket API 简介 套接字(Socket)是一种双向的通信接口,可以通过这个端口与任何一个具有 Socket端口的计算机通信,套接字是网络通信的基础。Socket 在 Windows以 句柄的形式被创建。使用Socket 进行网络通信必须包含下面的几种信息:双方认可的协议,本地主机的IP 地址,本地进程的协议端口,对方主机的IP 地址
13、, 对方进程的协议端口。Socket 可分为:1 数据报套接字( Datagram Sockets) 对于在 TCP/IP上实现的WinSock,数据报套接字使用用户数据报协议(UDP) 。数据报套接字提供了一种不可靠的、非连接的数据包通信方式。2 流式套接字(Stream Sockets) 流式套接字使用传输控制协议(TCP)。流式套接字可以将数据按顺序无重复地发送到目的地, 它提供的是一种可靠的、面向连接的数据传输方式。不管是对单个的数据报,还是对数据包,流式套接字都提供了一种流式数据传输。4.3 加解密原理DES 将明文分成64比特大小的众多数据块,即分组长度为64位,同时用56 位密钥
14、对64 位明文信息加密,最终形成64 位密文。如果明文长度不足64 位,则将其扩展为64 位(例如补零等方法)。具体加密算法过程首先是将输入的数据进行初始换位(IP) ,将明文M 中数据的排列顺序按一定的规则重新排列,生成新的数据序列,以打乱原来的次序。然后将交换后的数据平分成左右两部分,左边记为L0,右边记为R0,然后对R0施行在子密钥(由加秘密钥产生)控制下的变换f, 结果记为f(R0,K1,),再与L0做逐位异或运算,其结果记为R1, R0 则坐下一轮的L 1。如此循环16轮,最后得到L16、 R16,再对L16、 R16施行逆运算初始置换IP-1, 即可得到加密数据。解密过程与此 类似,不同之处在于子密钥的使用顺序正好相反。子秘钥产生流程五、设计步骤5.1 体系结构设计一般的通信工具,都采用客户端/ 服务器体系结构,本程序也不例外。客户端/服务器结构的具体结构是这样的:它包含客户端和服务器端; 客户端访问和处理服务器上的数据,服务器接收和处理客户端的数据请求。这种模式的好处就是可以将一个系统分为两个独立的部分进行开发设计,便于软件开发。而且也把一个软件的功能交给两个部分去完成,则更加有效的利用了系统资源。5.2 功能能模块设计由于本系统采用C/S 模式, 所以对功能模块进行划分时,就需要分服务器和客户端两部分进行。服务器有信息输入模块、信息接收模块和通信对象模
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025房屋无偿使用合同
- 2025二手货物买卖合同范本
- 2024年标准安全责任协议样本版B版
- 2025居间服务公司合同
- 2024年租赁合同守信承诺函
- 商丘幼儿师范高等专科学校《食品标准与法规A》2023-2024学年第一学期期末试卷
- 2024年离婚合同范本:子女抚养与探视权规定版B版
- 商丘学院《跨境电子商务》2023-2024学年第一学期期末试卷
- 2024年短期安保服务合同版B版
- 2024商铺物业管理与绿色建筑认证合同3篇
- 最新标点符号用法
- 特困人员生活自理能力评估表
- 预拌混凝土企业质量管理体系·程序文件
- 外国人换发或补发永久居留证件申请表样本
- 塔吊安装旁站监理记录表(示范稿)
- GCC认证对整车的一般要求
- OBD-II标准故障代码表
- 施工现场类安全隐患排查清单表
- 采购项目组织履约、验收方案、程序、办法
- 送货单(三联针式打印)
- pdca循环在护理教学中的应用学习教案
评论
0/150
提交评论