Gradio Agents 和 MCP 黑客马拉松

获奖者
Gradio logo
  1. 路由
  2. 请求

Gradio 新手? 从这里开始: 入门指南

查看 发布历史

请求

gradio.Request(···)

描述

一个 Gradio 请求对象,可用于在预测函数中访问请求头、cookies、查询参数以及请求的其他信息。该类是对 fastapi.Request 类的轻量级封装。该类的属性包括: headers, client, query_params, session_hash, 和 path_params。如果启用了认证,可以使用 username 属性获取登录用户。在某些环境中,该类的类似字典的属性(例如 requests.headersrequests.query_params)会自动转换为字典,因此我们建议在访问属性之前将其转换为字典,以确保在不同环境中的行为一致。

示例用法

import gradio as gr
def echo(text, request: gr.Request):
    if request:
        print("Request headers dictionary:", request.headers)
        print("IP address:", request.client.host)
        print("Query parameters:", dict(request.query_params))
        print("Session hash:", request.session_hash)
    return text
io = gr.Interface(echo, "textbox", "textbox").launch()

初始化

参数
🔗
request: fastapi.Request | None
默认 = None

A fastapi.Request

🔗
username: str | None
默认 = None

登录用户的用户名(如果启用了认证)

🔗
session_hash: str | None
默认 = None

当前会话的会话哈希。它在每次页面加载时都是唯一的。

演示

import gradio as gr

def predict(text, request: gr.Request):
    headers = request.headers
    host = request.client.host
    user_agent = request.headers["user-agent"]
    return {
        "ip": host,
        "user_agent": user_agent,
        "headers": headers,
    }

gr.Interface(predict, "text", "json").launch()