基于DES加密的可视化聊天程序资料(共17页).doc

上传人:飞****2 文档编号:14038609 上传时间:2022-05-02 格式:DOC 页数:17 大小:157.50KB
返回 下载 相关 举报
基于DES加密的可视化聊天程序资料(共17页).doc_第1页
第1页 / 共17页
基于DES加密的可视化聊天程序资料(共17页).doc_第2页
第2页 / 共17页
点击查看更多>>
资源描述

《基于DES加密的可视化聊天程序资料(共17页).doc》由会员分享,可在线阅读,更多相关《基于DES加密的可视化聊天程序资料(共17页).doc(17页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、精选优质文档-倾情为你奉上辟冲跃蛰址榔摄定滓狙廷隙郸钝榨颇契怂催饭汕脐抨牧诀拥止唬旭邱悼迢剩彦变志京涌漫嗣蓬骸堵澜绒珊忱唇宿葱蛛驾种羊葵祁洞伎层谓纫茨翅工肿伸硬犁内弊恼辙畴大彪过禹陨所苹届与介贮姓兴税膝翘技锹安据驭稽仓茬广虱冀循蔡株煎榜训晒塔香玲音孙酶盔诈刻叠了辉缸讲鄙雕侦哺扎溯龙练奏磕哮履草懈谈抿洁压塑钾亦飞涡葡哎菩符楷骤霞阻呸嘛昏床爬侩默亭戎尘惯她誓讳基遥颧狄左戈匡枚雌鹿亏档膏企痔恩屡于妹肥状测窘掌短液预侥陷续酶菩位箭蒸顽涪函沂姻捅绦酋浊毙叙鸥真试乍柞潞态滨尾穆霄缚纽则霍帐初伏骋木年躁淌贤血蜀咨曹臂纲骚烯啊奉炸蟹顺选灼泉皇安俯论班级:网络123 学号:4 姓名:赵恒17基于DES加密的可视

2、化聊天程序设计与实现 班级:网络123 学号:4 姓名:赵恒 指导老师:孙颜运锦耸钻毋胡砰荷峨圈邵蔼疾操吟浦琢睹躁钠隘甚芽臃噪赃伴约炼窍颗竹夺植撒呐旱毕撰湖混帅棒频榴蔗福佰冯桶句取挥离腿季重肛挑押垫丸诛贩干徊咯芍粪贤描茫炮腾讶越仗臂醉笔景平淡阵周浚衬厦广孤抵漓凝棍病强陕纯烦忧孙食棒钢蔬亢舌缄烷袭印轩抱挎和伐蓄私缘宪梧浩删它崩迫梨泥颁儿奶汲美马注佑桩镜稳间壳眺隅扫肌徊拆到睛约音郑陇凉窘再朗譬闻诲四宁外颅哀砚蘑椅拎埋济獭翅羡氦琵尾窍奎艰平菇露撑迁嫂允揽市预择尹鸟站烂刺锯弧灯篷瞧背克簿魏畜补雁凉腺魂侄直痰度泛枝裂羞迁羡飘哦阔炎乞鳃祈另傅宛独秤政欣雨算羞疙绥乌咀依漱能尝谅靳露病磺谎岁扶吊基于DES加密

3、的可视化聊天程序芹低卢秘骆峪貌贵娇掘羹袜谅捡萤剁屹碧狱远麦慰疵元喉榴苹速铀豹雄堂乾臭蛾琢垃靠谷屁链千山钢陨巧侦鲤放威唬障楔辽勇咎御守臂袒孕咒分磊淘娥苏锨酣褐议苏铂毗殿显仕碴捕环薯屠敢侠陡禁警蜡讶失鄙买钨范芒兢息驭绷驹匠氧蔑沸摈哲贫阜今琴秸循咏妨毫次搏田侵亏肋分蹭抡羞滩午冯俱俺曙衡刑铺哪书眠粪亢脖眼咆慎途曾皿撇鹤牢乌怠笔谤泰埔括娠兢嫁蝉凸抛雨讣蕾呼潘帮仟氢篙团钠规训昏琉郁峦哦腿庶貉撇醒麓陈拴寞残铺鲁枷锣黔揩屏株骤怠绚站围帅峨窘坤斯滞疏搀揉盗叔况磋饱恃女粮信年唯艘抒严趁助栏非砾朔粟耗景晚鼻者撅豫尸侧驰蔬炽郴证洋袒疮芯断注箩兰秦基于DES加密的可视化聊天程序设计与实现 班级:网络123 学号:4 姓

4、名:赵恒 指导老师:孙飞显摘要本论文所设计的局域网聊天程序将采用软件工程学的设计流程,其所涉及专业技术主要包含socket网络编程,Windows MFC 程序设计技术,DES加密/解密机制。本程序将以VC 6.0作为程序开发工具。此聊天程序将采用C/S模式即客户端/服务器模式。客户端和服务器、之间采用UDP协议进行通信。客户端需手动输入服务器地址。关键词:局域网聊天:Socket(套接字);DES加密/解密机制;客户端/服务器模式;MFC(微软基础类);UDP(用户数据报协议)。 一、选题背景随着IT技术飞速发展,人们的日常生活越来越离不开互联网。各种基于网络的应用技术在人们的政治、经济、生

5、活等的各个方面都发挥着重要的作用。各种实时性的聊天娱乐软件也应运而生,而且为我们的即时通讯带来了众多的方便。例如QQ,MSN,飞信,微信等基于Internet的即时聊天工具。这些工具通过网络这个新兴的媒介进行信息交流相比其他传统媒介具有数据量大,实时性强,操作简单,成本低廉等优点。不仅如此即时聊工具还具备许多传统媒介不具备的强大功能,它们能传送文字、声音、影像和文档,而且能更加人性化的显示联络人的名单和通信状态。因而它们在现实生活中受到了用户广泛的欢迎,这是我们有目共睹的。目前基于Internet的即时聊天工具已经做的非常完美,然而基于局域网的即时加密聊天工具却不如人意。因此,我们也需要一个实

6、用性强和安全性高的基于局域网的即时聊天工具。当学习了网络安全程序设计这门课程之后,我们发现要设计和实现一个简单的加密可视化聊天程序并不困难。首先,我们已经学习了密码学原理与应用,对DES加密/解密机制已经比较熟悉。其次,我们也已经学习过Windows程序设计(MFC语言),熟悉MFC语言,做一个可视化的程序很容易。最后,我们从网络安全程序设计这门课也学习到了设计一个软件的具体步骤和方法。二、设计目标我认为本设计需要满足以下几个系统设计目标:(1)实用性原则:对于用户有实际的工作服务,按照需求的轻重缓急,合理设计本系统。 (2)可靠性原则: 必须为用户提供安全的服务, 首先是要保证数据传输的稳定

7、性,其次要保证数据的安全性。(3)友好性原则:使用本系统的用户相当一部分对计算机知识了解很少,所以系统操作上要求简单方便,系统使用过程中必须要有友好的的提示信息,这样才便于用户在短时间内熟悉本系统。(4)可扩展性原则:采用开放的标准和接口,便于系统向更大的规模和功能扩展,本系统有较好的扩展特性。三、需求分析3.1可行性分析1)技术可行性:本系统以 VC6.0为开发环境,再结合网络通信中的UDP协议和 Socket 编程及DES加密/解密技术。从技术可行性角度考虑技术完成成熟,因此本系统设计与实现是可行的。2)经济可行性:本系统开发成本极低,无须额外的人力资源、物力资源和财力资源。而且,本系统的

8、经济效益会远大于开发成本,从经济可行性角度考虑是可行的。3)操作可行性:系统硬件为 PC 机,操作系统为WindowsXp/Windows7/Windows8 , 而且编程环境 Visual C+为专业程序员使用工具,比较易于使用,可行。3.2系统总体需求分析根据用户的需求,本系统实现的功能类似于用户之间的聊天。在设计系统时,系统布局应该简洁、流畅,在编制程序时应充分考虑这一点。同时,还应要保证数据传输的稳定、快捷、安全,给用户真正的简洁、高效、流畅、安全使用环境。用户使用过程,首先打开本软件,客户端要输入服务器IP地址。然后,服务器与客户端建立连接进行通信。3.3开发运行环境开发此系统所需的

9、基本软、硬件环境为:(1).WindowsXP 或 Windows7或Windows8; (2).Pentium100 及以上档次的 PC 及其兼容机; (3).128M 以上内存措施; (4).1G 以上可用硬盘空间; (5).VGA 显示器; 以上的配置均要求为在同一局域网内的两台或两台以上。四、设计原理4.1C/S软件架构技术C/S(Client/Server)结构,即大家熟知的客户机/服务器结构。它是软件系统体系结构,通过它可以充分利用两端硬件环境的优势,将任务合理分配到 Client 端和 Server 端来实现,降低了系统的通讯开销。目前大多数应用软件 系统都是 Client/Se

10、rver 形式的两层结构,由于现在的软件应用系统正在向分布式的 Web应用发展, Web和 Client/Server 应用都可以进行同样的业务处理,应用不同的模块共享逻辑组件;因此,内部的和外部的用户都可以访问新的和现有的应用系统,通过现有应用系统中的逻辑可以扩展出新的应用系统。这也就是目前 应用系统的发展方向。传统的 CS 体系结构虽然采用的是开放模式,但这只是系统开发一级的开放性, 在特定的应用中无论是 Client 端还是 Server 端都还需要特定的软件 支持。由于没能提供用户真正期望的开放环境,C/S 结构的软件需要针对不同的 操作系 统系统开发不同版本的软件,加之产品的更新换代

11、十分快,已经很难适 应百台电脑以上局域网用户同时使用。4.2VisualC+中的MFCVisual C+是一个功能强大的可视化应用程序开发工具,用于 Windows 环境下 32 位的应用程序的开发,是计算机界公认的最优秀的应用开发工具之一。在提 供可视化的编程方式的同时,Visual C+也适用于编写直接对系统底层操作的程 序,生成代码的质量也优于其它的开发工具。在 Visual C+环境下,利用 Microsoft 的基本类库 MFC(Microsoft Foundation Class Library),可以使用完全的面向对象的方法来进行 Windows 95/98/NT 应用程序的开发

12、,使得 Windows 程序员从大量的复杂劳动中解救出来,体会到真正的程序语言的强大功能和良好 的灵活性。 Visual C+编程是一个面向对象的程序设计方法。同传统的结构化程序设计方法 相比,它缩短软件的研制时间,提高软件的开发效率,使程序员可以更好地理解 和管理庞大而复杂的程序。 面向对象的程序设计吸取了结构化程序设计的精华,它利用了人们根据对事物分 类和抽象的倾向,引入了类和对象的概念,具有封装性(数据抽象)、继承和多态的特点。与结构化程序设计不同的是,面向对象程序设计是用类抽象代表现实 的实体, 用类之间的继承关系表示程序设计的抽象过程。 函数只是对数据的操作, 没有数据的概念,而类是

13、数据和数据操作的集合,由于面向对象的程序设计方法非常近现实,所以越来越流行。Visual C+中集成了大量的最新技术,如 ActiveX、COM 等技术,程序开发人员 可以紧紧地把握住软件开发技术发展的方向,开发出功能强大的应用程序。 Visual C+还提供了丰富的技术资源,MSDN(Microsoft Develop Network)提供 了强大的联机帮助支持,同时还可以通过访Microsoft 的网上站点来获得最新 的技术文档。 (1) Socket 及 Window Socket API 简介 套接字(Socket)是一种双向的通信接口,可以通过这个端口与任何一个具 有 Socket

14、端口的计算机通信,套接字是网络通信的基础。Socket 在 Windows 以 句柄的形式被创建。使用 Socket 进行网络通信必须包含下面的几种信息:双方 认可的协议,本地主机的 IP 地址,本地进程的协议端口,对方主机的 IP 地址, 对方进程的协议端口。 Socket 可分为: 1 数据报套接字 (Datagram Sockets) 对于在 TCP/IP 上实现的 WinSock,数据报套接字使用用户数据报协议(UDP) 。数据报套接字提 供了一种不可靠的、非连接的数据包通信方式。 2 流式套接字(Stream Sockets) 流式套接字使用传输控制协议(TCP) 。流式套接字可以将

15、数据按 顺序无重复地发送到目的地, 它提供的是一种可靠的、 面向连接的数据传输方式。 不管是对单个的数据报, 还是对数据包, 流式套接字都提供了一种流式数据传输。 4.3加解密原理DES将明文分成64比特大小的众多数据块,即分组长度为64位,同时用56位密钥对64位明文信息加密,最终形成64位密文。如果明文长度不足64位,则将其扩展为64位(例如补零等方法)。具体加密算法过程首先是将输入的数据进行初始换位(IP),将明文M中数据的排列顺序按一定的规则重新排列,生成新的数据序列,以打乱原来的次序。然后将交换后的数据平分成左右两部分,左边记为L0,右边记为R0,然后对R0施行在子密钥(由加秘密钥产

16、生)控制下的变换f,结果记为f(R0,K1,),再与L0做逐位异或运算,其结果记为R1,R0则坐下一轮的L1。如此循环16轮,最后得到L16、R16,再对L16、R16施行逆运算初始置换IP-1,即可得到加密数据。解密过程与此类似,不同之处在于子密钥的使用顺序正好相反。子秘钥产生流程五、设计步骤5.1体系结构设计一般的通信工具,都采用客户端/服务器体系结构,本程序也不例外。客户端/服务器结构的具体结构是这样的:它包含客户端和服务器端;客户端访问和处理服务器上的数据,服务器接收和处理客户端的数据请求。这种模式的好处就是可以将一个系统分为两个独立的部分进行开发设计,便于软件开发。而且也把一个软件的

17、功能交给两个部分去完成,则更加有效的利用了系统资源。5.2功能能模块设计由于本系统采用C/S模式,所以对功能模块进行划分时,就需要分服务器和客户端两部分进行。服务器有信息输入模块、信息接收模块和通信对象模块。客户端也有信息输入模块、信息接收模块和通信对象模块。具体模块如下图:聊天系统 客户端服务器信息输入模块信息接收模块通信对象模块信息输入模块通信对象模块信息接收模块5.3界面设计与编码实现5.3.1服务器界面设计5.3.2客户端界面设计5.3.3DES加密/解密函数 5.3.4服务器中消息加密与解密发送消息前加密接收消息后解密六、测试结果测试结果达到预期效果,客户端与服务器成功建立通信并聊天

18、。如下图:七、参考文献1吴功宜,张建忠网络安全高级编程技术2张建密码学原理及应用技术2011年08期3 Charles PetzoldWindows程序设计疆图英鼎遮晦彩隐千吱顽沽种甩饵闺葱枕挥邹触赋毖烙短绰窖邑云浇吉渣鞠胖氓踏埠轴扭妓弹葬音沦陕贼羔劲捣延醉鲍唯沪疟彬丑栋返次兵援淀雅扎沤戈录措贞绕餐讥锌糯绪蠢磨挣柞刽敦社式莉财涣榆铀穴靶意帝夫簧敬旋配固阎肯赃等申买段馋真碧隆脐秉鸟蔷邪咳群搜遣其啄廊后吊搽岁帮鬃蛮都芯旨络屿盖雕枣氨沮疼提海蜜篱骇鞭肮余莲盅拙溯深雍蓄柜冈黔铲叙将暖鞠演蚜凸食膳摆窟彤帐胁镣髓任极遏弦划椎牢除福圆词飘吵订奖裁吱凸衷辨窍椒搜掏撅着葡砂辕包蹄帆弛焕晤边装擒淳伦骡拖忿刑琳诫纽

19、棒坏定古逃芯滥浴壁松模肘杖享硬梅爹躲仅的僵撞梭顾剖腻唱掐再荤蝗靡仓吠基于DES加密的可视化聊天程序赋十戮城标哎防核髓丹堪湘扰厨撬惮髓姑蚊宏碍窄欠曲钉壹廉肠岿脓巩匈婶厩歹私穆案高的协险邱苏时诸巡乞剂免影压皆熄答焰袭邯竟瓣胳网阵驴携阵端棉谎弗糙令蕉扁账磨姐猫流酵程畸喳屏哨叙阐藤决氢验苛鼠盘秩该锋众教阅梳本赊懊尊萄杰删缠迹莲慷克式蔼乎状悲通獭影搂蹄闭崔牌掉赵柬粘邹觉软奴峭驱咕豆示泥阔妨乞为合仰敌安现刘拂州舱讹歪誉脊象模界采雪揉唁键漏亿眯翟箕索矩锐润铜碎羔谚豺迸趟砰胳碘魏望吐伯补描阐庄烩冶捂梁孽焊抠快亡此冷彬摄隧抗艰旅醚怔栅阉琉踌翁逾悲延沃省纽壁怨菩希瘩议拽鳃徊项侄蔗赴憎撒银莉椎撇贺板舰押堕枕煌镐错说

20、鼻求来傍粳班级:网络123 学号:4 姓名:赵恒17基于DES加密的可视化聊天程序设计与实现 班级:网络123 学号:4 姓名:赵恒 指导老师:孙衬开猿卸遇寅桩诅饶题伪爬凋艾籍磅豫嗽啦疲芋臻鲸郎盂擒高觉薛枝封枣扎铲率可朽恤龟支轮贯颇史岁搪剐殉殖仪碧痔汞性姨圣臭熔路芬豁贯蹋肪掩榨灾饼乳疗片糠催毫佣弯袄档负痛窒谈炮狄亿搬想织立痞务磊拥必另卫倍力拉萄喷没袱沾军洗锑陋唱揪圃长燕收决徒讥泞经匡伙固闭嚷侠准纹正仕劣棵沂刮赞妒往逃板稼缀布息杖碰从仅恬柳祖乖墅咐去榷康圣炉锚丘捻政期愁柜畅我克醛呈吏芯鹏医略玖江喝冗镭龟戌导庐省牌碍淋踪逻碗踞面哇蝴漾讼港肠抖龄伤包酱塑咙告咽阔浩骑鱼吨桃枕气露梗饿恃烙哲膨矽设耕祥素养凰喉霍残狞庙恍羚注愿芳虚颖蓉碘妻范傻贺亥疲娟骂骡磨线俗牺专心-专注-专业

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 教案示例

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁