内网打洞以及代码实现

2019-03-15 15:32:09

UDP-NAT简介:

1.一个NAT端口必须对应唯一的(内网ip:port)。

假设内网的多个ip或者同一ip的不同port,都要访问同一个(外网ip:port)。对NAT来说,从外网接收的包它的(srcIp:srcPort)==(serverIp,serverPort),它的dstIp==natIp,所以NAT只能用dstPort来决定把这个包转发给哪一个(内网Ip:port)

2.根据下文,cone nat中,一个NAT端口对应多个(外网ip:port)。

NAT根据从外网接收的包的dstPort,查找(srcIp,srcPort)在不在该dstPort对应的外网(ip,port)中。在则转发给内网,不在则丢弃掉

3.示例代码中如何处理UDP包的丢失、延迟。

clientA向clienB发送消息时,打洞要三个包(clientA请求server,server请求clientB,clientB打洞),发消息要三个包(clientA发消息头,clientA发消息体,clientB发确认包),任何一个包都可能丢失。只要clientA没有收到确认包,clientA便重复以上过程;而server、clientB并不处理包丢失的情况,程序的逻辑相当简洁!


  • 2020-01-17 23:21:54

    webpack打包优化之外部扩展externals的实际应用

    使用vue-cli创建项目,使用webpack打包。其中,有一个webpack优化webpack.optimize.CommonsChunkPlugin,它会将node_modules中的必需模块提取到vendor文件中,项目开发中,增加第三方模块,比如element-ui、vue-echarts等,vendor的包都会增大。这个时候,就需要考虑减轻vendor包的大小,增加构建速度。我们可以使用webpack的外部扩展(externals)功能。

  • 2020-01-18 01:26:59

    anyProxy使用注意事项

    anyproxy-ca 运行这个命令,如果是mac电脑他会提醒你去通过证书。

  • 2020-01-18 08:54:06

    利用localStorage来处理你的Javascript脚本错误

    localStorage作为HTML5中的新特性,它的出现可以说对于前端性能体验来讲可以获得相当大的改善。存储一些用户经常用到而又不是涉及隐私和安全的东西,的确是一个非常好的选择。下面分享一下用localStorage来处理客户端代码错误的例子来了解一下它的用途吧。

  • 2020-01-20 08:29:14

    js如何生成唯一标识符UUID

    在JavaScript中生成uuid的代码如下,这个函数会直接给你返回uuid,所以直接调用,然后用变量接收即可!