百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

通过Python实现内网穿透的几种方式?

itomcoil 2024-12-23 11:08 30 浏览

所谓的内网穿透,其实就是一种将私有网络与外部网络之间来建立连接的一种技术,主要的作用就是将内部网络中的服务暴露到外部网络中进行访问,或者是在外部网络中使得用户能够访问到内部网络中的资源,通过这种方式来实现内部网络与外部网络之间的灵活访问。可以帮助用户实现远程访问、远程调试、数据共享管理等,可以有效的提升工作效率。下面我们就来看看在Python中如何搭建一个简单的内网穿透服务。

通过Pyngrok来实现

在Python中实现内网穿透通常可以使用一些第三方的工具库来实现,例如可以使用pyngrok库来与Ngrok来建立服务通信。如下所示。

首先需要通过如下的命令来安装相关的库。

pip install pyngrok

代码实现如下所示。

from pyngrok import ngrok

# 创建一个 Ngrok 隧道
ngrok_tunnel = ngrok.connect(5000, "http")

# 获取公共访问 URL
public_url = ngrok_tunnel.public_url
print("公共访问 URL:", public_url)

# 保持程序运行
input("按 Enter 键退出程序...\n")

# 关闭 Ngrok 隧道
ngrok.disconnect(ngrok_tunnel.public_url)

运行这段代码之后,会在本地启动一个HTTP的服务器,端口号为5000,。然后通过Ngrok来建立一个通道,将本地的服务器映射到一个公共的可访问的URL上,然后用户就可以通过这个URL来访问到本地的HTTP服务。

但是需要注意的是,Ngrok免费版提供的服务可能会有一定的限制,例如对于带宽的限制,对于连接时长的限制,如果需要更加高级的版本可以考虑Ngrok的付费版本,或者是可以使用其他的内网穿透工具。

当然,也可以靠Python的其他内网穿透实现库,例如localtunnel、serveo等。这些库也提供了类似的内网穿透功能。

通过Localtunnel来实现

当然我们也可以通过LocalTunnel实现内网穿透,通过这个库可以使得在本地运行的服务器能够通过LocalTunnel提供的公共URL进行访问。以下是使用localtunnel库来实现的一个内网穿透小工具。

首先需要安装相关的库,如下所示。

pip install localtunnel

编写代码

from localtunnel import LTHTTPServer

# 本地 HTTP 服务器的地址和端口
local_host = "127.0.0.1"
local_port = 8000

# 创建 LocalTunnel 服务器
with LTHTTPServer(local_host, local_port) as server:
    # 获取隧道 URL
    tunnel_url = server.tunnel_url
    print("隧道 URL:", tunnel_url)

    # 保持程序运行
    input("按 Enter 键退出程序...\n")

这段代码会在本地启动一个HTTP服务器(默认端口号为 8000),然后通过LocalTunnel创建一个隧道,将本地服务器映射到一个公共可访问的URL上。用户可以通过访问该URL来访问本地的HTTP服务器。

与Ngrok类似,LocalTunnel也可能有一些限制和缺点,如连接不稳定、带宽限制等。因此,在选择内网穿透服务时,需要根据实际需求和情况选择合适的方案。

通过serveo来实现内网穿透

下面我们来看一下,通过Serveo实现内网穿透,需要用到ssh模块来建立SSH连接,并利用Serveo提供的服务将本地服务器暴露到公共网络。以下是使用 ssh 模块的示例代码

import subprocess
import sys
import random
import string

def generate_random_subdomain():
    """生成随机子域名"""
    return ''.join(random.choices(string.ascii_lowercase + string.digits, k=6))

def establish_tunnel(local_host, local_port):
    """建立 SSH 隧道"""
    subdomain = generate_random_subdomain()
    serveo_url = f"{subdomain}.serveo.net"
    ssh_command = f"ssh -R {subdomain}:80:{local_host}:{local_port} serveo.net"

    # 启动 SSH 进程
    try:
        subprocess.run(ssh_command, shell=True, check=True)
    except subprocess.CalledProcessError as e:
        print("Error:", e)
        sys.exit(1)

    return serveo_url

# 本地 HTTP 服务器的地址和端口
local_host = "127.0.0.1"
local_port = 8000

# 建立 Serveo 隧道
serveo_url = establish_tunnel(local_host, local_port)
print("Serveo URL:", serveo_url)

# 保持程序运行
input("按 Enter 键退出程序...\n")

上述代码,通过SSH建立一个反向隧道,将本地服务器(默认端口号为 8000)映射到Serveo提供的公共URL上。用户可以通过访问该URL来访问本地的HTTP服务器。

Python 通过Ngrok来代理Spring Boot的接口到公网上?

要通过Ngrok将Spring Boot接口代理到公网上,我们可以使用subprocess模块来启动Ngrok并建立连接,然后将应用程序的端口映射到Ngrok提供的公网地址上就可以实现Spring Boot的接口被外网访问了。代码实现如下所示。

import subprocess
import sys
import requests

def start_ngrok(local_port):
    """启动 Ngrok 并建立连接"""
    ngrok_process = subprocess.Popen(['ngrok', 'http', str(local_port)], stdout=subprocess.PIPE, stderr=subprocess.PIPE)
    ngrok_url = None

    # 读取 Ngrok 输出中的公网地址信息
    while True:
        line = ngrok_process.stdout.readline().strip().decode("utf-8")
        if "Forwarding" in line:
            ngrok_url = line.split(" ")[1]
            break

    return ngrok_url, ngrok_process

def main():
    """主函数"""
    # Spring Boot 应用程序的本地端口
    local_port = 8080

    # 启动 Ngrok
    ngrok_url, ngrok_process = start_ngrok(local_port)

    if ngrok_url:
        print("Ngrok 地址:", ngrok_url)

        try:
            # 测试访问 Ngrok 提供的公网地址
            response = requests.get(ngrok_url)
            print("Ngrok 测试结果:", response.text)
        except Exception as e:
            print("Ngrok 测试失败:", e)
            sys.exit(1)

        # 保持程序运行
        input("按 Enter 键退出程序...\n")

        # 结束 Ngrok 进程
        ngrok_process.terminate()
    else:
        print("无法获取 Ngrok 地址")
        sys.exit(1)

if __name__ == "__main__":
    main()

在这个代码中,我们通过使用subprocess模块来启动一个Ngrok,然后监听Spring Boot 应用程序的本地端口。从Ngrok输出中读取公网地址信息,并使用requests库测试访问Ngrok 提供的公网地址。

相关推荐

selenium(WEB自动化工具)

定义解释Selenium是一个用于Web应用程序测试的工具。Selenium测试直接运行在浏览器中,就像真正的用户在操作一样。支持的浏览器包括IE(7,8,9,10,11),MozillaF...

开发利器丨如何使用ELK设计微服务中的日志收集方案?

【摘要】微服务各个组件的相关实践会涉及到工具,本文将会介绍微服务日常开发的一些利器,这些工具帮助我们构建更加健壮的微服务系统,并帮助排查解决微服务系统中的问题与性能瓶颈等。我们将重点介绍微服务架构中...

高并发系统设计:应对每秒数万QPS的架构策略

当面试官问及"如何应对每秒几万QPS(QueriesPerSecond)"时,大概率是想知道你对高并发系统设计的理解有多少。本文将深入探讨从基础设施到应用层面的解决方案。01、理解...

2025 年每个 JavaScript 开发者都应该了解的功能

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发。1.Iteratorhelpers开发者...

JavaScript Array 对象

Array对象Array对象用于在变量中存储多个值:varcars=["Saab","Volvo","BMW"];第一个数组元素的索引值为0,第二个索引值为1,以此类推。更多有...

Gemini 2.5编程全球霸榜,谷歌重回AI王座,神秘模型曝光,奥特曼迎战

刚刚,Gemini2.5Pro编程登顶,6美元性价比碾压Claude3.7Sonnet。不仅如此,谷歌还暗藏着更强的编程模型Dragontail,这次是要彻底翻盘了。谷歌,彻底打了一场漂亮的翻...

动力节点最新JavaScript教程(高级篇),深入学习JavaScript

JavaScript是一种运行在浏览器中的解释型编程语言,它的解释器被称为JavaScript引擎,是浏览器的一部分,JavaScript广泛用于浏览器客户端编程,通常JavaScript脚本是通过嵌...

一文看懂Kiro,其 Spec工作流秒杀Cursor,可移植至Claude Code

当Cursor的“即兴编程”开始拖累项目质量,AWS新晋IDEKiro以Spec工作流打出“先规范后编码”的系统工程思维:需求-设计-任务三件套一次生成,文档与代码同步落地,复杂项目不...

「晚安·好梦」努力只能及格,拼命才能优秀

欢迎光临,浏览之前点击上面的音乐放松一下心情吧!喜欢的话给小编一个关注呀!Effortscanonlypass,anddesperatelycanbeexcellent.努力只能及格...

JavaScript 中 some 与 every 方法的区别是什么?

大家好,很高兴又见面了,我是姜茶的编程笔记,我们一起学习前端相关领域技术,共同进步,也欢迎大家关注、点赞、收藏、转发,您的支持是我不断创作的动力在JavaScript中,Array.protot...

10个高效的Python爬虫框架,你用过几个?

小型爬虫需求,requests库+bs4库就能解决;大型爬虫数据,尤其涉及异步抓取、内容管理及后续扩展等功能时,就需要用到爬虫框架了。下面介绍了10个爬虫框架,大家可以学习使用!1.Scrapysc...

12个高效的Python爬虫框架,你用过几个?

实现爬虫技术的编程环境有很多种,Java、Python、C++等都可以用来爬虫。但很多人选择Python来写爬虫,为什么呢?因为Python确实很适合做爬虫,丰富的第三方库十分强大,简单几行代码便可实...

pip3 install pyspider报错问题解决

运行如下命令报错:>>>pip3installpyspider观察上面的报错问题,需要安装pycurl。是到这个网址:http://www.lfd.uci.edu/~gohlke...

PySpider框架的使用

PysiderPysider是一个国人用Python编写的、带有强大的WebUI的网络爬虫系统,它支持多种数据库、任务监控、项目管理、结果查看、URL去重等强大的功能。安装pip3inst...

「机器学习」神经网络的激活函数、并通过python实现激活函数

神经网络的激活函数、并通过python实现whatis激活函数感知机的网络结构如下:左图中,偏置b没有被画出来,如果要表示出b,可以像右图那样做。用数学式来表示感知机:上面这个数学式子可以被改写:...