0

0

如何为 Google 表单设置密码验证以限制提交权限

聖光之護

聖光之護

发布时间:2026-02-12 19:49:33

|

724人浏览过

|

来源于php中文网

原创

如何为 Google 表单设置密码验证以限制提交权限

google 表单原生不支持密码或白名单访问控制,但可通过 apps script 在提交后自动校验预设验证码,并即时屏蔽无效响应,实现“伪密码门禁”效果。本文详解实现逻辑、修复常见脚本错误,并提供健壮可部署的完整方案。

在实际调研场景中,常需确保仅授权人员(如内部员工、受邀嘉宾)可提交表单,而非公开开放。虽然 Google 表单本身不提供前端密码验证、IP 限制或实时白名单拦截功能(即无法在用户点击“提交”前阻止非法访问),但我们可以通过 Google Apps Script 的 onFormSubmit 触发器,在响应提交后的毫秒级时间内完成校验,并自动作废无效提交——这是一种被广泛验证、稳定可靠的“后置准入控制”方案。

✅ 正确实现逻辑与关键修复点

您原始脚本存在多个关键问题,导致无法正常工作:

狸谱App
狸谱App

AI壁纸漫画梗图,年轻人的抽象创作社区

下载
  • ❌ e.response 在 onFormSubmit 触发器中不可用(该事件对象仅含 e.values, e.namedValues, e.source, e.authMode 等字段,不包含响应实例);
  • ❌ form.setAcceptingResponses(false) 会全局关闭整个表单,影响所有用户,而非仅拒绝当前提交;
  • ❌ 未处理空值、大小写敏感、首尾空格等常见校验陷阱;
  • ❌ 缺少错误日志与幂等保护,易因重复触发导致误关表单。

以下是修复后的生产就绪版脚本:

function onFormSubmit(e) {
  // 1. 获取表单和响应数据
  const form = FormApp.getActiveForm();
  const namedValues = e.namedValues; // { "验证码": ["ABC123"], "姓名": ["张三"] }

  // 2. 提取验证码(假设题目标签为"验证码",请按实际修改)
  const codeInput = (namedValues["验证码"] || [null])[0];
  if (!codeInput || typeof codeInput !== 'string') {
    console.warn("⚠️ 未检测到有效验证码字段,跳过校验");
    return;
  }
  const submittedCode = codeInput.trim().toUpperCase(); // 统一转大写并去空格

  // 3. 读取白名单代码(推荐:使用缓存 + 防错读取)
  const sheetUrl = 'YOUR_GOOGLE_SHEET_URL'; // 替换为您的表格链接
  try {
    const ss = SpreadsheetApp.openByUrl(sheetUrl);
    const codeSheet = ss.getSheetByName('Sheet1') || ss.getSheets()[0];
    const codeRange = codeSheet.getRange('A2:A'); // 建议从 A2 开始(A1 为标题),避免空行干扰
    const codes = codeRange.getValues()
      .flat()
      .filter(String) // 移除空单元格
      .map(c => String(c).trim().toUpperCase());

    // 4. 校验通过则保留,否则标记为“已拒绝”并隐藏响应
    if (!codes.includes(submittedCode)) {
      // ⚠️ 关键:不关闭表单!而是删除/归档该响应
      const responseId = e.responseId;
      const allResponses = form.getResponses();
      const targetResponse = allResponses.find(r => r.getId() === responseId);
      if (targetResponse) {
        form.deleteResponse(responseId); // 彻底移除无效响应(不可恢复)
        console.info(`✅ 已删除非法提交(ID: ${responseId},验证码: ${submittedCode})`);
      }
      return;
    }
    console.info(`✅ 验证码校验通过: ${submittedCode}`);
  } catch (err) {
    console.error("❌ 白名单读取失败:", err.toString());
    // 可选:发送告警邮件或记录到日志表
  }
}

? 部署步骤(务必按顺序操作)

  1. 在您的 Google 表单中 → 点击右上角「⁝」→ 「编辑表单脚本」(将打开 Apps Script 编辑器);
  2. 粘贴上方脚本,将 YOUR_GOOGLE_SHEET_URL 替换为您存放验证码的 Sheet 链接;
  3. 确认验证码题目标签名:脚本中 namedValues["验证码"] 的 "验证码" 必须与表单中该题目的精确标题文字一致(区分中英文标点);
  4. 保存项目 → 点击左上角「部署」→ 「新建部署」→ 选择触发器类型为:
    ▶️ onFormSubmit(事件类型:From form → On form submit);
  5. 授权运行权限(首次部署时需授权 https://www.googleapis.com/auth/forms.currentonly 和 https://www.googleapis.com/auth/spreadsheets.readonly)。

⚠️ 重要注意事项

  • 隐私与合规:被删除的响应无法恢复,且不会出现在任何导出文件中,符合 GDPR/《个人信息保护法》对“无效数据及时清除”的要求;
  • 性能优化:白名单建议控制在 5,000 行以内;若代码量极大,可改用 PropertiesService 缓存校验集(减少 Sheet I/O);
  • 防暴力尝试:Google 表单本身无频率限制,如需增强防护,可在 Sheet 中添加“使用次数”列,配合脚本实现一次性验证码;
  • 替代方案对比
    • 推荐:本方案零第三方依赖、完全可控、免费;
    • ⚠️ 插件/外链工具(如 FormLimiter)仅能限提交次数或时间,无法做白名单校验
    • ❌ 不推荐用“隐藏题+跳转逻辑”伪装密码——前端可被审查元素绕过,毫无安全性。

通过以上配置,您即可在不改变表单外观的前提下,构建一道轻量、可靠、合规的访问防线。所有未持有效验证码的提交将被静默丢弃,而合法用户全程无感知——这才是面向生产环境的专业实践。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2444

2024.08.16

PHP 高并发与性能优化
PHP 高并发与性能优化

本专题聚焦 PHP 在高并发场景下的性能优化与系统调优,内容涵盖 Nginx 与 PHP-FPM 优化、Opcode 缓存、Redis/Memcached 应用、异步任务队列、数据库优化、代码性能分析与瓶颈排查。通过实战案例(如高并发接口优化、缓存系统设计、秒杀活动实现),帮助学习者掌握 构建高性能PHP后端系统的核心能力。

105

2025.10.16

PHP 数据库操作与性能优化
PHP 数据库操作与性能优化

本专题聚焦于PHP在数据库开发中的核心应用,详细讲解PDO与MySQLi的使用方法、预处理语句、事务控制与安全防注入策略。同时深入分析SQL查询优化、索引设计、慢查询排查等性能提升手段。通过实战案例帮助开发者构建高效、安全、可扩展的PHP数据库应用系统。

93

2025.11.13

JavaScript 性能优化与前端调优
JavaScript 性能优化与前端调优

本专题系统讲解 JavaScript 性能优化的核心技术,涵盖页面加载优化、异步编程、内存管理、事件代理、代码分割、懒加载、浏览器缓存机制等。通过多个实际项目示例,帮助开发者掌握 如何通过前端调优提升网站性能,减少加载时间,提高用户体验与页面响应速度。

31

2025.12.30

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

5

2026.02.12

雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

2

2026.02.12

豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

52

2026.02.12

PostgreSQL性能优化与索引调优实战
PostgreSQL性能优化与索引调优实战

本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

8

2026.02.12

Next.js全栈开发与SSR服务端渲染实战
Next.js全栈开发与SSR服务端渲染实战

本专题系统讲解 Next.js 框架在现代全栈开发中的应用,重点解析 SSR、SSG 与 ISR 渲染模式的原理与差异。内容涵盖路由系统、API Routes、数据获取策略、性能优化以及部署实践。通过完整项目示例,帮助开发者掌握高性能 SEO 友好的 React 全栈开发方案。

3

2026.02.12

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 5万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

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

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