ngrok实现内网穿透(以Python FastAPI为例)

文章目录

简介

内网穿透:让外网设备能够访问你家或公司局域网内部的设备

ngrok:把本地电脑上的服务,如 API 接口安全地暴露到公网的工具。在没有公网 IP、无法配置路由器的情况下,也能让外网访问到本地服务

ngrok 工作原理:由内网主动建立一个到公网服务器的加密隧道,所有外部流量都通过这个隧道转发到本地服务

还可以使用 Cloudflare Tunnel

安装

解压到某目录下,添加环境变量 Path

shell 复制代码
ngrok config add-authtoken xxx

初试

main.py

python 复制代码
import uvicorn
from fastapi import FastAPI

app = FastAPI()


@app.get("/")
def index():
    return {"Hello": "World"}


if __name__ == "__main__":
    uvicorn.run("main:app")

暴露 8000 端口

shell 复制代码
ngrok http 8000

访问 Forwarding 的链接

Visit Site

查看请求日志

http://127.0.0.1:4040

设置静态域

免费版只能 1 个静态随机域名

前后端分离

frontend.html

html 复制代码
<!doctype html>
<html>
<head><meta charset="utf-8"><title>demo</title></head>
<body>
  <button id="btn">调后端</button>
  <pre id="out"></pre>

  <script>
    const API = "https://thing-prance-spindle.ngrok-free.dev";

    document.getElementById("btn").onclick = async () => {
      const r = await fetch(API + "/hello", {
        headers: { "ngrok-skip-browser-warning": "1" }
      });
      const data = await r.json();
      document.getElementById("out").textContent = JSON.stringify(data, null, 2);
    };
  </script>
</body>
</html>

backend.py

python 复制代码
from fastapi import FastAPI
from fastapi.middleware.cors import CORSMiddleware
from fastapi.staticfiles import StaticFiles

app = FastAPI()

app.add_middleware(
    CORSMiddleware,
    allow_origins=["*"],
    allow_methods=["*"],
    allow_headers=["*"],
    allow_credentials=True,
)


@app.get("/hello")
def hello():
    return {"msg": "hello"}


app.mount("/", StaticFiles(directory=".", html=True), name="static")


if __name__ == "__main__":
    import uvicorn

    uvicorn.run(app, host="0.0.0.0", port=8000)

启动

shell 复制代码
python backend.py

映射

shell 复制代码
ngrok http 8000

访问 https://thing-prance-spindle.ngrok-free.dev/frontend.html

TODO:多隧道

免费版并发隧道可以 3 条

backend.py

python 复制代码

启动

shell 复制代码
python backend.py

frontend.html

html 复制代码

启动

shell 复制代码
python -m http.server 3000

修改 %USERPROFILE%\AppData\Local\ngrok\ngrok.yml

yaml 复制代码
version: "3"
agent:
    authtoken: 你的token
    
tunnels:
  backend:
    proto: http
    addr: 8000
    domain: 你的domain(如thing-prance-spindle.ngrok-free.dev)
    
  frontend:
    proto: http
    addr: 3000

启动

shell 复制代码
ngrok start backend frontend

ngrok start --all

参考文献

  1. ngrok
相关推荐
接着奏乐接着舞1 小时前
dto 转entity方法
java·开发语言
0x00071 小时前
译 Anders Hejlsberg 谈 C# 与 .NET
开发语言·c#·.net
TechWayfarer1 小时前
IP精准定位服务在快递网点规划中的应用:如何用客户位置数据辅助选址
大数据·网络·python·tcp/ip·交通物流
czhaii1 小时前
基于51单片机的Modbus从机通信系统
开发语言·单片机
elseif1231 小时前
【C++】vector 详细版
开发语言·c++·算法
codingPower1 小时前
JAVA后端安全进阶:基于HMAC-SHA256+Nonce+Timestamp的API防重放攻击方案
java·开发语言·spring boot·安全
暗冰ཏོ1 小时前
Go 语言从入门到后端项目实战完整指南
开发语言·后端·golang·go·go语言
CSND7401 小时前
零基础学Python合集---3:字符串的定义和常用方法
人工智能·python
Xin_ye100861 小时前
C# 零基础到精通教程 - 第十七章:前端集成——Blazor 基础
开发语言·c#
LDR0061 小时前
LDR6020:多 Type‑C 端口角色管理与外设上电顺序的智慧核心
c语言·开发语言·云计算