
discord 的 modal(模态窗口)无法通过 `requests` 库直接抓取或解析其问题字段;modal 的结构与用户填写内容仅在客户端渲染,服务端需依赖 discord 官方事件回调(如 `on_modal_submit`)接收数据,`requests` 无法替代合法的 bot 事件监听机制。
Discord Modal 是一种由 Bot 触发、用户在客户端(桌面端/移动端)填写后提交的交互式表单。关键前提必须明确:Modal 的字段定义(如 TextInput 标题、提示、是否必填)和用户实际填写的内容,均不会以明文形式出现在网络请求载荷中(例如 Chrome DevTools 的 Network 标签页里看不到问题文本或答案)。这是因为:
- Modal 的 UI 渲染和初始结构由 Discord 客户端本地处理;
- 用户提交时,Discord 客户端将数据加密打包并签名后,通过受控的内部 API(如 POST /interactions)发送至 Discord 服务端;
- requests 是通用 HTTP 客户端库,它无法模拟 Discord 客户端的认证上下文、事件签名逻辑或交互生命周期,因此无法主动“读取”或“监听”Modal 的问题定义或用户答案。
✅ 正确做法:使用支持 Interaction 的 Discord Bot 框架(如 discord.py >= 2.0),在服务端监听 on_modal_submit 事件:
from discord import ui, Interaction
import discord
class MyModal(ui.Modal, title="用户反馈表单"):
name = ui.TextInput(label="姓名", placeholder="请输入您的名字")
feedback = ui.TextInput(label="建议", style=discord.TextStyle.long, required=False)
async def on_submit(self, interaction: Interaction):
# ✅ 此处可安全获取用户填写内容
await interaction.response.send_message(
f"感谢提交!\n姓名:{self.name}\n建议:{self.feedback}",
ephemeral=True
)
# 触发 Modal 示例(通常绑定在按钮或命令中)
@bot.tree.command()
async def feedback(interaction: Interaction):
await interaction.response.send_modal(MyModal())⚠️ 注意事项:
- 不要尝试用 requests 逆向抓包或伪造 Modal 提交——Discord 的交互请求包含动态签名(X-Signature-Ed25519 和 X-Signature-Timestamp),且需匹配 Bot 的公钥验证流程,技术上不可行且违反 Discord Developer Terms;
- Modal 字段信息(如 label)仅存在于 Bot 代码中,不会下发到前端以外的任何地方;你无法从外部“扫描”出某个已发送 Modal 包含哪些问题;
- 若需持久化或转发数据,应在 on_submit 回调内使用 requests.post() 将结构化数据(如 {"name": str(self.name), "feedback": str(self.feedback)})推送到你自己的 Webhook 或 API,而非试图用 requests 去“读取”Modal。
总结:Modal 不是静态 HTML 表单,而是 Discord 生态内受严格管控的交互组件。可靠、合规、可维护的方案只有一条路径——升级至 discord.py 2.0+,正确实现 Modal 类与 on_modal_submit 事件处理器。放弃对 requests 解析 Modal 的幻想,转向官方 Interaction 体系,才是工程实践的正确起点。







