java+vert.x实现内网穿透jrp-nat

news2025/7/16 19:10:16

用java vert.x开发一个内网穿透工具

  • 内网穿透概述
  • 技术原理
  • 常见内网穿透工具
  • 用java vert.x开发内网穿透工具 jrp-nat
    • 为什么用java开发内网穿透工具?
    • jrp-nat功能实现图解
    • jrp-nat内网穿透工具介绍
    • jrp-nat内网穿透工具特点
    • jrp-nat软件架构
    • jrp-nat安装教程
    • jrp-nat程序下载地址

内网穿透概述

内网穿透是一种通过技术手段实现外部网络访问内部局域网资源的技术,也称为NAT穿透。

内网穿透(NAT穿透)是指在没有公网IP的情况下,让处于不同局域网的设备能够直接通信,或将局域网内的服务暴露给互联网访问的技术。其核心目的是解决私有地址(如192.168.1.x等)无法在公网路由的问题,通过穿透NAT(网络地址转换)设备,实现内外网互联。

技术原理

主要依赖以下两种机制实现:

1.中继转发‌:通过公网服务器(如穿透工具的服务端)中转数据,将外部请求转发到内网服务。例如Ngrok、FRP等工具均采用此方式。

‌2.打洞技术(UDP Hole Punching)‌:利用NAT设备的端口映射规则,建立点对点直连通道。例如Go语言实现的UDP打洞方案中,双方通过信令服务器交换公网地址后,直接发送数据包触发NAT开放临时端口。

常见内网穿透工具

常见内网穿透工具有Ngrok、frp、NATAPP等。
‌Ngrok‌(go语言):简单易用的反向代理工具,提供免费域名映射。
‌FRP‌(go语言):开源的高性能内网穿透框架,支持自定义服务器。
‌NATAPP‌(go语言):国内商业化穿透服务,集成Web管理界面。

用java vert.x开发内网穿透工具 jrp-nat

为什么用java开发内网穿透工具?

做为一个javaer(开发人员),难免要远程访问服务或登录内网服务器(linux)。
使用远程工具(向日葵、toDesk)难免人多了抢着用;
使用Ngrok、frp、NATAPP等工具时,环境不是java的,总觉得安装使用费时间费力;
身为一个java开发人员认为java是万能的,系统运行环境也自带java,所以硬着头皮也必须要写一个简单实用的java版本内网穿透工具共享给javaers,基于websocket转发实现。

jrp-nat功能实现图解

在这里插入图片描述

jrp-nat内网穿透工具介绍

Java Reverse Proxy Network Address Translation,基于spring boot、vert.x开发的跨平台的内网穿透工具(jrp-server+jrp-Client),服务中转方式实现。

内网穿透工具包括服务端jrp-server和客户端jrp-Client,在先在有固定公网IP和开放对应端口的服务器上部署穿透服务中转程序jrp-server,然后在内网部署服务代理程序jrp-Client,后期支持通过可视化web配置页面或者配置文件管理配置。

jrp-nat内网穿透工具特点

在这里插入图片描述

  1. **跨平台好维护:**都通过java启动,装j有dk/jre 1.8+就可以运行,使用vert.x开发,代码量少好维护。
  2. **安全可靠:**服务注册有验证,外网访问代理服务也需要先通过用户名密码验证,可以根据需求快速修改验证功能。
  3. **部署简单:**部署只需3步:1.Linux、windows等系统上安装jdk或jre;2.修改配置文件;3.执行启动脚本运行程序。
  4. **使用便捷:**配置简单,客户端支持json文件方式配置穿透信息,穿透配置调整后,不需要重启客户端,客户端会自动重新注册,支持断线重连,可通过参数配置重连次数。

jrp-nat软件架构

软件架构说明 Spring Boot 2.7.14(运行控制、配置管理)+Vert.x 4.5.3(服务管理、服务代理、服务中转)+vue3(element ui实现web端管理配置信息,开发中)。

jrp-nat安装教程

  1. 安装jdk8+或jre8+

  2. 修改配置文件application.yml里vertx.jrp下参数:
    a. 内网穿透中转服务jrp-server配置(带独立外网ip和端口的服务器):

    vertx:
      jrp:
        #内网服务注册访问地址
        register-port: 2000
        #内网穿透中转服务web管理页面端口
        page-port: 10086
        #内网穿透中转服务web管理页面访问路径
        page-path: /jrp-server
        #内网穿透中转服务web管理页面登录用户名
        username: admin
        #内网穿透中转服务web管理页面密码
        password: 10010
        #http Digest认证算法
        algorithm: MD5
        #内网穿透服务注册验证信息,客户端需要和服务端一样,不然不能注册。
        token: 2023202
    

    b. 内网穿透客户端服务jrp-client配置(没有外网ip,能联网访问到带外网ip和端口服务器的局域网机器):

    vertx:
      jrp:
        #配置文件存储方式
        config-store-type: file
        #是否注册到内网穿透代理服务器
        register-to-server: true
        #内网穿透代理服务注册地址,外网ip和端口
        register-address: xxx.xxx.xxx.xxx:2000
        #内网穿透验证信息和jrp-server配置值一样,不然不能注册。
        token: 2023202
    
  3. 修改内网穿透客户端穿透代理配置参数config.json,通过java -jar jrp-client-1.0.0-SNAPSHOT.jar启动内网穿透客户端服务(一般是一台能联网的内网服务器,启动后修改配置不需要重启客户端,客户端会自动重新注册),目前主要支持HTTP、TCP:

     {
      "path": "/java-proxy",//代理服务配置管理服务HTTP访问路径
      "port": 2000,//代理服务配置管理服务HTTP访问端口
       "remote_proxies": [//内网穿透配置:内网服务注册到外网中转代理服务上实现内网穿透
        {
          "type": "HTTP",//穿透类型
          "remote_port": 2002,//穿透端口,外网中转代理服务代理后的服务端口
          "proxy_pass": "http://127.0.0.1:8001"//内网服务地址
        },
        {
          "type": "TCP",
          "remote_port": 2022,//穿透端口,外网中转代理服务代理后的服务端口
          "proxy_pass": "127.0.0.1:22"
        }
       ]
     }
    
  4. 穿透代理成功后,不管是http还是tcp代理成功后,得先通过浏览器HTTP方式访问外网ip端口,输入服务端配置的用户名密码认证信息,服务端重启后会要求重新输入认证信息。

  5. windows开机启动设置配置。

    打开文件夹“C:\ProgramData\Microsoft\Windows\Start Menu\Programs\StartUp”,start.bat脚本放到里面,start.bat示例脚本如下:

    chcp 65001
    cd D:\jrp-client
    D:
    java -server -Dfile.encoding=utf-8 -Dspring.config.location=./application.yml -jar jrp-client-1.0.0-SNAPSHOT.jar
    

    jrp-nat程序下载地址

    源码地址
    发布包地址

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2373495.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【程序员AI入门:应用开发】8.LangChain的核心抽象

一、 LangChain 的三大核心抽象 1. ChatModel(聊天模型) 核心作用:与大模型(如 GPT-4、Claude)交互的入口,负责处理输入并生成输出。关键功能: 支持同步调用(model.invoke&#xf…

每天五分钟机器学习:KTT条件

本文重点 在前面的课程中,我们学习了拉格朗日乘数法求解等式约束下函数极值,如果约束不是等式而是不等式呢?此时就需要KTT条件出手了,KTT条件是拉格朗日乘数法的推广。KTT条件不仅统一了等式约束与不等式约束的优化问题求解范式,KTT条件给出了这类问题取得极值的一阶必要…

Facebook的元宇宙新次元:社交互动如何改变?

科技的浪潮正将我们推向一个全新的时代——元宇宙时代。Facebook,这个全球最大的社交网络平台,已经宣布将公司名称更改为 Meta,全面拥抱元宇宙概念。那么,元宇宙究竟是什么?它将如何改变我们的社交互动方式呢&#xff…

概统期末复习--速成

随机事件及其概率 加法公式 推三个的时候ABC,夹逼准则 减法准则 除法公式 相互独立定义 两种分析 两个解法 古典概型求概率(排列组合) 分步相乘、分类相加 全概率公式和贝叶斯公式 两阶段问题 第一个小概率*A在小概率的概率。。。累计 …

n8n系列(1)初识n8n:工作流自动化平台概述

1. 引言 随着各类自动化工具的涌现,n8n作为一款开源的工作流自动化平台,凭借其灵活性、可扩展性和强大的集成能力,正在获得越来越多技术团队的青睐。 本文作为n8n系列的开篇,将带您全面了解这个强大的自动化平台,探索其起源、特性以及与其他工具的差异,帮助您判断n8n是否…

QT6 源(82):阅读与注释日历类型 QCalendar,本类并未完结,儒略历,格里高利历原来就是公历,

&#xff08;1&#xff09;本代码来自于头文件 qcalendar . h &#xff1a; #ifndef QCALENDAR_H #define QCALENDAR_H#include <limits>#include <QtCore/qglobal.h> #include <QtCore/qlocale.h> #include <QtCore/qstring.h> #include <QtCore/…

CVE体系若消亡将如何影响网络安全防御格局

CVE体系的核心价值与当前危机 由MITRE运营的通用漏洞披露&#xff08;CVE&#xff09;项目的重要性不容低估。25年来&#xff0c;它始终是网络安全专业人员理解和缓解安全漏洞的基准参照系。通过提供标准化的漏洞命名与分类方法&#xff0c;这套体系为防御者建立了理解、优先级…

OpenKylin安装Elastic Search8

一、环境准备 Java安装 安装过程此处不做赘述&#xff0c;使用以下命令检查是否安装成功。 java -version 注意&#xff1a;Elasticsearch 自 7.0 版本起内置了 OpenJDK&#xff0c;无需单独安装。但如需自定义 JDK&#xff0c;可设置 JAVA_HOME。 二、安装Elasticsearch …

【ARM AMBA AHB 入门 3 -- AHB 总线介绍】

请阅读【ARM AMBA 总线 文章专栏导读】 文章目录 AHB Bus 简介AHB Bus 构成AHB BUS 工作机制AHB 传输阶段 AHB InterfacesAHB仲裁信号 AHB 数据访问零等待传输(no waitstatetransfer)等待传输(transfers with wait states)多重传送(multipletransfer)--Pipeline AHB 控制信号 A…

多模态大模型中的视觉分词器(Tokenizer)前沿研究介绍

文章目录 引言MAETok背景方法介绍高斯混合模型&#xff08;GMM&#xff09;分析模型架构 实验分析总结 FlexTok背景方法介绍模型架构 实验分析总结 Emu3背景方法介绍模型架构训练细节 实验分析总结 InternVL2.5背景方法介绍模型架构 实验分析总结 LLAVA-MINI背景方法介绍出发点…

sqli-labs靶场第二关——数字型

一&#xff1a;查找注入类型&#xff1a; 输入 ?id1--与第一关的差别&#xff1a;报错; 说明不是字符型 渐进测试&#xff1a;?id1--&#xff0c;结果正常&#xff0c;说明是数字型 二&#xff1a;判断列数和回显位 ?id1 order by 3-- 正常&#xff0c; 说明有三列&am…

[模型选择与调优]机器学习-part4

七 模型选择与调优 1 交叉验证 (1) 保留交叉验证HoldOut HoldOut Cross-validation&#xff08;Train-Test Split&#xff09; 在这种交叉验证技术中&#xff0c;整个数据集被随机地划分为训练集和验证集。根据经验法则&#xff0c;整个数据集的近70%被用作训练集&#xff…

【计算机网络-数据链路层】以太网、MAC地址、MTU与ARP协议

&#x1f4da; 博主的专栏 &#x1f427; Linux | &#x1f5a5;️ C | &#x1f4ca; 数据结构 | &#x1f4a1;C 算法 | &#x1f152; C 语言 | &#x1f310; 计算机网络 上篇文章&#xff1a;传输层-TCP协议TCP核心机制与可靠性保障 下篇文章&#xff1a; 网络…

Kafka 与 RabbitMQ、RocketMQ 有何不同?

一、不同的诞生背景&#xff0c;塑造了不同的“性格” 名称 背景与目标 产品定位 Kafka 为了解决 LinkedIn 的日志收集瓶颈&#xff0c;强调吞吐与持久化 更像一个“可持久化的分布式日志系统” RabbitMQ 出自金融通信协议 AMQP 的实现&#xff0c;强调协议标准与广泛适…

【MATLAB源码-第277期】基于matlab的AF中继系统仿真,AF和直传误码率对比、不同中继位置误码率对比、信道容量、中继功率分配以及终端概率。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 在AF&#xff08;放大转发&#xff09;中继通信系统中&#xff0c;信号的传输质量和效率受到多个因素的影响&#xff0c;理解这些因素对于系统的优化至关重要。AF中继通信的基本架构由发射端、中继节点和接收端组成。发射端负…

webRtc之指定摄像头设备绿屏问题

摘要&#xff1a;最近发现&#xff0c;在使用navigator.mediaDevices.getUserMedia({ deviceId: ‘xxx’}),指定设备的时候&#xff0c;video播放总是绿屏&#xff0c;发现关闭浏览器硬件加速不会出现&#xff0c;但显然这不是一个最好的方案; 播放后张这样 修复后 上代码 指定…

2023年03月青少年软件编程(图形化)等级考试四级编程题

求和 1.准备工作 &#xff08;1&#xff09;保留舞台中的小猫角色和白色背景。 2.功能实现 &#xff08;1&#xff09;计算1&#xff5e;100中&#xff0c;可以被3整除的数之和&#xff1b; &#xff08;2&#xff09;说出被3整除的数之和。 标准答案&#xff1a; 参考程序&…

ensp的华为小实验

1.先进行子网划分 2.进行接口的IP地址配置和ospf的简易配置&#xff0c;先做到全网小通 3.进行ospf优化 对区域所有区域域间路由器进行一个汇总 对区域1进行优化 对区域2.3进行nssa设置 4.对ISP的路由进行协议配置 最后ping通5.5.5.5

ragflow报错:KeyError: ‘\n “序号“‘

环境&#xff1a; ragflowv 0.17.2 问题描述&#xff1a; ragflow报错&#xff1a;KeyError: ‘\n “序号”’ **1. 推荐表&#xff08;输出json格式&#xff09;** [{"},{},{"},{} ]raceback (most recent call last): May 08 20:06:09 VM-0-2-ubuntu ragflow-s…

FHE与后量子密码学

1. 引言 近年来&#xff0c;关于 后量子密码学&#xff08;PQC, Post-Quantum Cryptography&#xff09; 的讨论愈发热烈。这是因为安全专家担心&#xff0c;一旦有人成功研发出量子计算机&#xff0c;会发生什么可怕的事情。由于 Shor 算法的存在&#xff0c;量子计算机将能够…