如何在Golang中开发问卷调查系统_Golang 问卷调查系统实战

答案:基于Golang的问卷系统包含创建、发布、填写和查看结果功能,使用Gin框架与GORM操作数据库,通过HTML模板实现前端交互,结构清晰,便于扩展。

开发一个问卷调查系统在Golang中是一个实用且常见的项目,适合练习Web开发、数据库设计和用户交互处理。下面从需求分析到核心功能实现,一步步带你构建一个基础但完整的问卷调查系统。

系统核心功能设计

一个基础的问卷调查系统通常包含以下功能:

  • 创建问卷:用户能定义标题、描述和多个问题(单选、多选、填空等)
  • 发布问卷:生成唯一链接供他人填写
  • 填写问卷:访客通过链接提交答案
  • 查看结果:统计每个问题的回答情况
  • 数据存储:使用数据库保存问卷与回答记录

技术选型与项目结构

使用Golang标准库 net/http 搭建服务,配合 Gin 框架提升开发效率,数据库选用 SQLite 或 MySQL。结构建议如下:

├── main.go
├── handlers/
│ ├── survey_handler.go
│ └── response_handler.go
├── models/
│ ├── survey.go
│ └── response.go
├── routes/
│ └── router.go
└── templates/
├── create.html
├── fill.html
└── result.html

models 定义结构体,handlers 处理请求逻辑,templates 存放 HTML 页面。

数据库模型设计

用 GORM 映射结构体到数据库表。示例模型:

问卷表(surveys)

type Survey struct {
    ID      uint   `gorm:"primarykey"`
    Title   string
    Desc    string
    Token   string // 唯一访问标识
    Questions []Question
}

type Question struct {
    ID        uint   `gorm:"primarykey"`
    SurveyID  uint
    Text      string
    Type      string // "text", "radio", "checkbox"
    Options   []Option
}

type Option struct {
    ID         uint   `gorm:"primarykey"`
    QuestionID uint
    Text       string
}

回答相关表

type Response struct {
    ID        uint `gorm:"primarykey"`
    SurveyID  uint
    Answers   []Answer
}

type Answer struct {
    ID         uint `gorm:"primarykey"`
    ResponseID uint
    QuestionID uint
    Text       string
    OptionIDs  []uint // 多选时记录多个选项ID
}

Token 字段用于生成如 /s/abc123 的公开填写链接。

关键接口实现

以 Gin 为例,注册路由并处理请求:

func setupRouter() *gin.Engine {
    r := gin.Default()
    r.Static("/static", "./static")
    r.LoadHTMLGlob("templates/*")

    r.GET("/", indexHandler)
    r.GET("/create", showCreateForm)
    r.POST("/survey", createSurvey)
    r.GET("/s/:token", showSurvey)
    r.POST("/s/:token", submitResponse)
    r.GET("/r/:id", viewResults)

    return r
}

创建问卷时生成唯一 Token(可用 uuid 或随机字符串),保存后跳转到 /s/ 链接预览。

填写页面根据 Token 查询问卷,并动态渲染题目和选项。提交时校验必填项,保存答案到数据库。

查看结果页聚合每个问题的答案分布,例如单选题可统计各选项被选次数。

前端简单交互

使用 HTML + JavaScript 实现基本动态操作。例如添加新问题时:




后端解析 q_text[] 和 q_type[] 数组,构建 Question 列表。

部署与扩展建议

本地测试可用 go run main.go 启动服务。生产环境编译为二进制部署,配合 Nginx 反向代理。

后续可扩展功能:

  • 用户登录系统,管理自己的问卷
  • 设置截止时间或填写次数限制
  • 导出结果为 CSV 或图表展示
  • 支持富文本编辑器和图片上传

基本上就这些。Golang 写问卷系统不复杂但容易忽略细节,比如表单验证、SQL 注入防护、并发安全等。保持模块清晰,逐步迭代,就能做出稳定可用的版本。