如何在其他终端访问本地部署的flask软件-ngrok实现内网穿透

博主用flask开发了一个软件,但是使用本地服务器时,局域网外的设备都不能访问,而且如果是连的是有防火墙的校园网,连局域网内部都不可访问。于是在网上找了一些教程,希望能通过公网访问。兜兜转转一大圈,还特地去下载了一个streamlit,测试成功了才发现好像根本用不上。。为了避免小伙伴们走弯路,这里简单分享一下【如何在其他终端公网访问本地部署的flask软件】

1.实现局域网内部访问

选中配置,进行编辑。

可以看到,没有配置环境变量时,系统没有开启debug mode,URL也只有一个。

FLASK_RUN_HOST=0.0.0.0;FLASK_DEBUG=1

在环境变量中输入上述命令,

FLASK_RUN_HOST=0.0.0.0
指定 Flask 应用运行时监听的主机地址。
0.0.0.0 表示监听所有可用的网络接口,这样你的应用可以通过网络被访问(例如在本地网络或通过服务器的公网 IP 访问)。
如果设置为 127.0.0.1 或 localhost,则只能在本地计算机上访问。

FLASK_DEBUG=1
启用 Flask 的调试模式。
1 表示启用调试模式,这会自动开启 Flask 的调试工具,例如显示交互式调试器(Debug Toolbar),方便开发时调试代码。

配置了环境变量后再运行flask可以看到debug模式开启,有两个URL,172的可以被局域网访问(可以开一个热点用手机访问一下)

增加两个注意事项,是我之前踩坑过的。

一个是,可能你在代码文件中有一些自定义配置,比如设定host,port,或者debug模式,但是运行的时候发现还是没有改变。原因是,环境变量的优先级不同,环境变量会覆盖代码中的设置。比如下面这张图,设置了port为3600,而软件监听的仍然是5000.

所以如果要改的话,在优先级高的环境变量中修改,FLASK_RUN_PORT=3600.

第二个是,新版的Pycharm 专业版和以前的配置界面有所不同,开启debug模式是通过右上角的修改选项,选中flask调试,左下角会自动出现一个“flask调试 x”。当然你要直接在环境变量E中用命令也行。

2.ngrok实现公网访问

这里参考了大佬的文章:Ngrok快速将你的本地Streamlit应用创建一个公共的 URL,供外网访问_stremlit ngrok-优快云博客

先去官网(ngrok - Online in One Line)下载ngrok,然后申请你的token。

可以用cmd命令添加

ngrok config 【你的token】

也可以找到文件,手动粘贴(ngrok文件夹下)

配置之后,在cmd运行代码

ngrok http 5000 

如果你的端口是3600,那么运行3600

得到一个URL,复制粘贴给局域网外的用户,就可以访问了

3.多路由访问

在URL最后添加自己的子路由,就可以访问不同的网页啦

<think>嗯,用户的问题是关于如何配置ngrok允许外部访问,而不仅仅是本地访问。首先,我需要回顾一下ngrok的基本工作原理。ngrok通过创建隧道将本地端口映射到公网地址,这样外部用户就可以通过这个公网地址访问本地服务了。根据用户提到的引用资料,特别是引用[1]、[2]、[3]、[4],ngrok默认情况下应该已经允许外部访问了,因为它的主要目的就是内网穿透,让外网能访问本地服务。 但用户提到“仅限本地访问”,这可能意味着配置过程中出现了问题。首先,我需要考虑可能的原因。常见问题可能包括防火墙或安全软件阻止了外部连接,或者ngrok配置不正确,比如没有正确指定允许的主机头,或者本地服务本身只绑定到了localhost而不是0.0.0.0。 根据引用[3],ngrok的配置相对简单,但有时候可能需要调整参数。例如,使用`-host-header`参数来重写主机头,或者使用`-hostname`指定自定义域名。另外,本地服务如果只监听127.0.0.1,那么即使ngrok正确映射,外部请求也无法到达应用,因此需要确保本地服务绑定到0.0.0.0。 另外,引用[2]提到ngrok可以将本地端口映射到公网,但需要确保隧道配置正确。可能需要检查ngrok的启动命令是否正确,比如端口号是否正确,是否使用了正确的认证token(如果有的话)。此外,免费版的ngrok可能有一些限制,比如每次重启后域名会变化,或者并发连接数的限制,但不会限制外部访问本身。 可能的解决步骤包括:检查本地服务绑定地址、配置防火墙、使用正确的ngrok参数、检查网络设置是否阻止了外部流量,以及验证ngrok的隧道状态。此外,用户可能需要升级到付费计划以获得更稳定的域名或更多功能,如引用[4]提到的可能需要自定义域名来避免变动。 总结下来,解决方案应该分步骤指导用户检查本地服务配置、ngrok命令参数、防火墙设置,以及如何验证配置是否成功。同时,引用相关文档中的信息来支持每一步的建议,比如引用[3]提到的命令行操作简便性,引用[2]的安全远程访问特性,以及引用[1]中关于内网穿透的基本原理。</think>### 分步解决方案:配置 ngrok 允许外部访问 #### **1. 确认本地服务已正确绑定** - **问题**:本地服务可能仅绑定到 `127.0.0.1`(仅限本机访问),导致外部请求无法穿透到应用。 - **解决**: 修改服务配置,使其绑定到 `0.0.0.0`(监听所有网络接口)。例如: ```python # Flask 示例 app.run(host='0.0.0.0', port=5000) ``` 其他框架(如 Node.js、Django)同理,需设置 `host` 参数为 `0.0.0.0`[^1]。 --- #### **2. 使用 ngrok 正确映射端口** - **命令示例**: ```bash ngrok http 5000 --host-header="localhost:5000" ``` - `http 5000`:将本地 5000 端口映射到公网。 - `--host-header="localhost:5000"`:重写请求头,解决服务对域名或端口的校验问题[^2][^3]。 --- #### **3. 检查防火墙或安全软件** - **问题**:本地防火墙或杀毒软件可能阻止外部流量。 - **解决**: - 临时关闭防火墙测试(仅限调试): ```bash # Windows netsh advfirewall set allprofiles state off # Linux sudo ufw disable ``` - 永久方案:在防火墙中添加规则,允许 `ngrok` 进程和本地服务端口(如 5000)的入站流量。 --- #### **4. 使用自定义域名(增强稳定性)** - **问题**:免费版 ngrok 的域名会动态变化,可能导致外部访问中断。 - **解决**: 1. 注册 ngrok 账号并获取认证 Token。 2. 保留固定域名(付费功能): ```bash ngrok authtoken <YOUR_TOKEN> ngrok http 5000 --subdomain=yourname --region=us ``` 此时外部可通过 `https://yourname.ngrok.io` 稳定访问[^4]。 --- #### **5. 验证外部访问** - 通过 `curl` 或浏览器访问 ngrok 提供的公网 URL(如 `https://abcd1234.ngrok.io`)。 - 检查 ngrok 控制台日志,确认请求是否成功转发到本地服务[^3]。 --- #### **补充:网络路由排查** - **问题**:如果本地处于多层 NAT(如公司内网),可能需要调整路由器端口转发。 - **解决**: 联系网络管理员,将 ngrok 使用的端口(如 5000)在路由器中转发到本地机器。 --- ### 关键配置参数总结 | 参数 | 作用 | 示例 | |-----------------------|----------------------------------|-------------------------------| | `--host-header` | 重写请求头以匹配本地服务 | `--host-header="localhost:80"`| | `--region` | 指定服务器区域(提升速度) | `--region=eu`(欧洲节点) | | `--subdomain` | 自定义子域名(需付费) | `--subdomain=myapp` | 通过以上步骤,可确保 ngrok 正确穿透内网限制,允许外部用户访问本地服务。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值