NAT穿越技术研究及实现.docVIP

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
NAT穿越技术研究及实现.doc

NAT穿越技术研究及实现   摘要:该文根据NAT技术的基本概念、工作原理和分类及其在当前网络环境中的应用,分析了当前网络环境中广泛存在的NAT设备对P2P通信的影响,最后实现利用C#语言实现了一个基于UDP穿越技术的P2P聊天软件系统。   关键词:NAT穿越;P2P网络;UDP封装打洞   中图分类号:TP393 文献标识码:A 文章编号:1009-3044(2013)27-6104-02   在目前IPV4的网络环境中,由于IP地址的缺乏,NAT技术获得了广泛的应用,NAT技术可以节省IPV4 地址资源,缓解IP 地址资源短缺的问题,同时能起到类似防火墙的保护内网的作用。但是NAT术的使用会使处于不同内网的主机之间的通讯带来了障碍,主要体现在NAT对P2P网络的影响,限制了P2P网络的应用。本文根据NAT(Network Address Translator)技术的基本概念、工作原理和分类及其在当前网络环境中的应用,分析了当前网络环境中广泛存在的NAT设备对P2P(Peer-to-Peer)通信的影响,最后实现利用C#语言实现了一个基于UDP穿越技术的P2P聊天软件系统。该系统包括Server和Client两个客户端,通过模拟现实中的网络,使Server端和Client端处于不同网段中,处于不同私网中的主机通过Server的连接,完成NAT穿越,Client可以进行即时对等通信。   1 NAT概述   NAT的英文全称是Network Address Translation,翻译为:网络地址转换或者网络地址翻译。NAT是在IPv4地址短缺的情况下产生的一种新技术,主要目的就是为了能够重用IP地址。Windows操作系统中用于多台主机共享上网的“Internet连接共享”使用的就是NAT技术;很多即时信息系统如ICQ、MSN、以及QQ等是最流行的P2P 应用,其他还有P2P 文件共享程序都用到了NAT穿越技术。NAT技术的主要原理是:通过将局域网上的主机地址映射为Internet上的P地址,从而实现了网络地址的复用。NAT技术可以隐藏了内部网络地址信息,保护内部网络;同时也可以暂时解决IPv4 地址分配的限制,从而合理地安排网络中公有IP 地址和私有IP 地址的使用,使NAT 在防火墙中得到了广泛的应用。   2 基于NAT穿越的实现   2.1 系统结构图   在系统中主要实现了服务器端和客户端;服务器端处于公网中,IP地址使用全局IP地址,主要用于连接客户端,为客户端服务;客户端处于私有网络中,IP地址使用私有IP地址;如图1系统结构图所示。   当服务器客户端开启后,用户A和B客户端可以进行连接服务器,连接成功后服务器S记录下客户(例如A、B等)多个客户端的IP地址和端口号;用户客户端上记录下连接服务器S的每个私有网络用户IP地址和端口号;用户客户端可以选择其中任意用户进行即时通信交流。   系统结构图体现了最常见的NAT穿越环境,一般的还有主机在相同NAT后面以及主机由多个NAT分开这两种情况下各主机的对等通信、即时通信交流。   2.2 系统运行环境   1)根据系统结构图可以得知,系统的运行环境分三部分,需要用2个连到公网上的局域网,1台具有公网地址的电脑,如果不是这样的环境,程序执行可能会不正常。   2)准备好环境(例如有两个连接到公网上的局域网)之后做以下就绪工作:   (1)在广域网的电脑上执行服务器端的“WindowsApplication1.exe”程序,假设这台电脑的公网IP地址是:“200.200.1.100”。   (2)在局域网A中的一台电脑上执行客户端“WindowsApplication2.exe”程序,假设这台电脑的私有网络IP地址是:“192.168.1.2”。   (3)在局域网B中的一台电脑上执行客户端“WindowsApplication2.exe”程序,假设这台电脑的私有网络IP地址是:“192.168.2.2”。   程序执行成功后的界面:连接成功后服务器S记录下客户(例如A、B等)多个客户端的IP地址和端口号;用户客户端上记录下连接服务器S的每个私有网络用户IP地址和端口号;此时表示穿越NAT的UDP连接已经建立起来,即时的通信交流就可以开始。   2.3 实现穿越过程   系统在VS2010环境下利用C#语言实现UDP打洞技术穿越NAT,以达到在不同NAT后面以及主机由多个NAT分开三种情况下各主机的对等通信、即时通信交流;系统设计中主要实现了UDP打洞技术的NAT穿越,并且实现了服务器端和客户端界面。   当服务器开启后,客户端就可以连接服务器,连接成功后CA与CB都可以与Server S通信。此时CA还不能使用该公

文档评论(0)

guan_son + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档