警告:虽然此项目已大致可用,但我们不为其bug或稳定性问题承担任何后果。此软件所包含的某些工具包可能会被一些组织视为违反网络安全条例,您自行承担使用此工具带来的一切后果
- 实现穿透一切任意一方直接具有公网IP的网络
- 实现穿透一切任意一方具有UPnP支持的网络环境的NAT
- 实现穿透一切任意一方为全锥型NAT的网络环境
- 尽最大努力穿透任意一方为限制型NAT甚至对称型NAT
- 穿透成功后,提供可靠的流式传输(STREAM)和不可靠的报文传输(DGRAM)功能
- 穿透成功后,对流式传输提供安全传输功能
- 提供具有TCP和UDP端口转发功能的CLI的Daemon程序 (尽管不可能直接进行TCP打洞,但是可以在打通的UDP链路上运行可靠的传输协议)
- 跨操作系统平台支持,应至少支持Linux、Windows。可选支持 Android和macOS
- 跨CPU架构支持,应至少支持x86-64和AArch64架构的CPU
- 同时支持小数据量和大数据量传输,对于不同数据量采取不同的传输策略。例如,小数据量传送可以考虑在P2P链路建立前直接通过中转服务器发出,而大数据量传送则应等待链路建立后再进行传送。
- 国产信创平台支持,能够部署到国产操作系统和CPU上——信创产业学院设备提供支撑
- GPL 开源 & 自由 & 免费
本程序也可以当作去中心化 VPN 使用。
强烈建议使用 Docker 镜像 一键安装
docker pull kenvix/natpoked
docker-compose up -d
为确保兼容性,应使用 Java11 编译,但应在 Java17 平台上运行,就像 Dockerfile
里写的一样。
git submodule update --init --recursive
chmod +x ./gradlew
./gradlew shadowJar
git submodule update --init --recursive
chmod +x ./DockerBuild.sh
./DockerBuild.sh