`
jxxms
  • 浏览: 106923 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论
阅读更多

用UDP穿透NAT可以解决P2P软件中的两个通过NAT上网的客户端直接通信的问题。
需要一个中介来帮助找到对方。

Java代码如下:

UDPAgent.java:

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetSocketAddress;
import java.net.SocketAddress;
import java.util.regex.Pattern;


public class UDPAgent implements Runnable {

public static void main(String[] args) throws Exception {
  new UDPAgent(-1).start();
}

DatagramSocket ds;

byte[] recbuf = new byte[1024];

DatagramPacket rec = new DatagramPacket(recbuf, recbuf.length);

static String ipPattern = "([0-9]{1,3}.){3}[0-9]{1,3}";

static String portPattern = "[0-9]{1,5}";

static Pattern sendPattern = Pattern.compile("send " + ipPattern + " "
  + portPattern + " .*");

int port;

public UDPAgent(int port) {
  this.port = port;

}

public void init() throws Exception {
  if (port < 1024 || port > 655535) {
  ds = new DatagramSocket();
  } else {
  ds = new DatagramSocket(port);
  }
}

public void start() throws Exception {
  println("start");
  println("LocalPort:" + port);
  init();
  new Thread(this).start();// recive thread
  receive();
}

public void receive() {
  for (;;) {
  try {
  ds.receive(rec);
  String msg = new String(rec.getData(), rec.getOffset(), rec
  .getLength());
  String line = rec.getSocketAddress() + ":" + msg;
  println(line);
  onReceive(rec);
  } catch (Exception e) {
  e.printStackTrace();
  }
  }
}

public void onReceive(DatagramPacket rec) {

}

public void doCommand(String cmd) throws Exception {
  // command:
  // 1. send xxx.xxx.xxx.xxx xxx *******************
  if (sendPattern.matcher(cmd).matches()) {
  doSend(cmd);
  }
}

public void doSend(String cmd) throws Exception {
  println("CMD: " + cmd);
  String[] s = cmd.split(" ", 4);
  int port = Integer.parseInt(s[2]);
  InetSocketAddress target = new InetSocketAddress(s[1], port);
  byte[] bs = s[3].getBytes();
  doSend(target, bs);
}

public void doSend(SocketAddress addr, byte[] data) throws Exception {
  DatagramPacket pack = new DatagramPacket(data, data.length, addr);
  ds.send(pack);
}

public void run() {
  BufferedReader reader = new BufferedReader(new InputStreamReader(
  System.in));
  try {
  String line = reader.readLine();
  while (!"exit".equals(line)) {
  doCommand(line);
  line = reader.readLine();
  }
  System.exit(0);
  } catch (Exception e) {
  e.printStackTrace();
  }
}

public void println(String s) {
  System.out.println(System.currentTimeMillis() + ":" + s);
}
}


UDPClient.java


import java.net.DatagramPacket;
import java.net.InetAddress;
import java.net.InetSocketAddress;
import java.net.SocketAddress;

public class UDPClient extends UDPAgent {

/**
* @param args
*/
public static void main(String[] args) throws Exception {
  new UDPClient("www.javadoc.cn", 2008, -1).start();
}

String serverName;

int serverPort;

SocketAddress server;

public UDPClient(String host, int port, int localPort) {
  super(localPort);
  this.server = new InetSocketAddress(host, port);

}

public void start() throws Exception {
  println("start");
  init();
  register();
  new Thread(this).start();// recive thread
  receive();
}

public void onReceive(DatagramPacket rec) {
  try {
  report(rec);
  if (rec.getSocketAddress().equals(server)) {
  doCommand(new String(rec.getData(), rec.getOffset(), rec
  .getLength()));
  }
  } catch (Exception e) {
  e.printStackTrace();
  }

}

public void report(DatagramPacket rec) throws Exception {
  String s = rec.getSocketAddress()
  + new String(rec.getData(), rec.getOffset(), rec.getLength());
  byte[] buf = s.getBytes();
  ds.send(new DatagramPacket(buf, buf.length, server));
}

public void register() throws Exception {
  String msg = "register " + getLocalAddress() + " " + ds.getLocalPort();
  doSend(server, msg.getBytes());
}

public String getLocalAddress() throws Exception {
  InetAddress addr = InetAddress.getLocalHost();
  return addr.getHostAddress();
}
}

UDPServer.java



public class UDPServer extends UDPAgent {

public static void main(String[] args) throws Exception {
  new UDPServer(2008).start();
}

public UDPServer(int port) {
  super(port);
}
}

1。启动一个Server.

2。启动两个Client.

然后从Server端的Console里边可以看到两个Client的NAT后的地址和端口。

在Server段输入命令 send a.a.a.a A send b.b.b.b B hello

a.a.a.a是第一个Client的NAT后的ip,A端口号。

b是第二个。。。

输入这个命令后,A就会直接发给B一个 hello。 发送成功。 如果是同一个NAT后边,可能要让A发送到B的内网地址才能成功。

分享到:
评论

相关推荐

    P2P版M3U8解析源码1.2.1版.zip_P2P解析m3u8源码_m3u8 p2p解析_p2p加速m3u8接口_p2p视频解

    《P2P版M3U8解析源码1.2.1版》是一个针对M3U8视频流的P2P加速解决方案,旨在优化视频播放体验,提高数据传输效率。M3U8是一种用于存储多媒体播放列表的文件格式,常用于HTTP流媒体服务。在本项目中,P2P技术被巧妙地...

    P2P.zip_p2p VC

    【标题】"P2P.zip_p2p VC" 涉及的核心知识点是P2P(Peer-to-Peer)网络技术和VC++编程,主要聚焦在P2P网络中的打洞技术在网络编程中的应用。 P2P网络是一种分布式共享模型,其中每个节点既是服务的提供者也是消费者...

    《P2P技术揭秘P2P网络技术原理与典型系统开发》(管磊 编著)

    主要内容包括P2P概述、P2P网络拓扑结构、P2P网络搜索技术、P2P关键技术及应用、P2P网络中的nat穿透技术、基于P2P的bittorrent(后文简称bt)技术、基于P2P的emule文件共享技术、基于P2P的skype即时通信技术、基于P2P的...

    用JAVA实现P2P网络通信

    "用JAVA实现P2P网络通信" 本文将详细介绍如何使用JAVA实现P2P网络通信,分析P2P基本概念及其基本工作原理,并探讨了用JAVA实现p2p网络通信的技术。 一、P2P基本概念 P2P(Peer-to-Peer)模型是与C/S(客户/服务器...

    p2p.rar_P2P_P2P 文件传输_P2P文件传输_易语言p2p传输

    P2P(Peer-to-Peer)技术是一种网络通信模型,它打破了传统的客户端-服务器(Client-Server,C/S)架构,让网络中的每个参与者都可以同时作为客户端和服务器,互相分享资源和服务。这种技术最初应用于文件共享,如...

    原力P2P检测工具-需下载原力插件

    标题中的“原力P2P检测工具”是一个专门用于检测P2P网络的软件,它可能包含了一系列功能,如分析网络流量、识别P2P连接、监控带宽使用情况等。P2P(Peer-to-Peer)技术是互联网上一种分布式通信模型,允许网络上的...

    wifi_p2p分析

    ### Wi-Fi P2P技术概览与流程分析 #### Wi-Fi P2P基本概念 Wi-Fi P2P(Peer-to-Peer)技术是一项基于Wi-Fi的无线通信技术,旨在实现设备之间的直接通信,无需借助传统的接入点(Access Point, AP)。这种技术特别...

    p2p终结者3.5免费版

    《P2P终结者3.5免费版:网络流量管理利器》 P2P终结者3.5免费版是一款专为个人用户设计的网络流量管理工具,尤其在家庭和小型办公室环境中,它可以帮助用户有效控制局域网内的P2P(Peer-to-Peer)流量,避免个别...

    反p2p限制软件,防止有人限制

    标题 "反p2p限制软件,防止有人限制" 暗示了这是一个旨在解除或避免P2P(点对点)网络流量限制的工具。P2P技术常用于文件共享,如BitTorrent,但有时会被互联网服务提供商(ISP)或其他网络管理者限制,以避免网络拥塞...

    java简单实现p2p(看评论酌情下载)

    标题中的“java简单实现p2p”指的是使用Java编程语言实现一种简单的对等网络(Peer-to-Peer,简称P2P)系统。P2P网络是一种分布式网络架构,其中每个节点既是服务的提供者也是消费者,不同于传统的客户端-服务器模型...

    P2P超级搜索工具,好用

    标题中的“P2P超级搜索工具,好用”暗示了我们讨论的是一个基于P2P技术的高效搜索引擎。P2P(Peer-to-Peer)是一种网络架构,其中每个参与者既是客户端也是服务器,允许用户直接相互连接,共享资源,而不依赖中心...

    p2p源代码,点对点源代码demo

    点对点(P2P,Peer-to-Peer)技术是一种分布式网络架构,它允许网络中的节点直接通信,而无需通过中心服务器。P2P技术在众多领域有着广泛的应用,如文件共享、流媒体服务、区块链系统等。在这个“p2p源代码,点对点...

    基于Wireshark的P2P流量测量和分析

    ### 基于Wireshark的P2P流量测量与分析 #### 一、引言 随着互联网技术的发展,对等网络(Peer-to-Peer,简称P2P)技术因其高效性和灵活性而得到了广泛的应用。然而,P2P流量的特点往往会给网络带来额外的负载,...

    基于P2P的实时流媒体系统设计

    本课题讨论并研究的主要问题是,分析研究P2P技术及该技术下流媒体数据传输的应用,设计并实现一个基于P2P技术的传输服务系统。通过搭建P2P传输平台,研究流媒体数据的实时高效传输。1.研究P2P传输技术的相关理论,...

    深入理解Wi-Fi-P2P

    BSS 网络在结构上有许多相似之处,但P2P技术的创新在于它允许设备之间直接建立连接,无需依赖传统的接入点(AP)。这种技术对于设备间的直接通信,如无线显示(Wi-Fi Display/Miracast)或数据传输等应用场景具有...

    wpa_supplicant _ hostapd:Wi-Fi Direct-P2P模块.pdf

    文档还提到了一些主要的P2P操作函数,如p2p_find(), p2p_stop_find(), p2p_listen(), p2p_connect()等。 系统架构方面,P2P模块可以位于wpa_supplicant进程内部,与Linux/mac80211驱动程序配合使用,也可以位于内核...

    P2P网络技术原理与C++开发案例

    P2P网络技术是一种互联网通信模型,其中“P2P”代表点对点(Peer-to-Peer)。在P2P网络中,每个参与节点既可以作为客户端向其他节点请求数据,也可以作为服务器响应其他节点的请求。这种模式的优点在于不需要中央...

    p2p3.5绿色版

    【标题】"p2p3.5绿色版"所指的是一个基于P2P技术的搜索工具,名为p2pSearcher的3.5版本。这个版本被称为“绿色版”,通常意味着它无需安装,是一个便携式的软件,可以直接运行而不会在系统中留下任何痕迹。 【描述...

Global site tag (gtag.js) - Google Analytics