多步骤表单必须由后端维护状态,前端仅负责展示和传递步序与数据;推荐用 session(如 gorilla/sessions)或数据库临时表存储中间状态,并校验前置步骤、防跳步与重复提交。
前端分步只是视觉拆分,form 提交仍是一次性发到后端。如果用户跳过某步、刷新页面、或禁用 JS,后端无法感知当前进度,容易造成数据不一致或空字段入库。真正可靠的多步骤必
须由后端维护状态,前端只负责展示和传递当前步序与数据。
session 存储中间状态最直接Golang 标准库不带 session,需引入轻量方案(如 gorilla/sessions)。每步提交后,把当前字段写入 session,并重定向到下一步;最后一步才做完整校验与落库。
session key 建议按用户唯一标识(如 user_id 或随机 session_id)隔离,避免跨用户污染30 * time.Minute),避免长期占用内存store := cookie.NewStore([]byte("your-secret-key"))
session, _ := store.Get(r, "multi-step-session")
session.Values["step1_email"] = r.FormValue("email")
session.Save(r, w)当步骤跨度长(如用户可能隔天回来)、需支持多设备同步、或 session 服务不可靠时,应改用数据库临时记录。建一张 form_temp_data 表,含 session_id、step、data_json、updated_at 字段。
step 的 data_json(用 json.Marshal 序列化)session_id + step 拉取,避免全表扫描updated_at 超过 24 小时的记录,防止堆积仅靠 URL 路径(如 /step2)无法限制访问,必须在 handler 里校验前置步骤是否已完成。
session 或 DB 查当前用户最高完成步数,比如返回 step2,则允许访问 /step3,但拒绝 /step4
POST 接口加 X-Requested-With: XMLHttpRequest 头校验(防直接 POST 表单绕过前端)uuid 存入 session,表单带 hidden 字段,提交时比对并立即失效fetch 捕获 4xx/5xx 并提示,避免用户狂点跳步和重复是真实高频问题,别依赖“用户会乖乖点下一步”这种假设。