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
相关推荐
CaffeinePro17 分钟前
Pydantic深度使用:数据校验、枚举、ORM映射
后端·fastapi
星云穿梭2 小时前
用Python写一个带图形界面的学生管理系统——完整教程
python
金銀銅鐵2 小时前
用 Pygame 实现 15 puzzle
python·数学·游戏
黄忠8 小时前
大模型之LangGraph技术体系
python·llm
hboot21 小时前
AI工程师第二课 - 数据处理
人工智能·python·数据分析
用户8356290780511 天前
使用 Python 自动化 PowerPoint 形状布局与格式设置
后端·python
用户8356290780511 天前
用 Python 自动化 PowerPoint 演讲者备注添加
后端·python
黄忠1 天前
01-系统架构设计-LangGraph状态机与多源异构RAG
python
zzzzzz3101 天前
假如我是掘金管理员,我先给评论区装个'代码审查'系统
python·程序员·机器人
砍材农夫1 天前
python环境|conda安装和使用(2)
后端·python