STUN:Simple Traversal of User Datagram Protocol (UDP)
Through Network Address Translators (NATs)
stun是一个用于UDP NAT打洞的协议,注意是UDP,不是TCP,UDP NAT通常有以下四种,但是stun只适用于前三种:
1) Full Cone
这种NAT内部的一台机器A连接过外网机器C后,NAT会打开一个端口.然后外网的任何发到这个打开的端口的UDP数据报都可以到达A.不管是不是C发过来的.
例如 A:192.168.8.100 NAT:202.100.100.100 C:292.88.88.88
A(192.168.8.100:5000) -> NAT(202.100.100.100:8000) -> C(292.88.88.88:2000)
任何发送到 NAT(202.100.100.100:8000)的数据都可以到达A(192.168.8.100:5000)
2) Address Restricted Cone
这种NAT内部的一台机器A连接过外网的机器C后,NAT打开一个端口.然后C可以用任何端口和A通信.其他的外网机器不行.
例如 A:192.168.8.100 NAT:202.100.100.100 C:292.88.88.88
A(192.168.8.100:5000) -> NAT(202.100.100.100 : 8000) -> C(292.88.88.88:2000)
任何从C发送到 NAT(202.100.100.100:8000)的数据都可以到达A(192.168.8.100:5000)
3) Port Restricted Cone
这种NAT内部的一台机器A连接过外网的机器C后,NAT打开一个端口.然后C可以用原来的端口和A通信.其他的外网机器不行.
例如 A:192.168.8.100 NAT:202.100.100.100 C:292.88.88.88
A(192.168.8.100:5000) -> NAT(202.100.100.100 : 8000) -> C(292.88.88.88:2000)
C(202.88.88.88:2000)发送到 NAT(202.100.100.100:8000)的数据都可以到达A(192.168.8.100:5000)
以上三种NAT通称Cone NAT(圆锥形NAT).我们只能用这种NAT进行UDP打洞.
4) Symmetric(对称形)
对于这种NAT。连接不同的外部Server,NAT打开的端口会变化。也就是内部机器A连接外网机器B时,NAT会打开一个端口,连接外网机器C时又会打开另外一个端口
另外可以参考RFC3489中的NAT Variations部分关于这四种nat的解释,英文可能解释的更明白http://www.ietf.org/rfc/rfc3489.txt
参考:
http://www.cnblogs.com/whyandinside/archive/2010/12/08/1900492.html
http://en.wikipedia.org/wiki/STUN
NAT穿越方式:
NAT/ALG 方式
MIDCOM 方式
STUN 方式
TURN方式
ICE方式
参考:http://baike.baidu.com/view/1580678.htm
分享到:
相关推荐
stunserver 的客户端源码,已经裁剪和移植到android系统,编译和测试已经通过,如果编译不过,只需要改下mk文件就可以了,用于nat穿越和检测
非常好的学习stun/turn/ice NAT穿越资料
免费的服务器,stun,内网穿透用,比较全了,有的地方封,大家多尝试
关于nat穿越研究的一篇文章。分享一下。
基于STUN协议的NAT路由器穿越算法设计与实现.pdf
NAT穿越服务器概要设计 编写目的 多媒体会话信令协议是在准备建立媒体流传输的代理之间交换信息的协议,例如SIP...本文档描述基于STUN/TURN协议解决穿越NAT的NAT穿越服务器(Nat Traversal Server)的概要设计说明书。
P2P技术的NAT穿越方案,需要针对上述的4种NAT类型使用不同的方案,才有可能打洞(穿墙)成功,而最在要紧的是,我该怎么知道目前某台客户端所处的路由属于哪种NAT类型呢?
非常详细的NAT穿越技术,写的不错,有实用性。
c++ 实现P2P网络中NAT的UDP穿越的客户端功能和STUN服务器功能
基于STUN的SIP穿越非对称型NAT,杨伟,, NAT(Network Address Translator)打破了IP网络的端到端的特性,使得大量的IP应用(尤其是多媒体的应用)无法在IP网上使用。为了减小NAT设备对IP网
介绍了网络地址转换(NAT)的基本原理,及穿越的几种方法。
NGN网络最大的好处就是能为用户提供丰富的业务,但是像H.323、SIP、MGCP、H....本文主要探讨了NGN软终端和IAD的NAT问题,介绍了ALG、MidCom、STUN、协议修改、Proxy等几种私网穿越方法,并分析了方案的可行性和适用性
pjsip, PJSIP是开源 SIP,媒体和NAT穿越库 PJSIPPJSIP是一个免费的开源多媒体通信库,用C 语言编写,实现了 SIP 。SDP 。RTP 。STUN 。TURN和ICE等标准协议。特性支持的平台:iOS8 支持的体系结构:armv7.armv7s 。...
java stun 实现nat穿越及功能开发包。另:stun4j后续项目是ice4j
分析了H.323协议在穿越NAT时遇到的几个主要问题,并对比了不同的解决方法,给出了一种相对可靠有效的解决方案;同时以OpenH.323和GNUGK为例,给出了具体的实现方法。
一、NAT介绍 二、NAT分类 1.完全锥形NAT(Full Cone) 2.受限制锥形(Restricted Cone) 3.端口受限制锥形(Port Restricted Cone) 4.对称类型(Symmetric) 三、STUN协议 四、UDP Hole Punching技术
Stun4j 是 Java 程序实现 NAT 穿越的一种方案。是对 STUN 协议(RFC3489)的Java实现。
网上的原理很多,代码很少,好用的更少,多数都有问题,这个代码是我根据网上的代码修改的,保证好用。还有一些代码是我整理的stun资料。
STUN(Simple Traversal of UDP over NATs,NAT 的UDP简单穿越)是一种网络协议,它允许位于NAT(或多重NAT)后的客户端找出自己的公网地址,查出自己位于哪种类型的NAT之后以及NAT为某一 个本地端口所绑定的...