
google 表单本身不支持通过 apps script 在用户打开表单前进行身份校验;但可通过「响应验证」功能,在第一题强制校验学号,结合 workspace 账户访问控制,有效限制非本班学生参与考试。
Google 表单是教师常用的在线测评工具,但其底层架构决定了 Apps Script 无法拦截或验证“打开表单”这一行为——所有 FormApp 或 Ui 相关脚本(如 onOpen()、prompt()、自定义验证函数)仅在表单编辑者(即您本人)打开编辑界面时生效,对填写者(学生)完全不可见、不可触发。这也是您遇到 Exception: Invalid conversion for item type: SECTION_HEADER 错误的根本原因:脚本试图操作表单结构(如 form.getItems()[0]),但该位置可能不是文本题(而是标题/分节符),且更关键的是——这段代码根本不会在学生端运行。
✅ 正确可行的解决方案如下:
1. 使用内置「响应验证」功能(推荐|零代码)
这是最稳定、最易用的方式,适用于所有教师:
- 在表单第一题设置为 「短答案」题型,标题如:“请输入您的学号(仅限本班学生)”;
- 点击题目的 ⋮ →「响应验证」→「文本」→「必须匹配正则表达式」→「与以下内容完全匹配」;
- 在输入框中填入:
^(92984270353|5449205725|437147249)$
✅ 注意:^ 表示开头,$ 表示结尾,| 是“或”,括号确保整体匹配。无需写 var 或 pattern,直接粘贴纯正则即可。
- 同时设置「不符合时显示提示文字」,例如:“学号未识别,请确认是否为本班学生,或联系老师。”
该验证会在学生提交前实时触发,且不依赖任何脚本,100% 可靠。
2. 启用 Google Workspace 访问限制(强推荐|管理员配合)
若您所在学校使用 Google Workspace 教育版(原 G Suite):
- 进入表单 → 点击右上角 「发送」→「链接」→「限制为[您的域名]的用户」(如 @yourschool.edu);
- 或在表单设置(⚙️)中开启 「仅限组织内成员」;
- 此时,非本校邮箱(如 Gmail.com)用户将无法打开表单,从源头杜绝外部访问。
⚠️ 提示:此功能需由贵校 Workspace 管理员在 Admin Console 中启用「外部共享策略」,如未生效,请联系管理员参考官方文档:控制表单对外共享。
❌ 不可行方案说明(避免踩坑)
- idValidation() 类脚本无法对学生生效——Apps Script 无权干预表单渲染流程;
- 尝试用 Session.getActiveUser().getEmail() 获取学生邮箱?❌ 仅在编辑者视角返回邮箱,填写者始终为空;
- 第三方登录/重定向/弹窗验证?❌ Google 表单不开放前端 DOM 控制,禁止注入 JS。
? 总结:请放弃“用 JavaScript 拦截学生”的思路。真正的安全防线在于「表单设置 + 内置验证」双保险:用 Workspace 域名锁住入口,再用正则验证学号守住第一关。两者结合,既专业可靠,又无需编码维护,最适合教学场景。










