文心一言 ERNIE Bot 教程
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 事件:
⚠️ 注意事项:
- 不要尝试用 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 体系,才是工程实践的正确起点。
发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/267042.html原文链接:https://javaforall.net
