成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

使用FastAPI整合Gradio和Django

人工智能
本文分享了一種整合 Gradio 和 Django 程序的方法,在這種方法下,Gradio 和 Django 可以使用同一個進程,使用相同的端口號對外服務,同時Gradio程序使用子目錄 /gradio 進行訪問,Django 程序使用根目錄 / 進行訪問。

大家好,我是每天分享AI應用的螢火君!

經常接觸機器學習的同學可能都接觸過Gradio這個框架,Gradio是一個基于Python的專門為機器學習項目創建的快速開發框架,可以讓開發者快速發布自己的模型給用戶測試,目前Huggingface上的機器學習項目都是基于Gradio對外提供服務的。

不過Gradio的目標是機器學習模型的快速演示,真正為用戶提供服務時,我們還有很多需要關注的方面,比如用戶的鑒權授權、消息通知、靜態頁面、SEO優化等等,這些使用Gradio有點捉襟見肘,我們還需要使用更加成熟的Web開發框架,比如Django這種。

但是我們初期可能已經用Gradio做了很多的功能,不想重寫這些東西,這時候就產生了集成Gradio到其它框架的需求。這篇文章就來分享如何將Gradio集成到成熟的Web框架Django,以方便后來者。

創建Django項目

這里假設我們已經有了一個Gradio的項目,將在這個項目中繼續創建一個Django項目。

創建 Django 項目

首先通過 pip 安裝 Django

pip install django

然后在程序的根目錄初始化Django項目的一些基礎文件:

django-admin startproject myproject
cd myproject

這里的 myproject 需要替換成你的 Django 項目名。

然后我們還要繼續創建 Django 應用,應用可以理解為模塊,比如項目下有管理模塊、用戶模塊、支付模塊和具體的業務單元模塊。每個應用都有自己的模型、視圖、模板和 URL 路由。

python manage.py startapp myapp

請將myapp改為你的應用名稱。

執行完這些命令之后,項目中將會增加一些Django的框架腳本。

創建 Django 頁面

有了Django的基礎腳本,然后就可以開發Web頁面了。

1個頁面涉及三個方面:視圖、路由和HTML模板,還是以 myapp 為例:

在 myapp/views.py 中創建一個視圖:

from django.shortcuts import render

def index(request):
    return render(request, 'index.html')

在 myapp/urls.py 中設置 URL 路由到這個視圖:

from django.urls import path
from .views import index

urlpatterns = [
    path('', index, name='index'),
]

在 myapp/templates/index.html 創建 HTML 模板:

<!DOCTYPE html>
<html>
<head>
    <title>Gradio in Django</title>
</head>
<body>
    <h1>Welcome to My App</h1>
</body>
</html>

然后我們就可以啟動程序,在瀏覽器訪問這個頁面了:

uvicorn myproject.wsgi:application --reload

啟動程序使用的是 uvicorn工具,myproject是項目的名稱,wsgi對應到myproject文件夾下的 wsgi.py。

集成Gradio到Django

準備一個Gradio項目

為了演示,這里準備一個Gradio的程序。

假設文件路徑為:gradio/app.py

import gradio as gr

def greet(name):
    return f"Hello {name}!"

# 定義 Gradio 接口
demo = gr.Interface(fn=greet, inputs="text", outputs="text")

整合 Gradio 和 Django

現在我們把 Gradio 集成到 Django 中,它們將在同一個進程中運行,對外使用一個端口號。Django 默認通過根目錄 / 進行訪問,Gradio則通過 /gradio 進行訪問。

這里走過一些彎路,有問題的方法就不講了,直接給出我的方案。

這里還要引入一個框架 FastAPI,我們將使用 FastAPI 來代理對 Gradio 和 Django 的訪問,所以其實不是將Gradio集成到Django,這個方法本質上是將 Gradio 和 Django 整合到一起。

打開 myproject/wsgi.py,這是 Django 項目的主文件:

import os
from django.core.wsgi import get_wsgi_application
from fastapi import Request, Response
from starlette.middleware.wsgi import WSGIMiddleware
import gradio as gr
from gradio.app import demo

os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'myproject.settings')

# 創建 FastAPI 應用
app = FastAPI()

# 掛載 Gradio 到FastAPI,注意這個path要和下邊中間件中的一致
app = gr.mount_gradio_app(app, demo, path="/gradio")

# 獲取 Django 的 WSGI 應用
django_app = get_wsgi_application()

# 注冊一個FastAPI中間件,實現
@app.middleware("http")
async def route_middleware(request: Request, call_next):
   
    # 如果路徑是 /gradio,則調用call_next,FastAPI框架會交給已經注冊的 Gradio程序 處理
    if request.url.path.startswith("/gradio"):
        return await call_next(request)
    
    # 否則交給Django處理
    response = Response()
    
    async def send(message):
        if message['type'] == 'http.response.start':
            response.status_code = message['status']
            response.headers.update({k.decode(): v.decode() for k, v in message['headers']})
        elif message['type'] == 'http.response.body':
            response.body += message.get('body', b'')  # 注意這里用 += 來累積響應體
            
    await WSGIMiddleware(django_app)(request.scope, request.receive, send)
    
    response.headers["content-length"] = str(len(response.body))
    return response

這段代碼的邏輯也比較簡單,先創建FastAPI應用,然后將Gradio程序掛載到FastAPI,這里使用的是Gradio自帶的mount_gradio_app方法,然后創建了一個FastAPI的中間件,對不同的路由使用不同的處理。

重點就在這個FastAPI中間件,它可以保證通過 /gradio 訪問到Gradio程序,通過 / 訪問到 Django 程序。

如果我們使用下面的這種方式來代理 Django,實測將不能通過 /gradio 訪問到Gradio程序,無論 Gradio 和 Django 誰先注冊。如果你的環境可以,歡迎留下你的各個 package 的版本。

app.mount("/", WSGIMiddleware(django_app))

靜態文件的訪問

因為靜態文件是每個Web程序幾乎避不開的,比如圖片、css、js等,所以這里特別提下。

在上邊的路由中間件中,除了 /gradio 會路由到Gradio程序,其它都會走Django進行處理,靜態文件也不例外。

這里假設靜態文件放在 static 目錄下。

打開 myproject/settings.py,這是 Django 項目的基礎設置文件,修改其中靜態文件的部分:

STATIC_URL = '/static/'
if DEBUG:
    STATICFILES_DIRS = [
        os.path.join(BASE_DIR, "static"),
    ]
else:
    STATIC_ROOT = os.path.join(BASE_DIR, 'static')

打開 myproject/urls.py,修改其中的路由定義,增加 re_path 這一行。

urlpatterns = [
    re_path('^static/(?P<path>.*)', serve, {'document_root': settings.STATIC_ROOT}),
    path('', include('myapp.urls')),  # 包含 myapp 的 URL 配置
]

這樣可以在調測和生產環境都能正常訪問 static 目錄下的靜態文件,而不用再進行不同的設置。

總結

本文分享了一種整合 Gradio 和 Django 程序的方法,在這種方法下,Gradio 和 Django 可以使用同一個進程,使用相同的端口號對外服務,同時Gradio程序使用子目錄 /gradio 進行訪問,Django 程序使用根目錄 / 進行訪問。

因本人對 Django 和 Gradio 的了解有限,文中介紹的方法可能存在瑕疵,請謹慎使用。



責任編輯:武曉燕 來源: 螢火架構
相關推薦

2021-04-28 07:03:28

DjangoFlaskFastAPI

2023-10-09 18:17:52

Python語言Web

2012-04-19 10:04:20

ibmdw

2024-07-25 08:58:16

GradioPython數據應用

2025-05-14 08:16:46

?Redis機器學習推薦模型

2025-06-16 07:55:29

2020-06-04 17:38:49

PythonFastAPIWeb服務

2025-05-07 10:00:00

開發FastAPI日志

2025-05-19 08:30:19

2023-03-27 15:07:27

PythonWeb 開發編程語言

2016-11-09 14:02:46

HiveHBase集成

2009-06-19 10:00:37

Struts和Spri

2023-12-05 15:44:46

計算機視覺FastAPI

2017-04-19 22:30:26

LinuxNginxGunicorn

2025-05-12 10:02:05

2021-06-09 09:36:18

DjangoElasticSearLinux

2021-04-26 10:47:54

AJAXDjango前端

2025-04-09 11:30:00

Flask開發Python

2024-10-14 10:12:37

Python Web框架Python

2009-07-03 13:31:07

PHP和JSPApache處理
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 精品国产一区二区国模嫣然 | 在线视频中文字幕 | 国产二区精品视频 | 日韩欧美国产一区二区三区 | 亚洲国产一区二区在线 | 日本污视频 | 日韩视频在线免费观看 | 情侣av| 91久久| 黄色一级片视频 | 日本高清中文字幕 | 中文字幕在线一区二区三区 | 国产在线播放一区二区三区 | 九九久久精品 | 精品中文字幕一区二区 | 亚洲国产精品久久久久婷婷老年 | 欧美aaa一级片 | 91国产精品 | 亚洲协和影视 | 亚洲一区二区三区欧美 | 一区二区三区精品在线视频 | 狠狠做六月爱婷婷综合aⅴ 国产精品视频网 | 国产98色在线 | 日韩 | www.一级片| 91se在线 | 欧美日韩视频网站 | 日韩一区二区在线视频 | 99精品一区二区三区 | 国内自拍第一页 | 国产做a爱片久久毛片 | 99国内精品久久久久久久 | 在线观看国产视频 | 中文字幕在线一区二区三区 | 在线免费观看黄a | 一区二区三区亚洲 | 在线精品国产 | 日韩精品久久久 | 日本在线精品视频 | 免费精品在线视频 | 欧美成人自拍 | 91视频在线观看 |