0

0

如何通过 Discord API 读取 Modal 表单中的用户输入?

聖光之護

聖光之護

发布时间:2026-02-11 23:55:26

|

341人浏览过

|

来源于php中文网

原创

如何通过 Discord API 读取 Modal 表单中的用户输入?

discord modal 是前端交互组件,其问题字段和用户填写内容仅在客户端渲染并提交至 bot 的 interaction 回调中处理;requests 无法直接“读取”已显示的 modal 内容,因为 modal 结构不暴露于 http 请求载荷,也不存在于公开 api 端点中。

Discord Modal(模态框)是 Discord 提供的一种交互式表单组件,用于向用户收集结构化输入(如文本、下拉选项等)。但需明确一个关键前提:Modal 本身不是服务器端资源,而是由 Discord 客户端动态渲染的 UI 元素。当 Bot 通过 interaction.response.send_modal() 发送 Modal 后,所有字段定义(TextInput 标题、提示、是否必填等)仅保留在 Bot 的内存或代码逻辑中;用户填写的内容不会以明文形式出现在浏览器网络请求(如 Chrome DevTools 中捕获的 XHR/Fetch 请求)里,也不会通过公开 REST 接口暴露。

✅ 正确获取 Modal 数据的方式:响应 Interaction Callback

Modal 提交后,Discord 会向你的 Bot 发送一个 ModalSubmit 类型的 Interaction 事件。你必须在服务端监听该事件,并从中解析 components 字段提取用户输入:

Aha
Aha

全天候网红营销AI智能体平台

下载
import discord
from discord import ui, Interaction
from discord.ext import commands

class MyModal(ui.Modal, title="用户信息收集"):
    name = ui.TextInput(label="姓名", placeholder="请输入您的真实姓名")
    age = ui.TextInput(label="年龄", placeholder="例如:25", required=False)

    async def on_submit(self, interaction: Interaction):
        # ✅ 正确获取用户填写内容
        user_name = self.name.value.strip()
        user_age = self.age.value.strip() if self.age.value else "未填写"

        await interaction.response.send_message(
            f"✅ 已收到:\n姓名 → `{user_name}`\n年龄 → `{user_age}`",
            ephemeral=True
        )

# 在命令中触发 Modal
@commands.command()
async def apply(ctx):
    modal = MyModal()
    await ctx.interaction.response.send_modal(modal)
? 为什么 requests 无法读取 Modal 问题? Modal 的字段定义(如 label="邮箱")由 Bot 主动构造并随 POST /interactions/{id}/{token}/callback 请求发送给 Discord,但该请求体是加密/签名的 interaction payload,不包含可被外部抓包解析的原始字段结构; 用户提交时,浏览器发出的请求是 POST https://discord.com/api/v10/interactions,载荷为二进制或高度封装的 interaction data,其中 components 字段经过序列化且无文档化公开 schema —— 即便抓包也无法安全反解出原始问题文本; Discord 官方 API 文档明确指出:Modal 的 schema 和提交数据仅通过 Interaction 事件回调传递给 Bot 应用,不存在独立的 GET /modal/{id} 或类似端点。

⚠️ 注意事项与最佳实践

  • 不要尝试逆向工程前端请求:Discord 前端频繁更新,网络请求格式、签名机制、端点路径均可能随时变更,依赖抓包方案极不稳定且违反 Discord Developer Terms
  • Webhook 不适用于接收 Modal 数据:Modal 提交触发的是 Interaction 事件,而非 Webhook 调用;若强行用 requests.post(webhook_url, json={...}) 手动转发,你仍需先在 Bot 端接收到原始 Interaction 才能获取数据 —— 这属于冗余中转,无实际意义;
  • 字段校验应在 on_submit 中完成:利用 TextInput.min_length、max_length、正则 regex(需自定义验证)等做前置约束,而非依赖客户端不可靠的呈现;
  • 敏感数据需脱敏处理:用户输入可能含隐私信息(如邮箱、ID),记录前务必遵循 GDPR/CCPA 等合规要求。

✅ 总结

要“读取 Modal 中的问题及答案”,唯一可靠、官方支持、长期稳定的方式是:
在 Bot 侧完整实现 Modal 类 + on_submit 回调逻辑,通过 self.xxx.value 直接访问属性值。
requests 模块在此场景中无实质作用——它适合调用公开 REST API(如发送消息、获取频道信息),但无法替代 Interaction 事件驱动模型。拥抱 Discord 的 Interaction 设计范式,才是构建健壮 Bot 的正确路径。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

436

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

544

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

317

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

81

2025.09.10

chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

930

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

776

2023.11.06

chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

930

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

776

2023.11.06

2026春节习俗大全
2026春节习俗大全

本专题整合了2026春节习俗大全,阅读专题下面的文章了解更多详细内容。

68

2026.02.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号