You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
Go to file
秦泽旺 885afb5fc0
Default Changelist
4 days ago
.idea 添加了doc 4 days ago
backend Default Changelist 4 days ago
doc init Repo 2 months ago
frontend init Repo 2 months ago
.gitignore init Repo 2 months ago
Dockerfile init Repo 2 months ago
LICENSE init Repo 2 months ago
README.md init Repo 2 months ago
build.sh init Repo 2 months ago
entrypoint.sh init Repo 2 months ago
start.sh init Repo 2 months ago

README.md

spring-boot-online-exam

在线Demo预览http://129.211.88.191 账户分别是admin、teacher、student密码是admin123。视频讲解代码https://www.bilibili.com/video/BV1FP4y1L7xt/

好消息一个小伙伴做了Python实现欢迎大家starhttps://github.com/xingxingzaixian/django-drf-online-exam

1.快速体验

1.1 事先准备

clone代码并进入代码路径

git clone git@github.com:lsgwr/spring-boot-online-exam.git
cd spring-boot-online-exam

下面按照Linux和windows说明快速搭建的方法

1.2 Linux

执行代码下的脚本start.sh即可

然后访问 http://ip:80 即可访问自己搭建的考试系统

1.3 windows

  • 1.安装JDK推荐JDK8
  • 2.从官方仓库下载发布的jar包建议选择最新版https://github.com/lsgwr/spring-boot-online-exam/releases
  • 3.安装MySQL创建数据库exam并初始化密码为aA111111导入doc/sql/exam.sql文件来创建数据库
  • 4.启动jar包java -jar exam.jar
  • 5.访问:http://ip:9527 即可访问自己搭建的考试系统

2.介绍

基于springboot的在线考试系统

2.1 功能简介

  • 支持单选题、多选题、判断题
  • 支持学生(student)、教师(teacher)、管理员(admin)三种角色
    • 学生:参加考试和查看我的考试
    • 教师:学生的所有权限+创建/编辑题目+创建/编辑考试
    • 管理员:教师的所有权限+管理用户

2.3 软件架构

前后端分离,前段组件化,方便二次开发;后端

  • 后端采用SpringBoot+JPA++Swagger2+JWT校验,根据不同用户的权限返回给用户不同的数据
  • 后端采用Vue+AntDesign,组件化拆分,封装了很多年公共组件,方便维护和二次开发

2.3 使用教程

  • 1.下载代码
    git clone https://github.com/19920625lsg/spring-boot-online-exam.git
    
  • 2.初始化数据库

    安装mysql的步骤这里省略网上的教程很多。安装好mysql后新建exam数据库密码和spring-boot-online-exam/backend/exam/src/main/resources/application.ymlpassword: xxxxxx保持一致,然后导入spring-boot-online-exam/doc/sql/exam.sql

  • 3.启动后端

    打开spring-boot-online-exam/backend/exam这个Maven项目可以在IDE里启动或者执行mvn install生成jar包启动

  • 4.启动前端
    • 进入到前端代码路径 cd spring-boot-online-exam/frontend/exam/
    • 安装依赖 npm install
    • 启动前端 npm run serve
  • 5.部署完毕,查看效果

    打开 http://localhost:8000 或者 http://本机ip:8000 即可查看演示效果

3.功能图示

  • 1.管理题目
    • 1.1 题目列表

      题目查看

    • 1.2 题目创建

      题目创建

    • 1.3 题目更新

      题目更新

  • 2.考试管理
    • 2.1 考试列表

      考试查看

    • 2.2 考试创建

      考试创建

    • 2.3 考试更新(还有点小bug开发中)

      考试更新

  • 3.我的考试
    • 3.1 参加考试

      在"考试列表"模块点击自己想参加的考试卡片即可 参加考试1 参加考试2

    • 3.2 考试记录查看

      考试记录查看

4.参与贡献

  1. Fork 本仓库
  2. 新建 exam_xxx 分支
  3. 提交代码
  4. 新建 Pull Request

5.Todo

  • 0.修复issue提地bug题目创建失败
  • 1.考试详情编辑
  • 2.支持题目和考试的删除删除的话比较麻烦先不做了最好是弄个visible字段不实际删除要不后面有些关联数据找不到就不好了

    如果题目有关联的考试则必须先删除对应的考试,反过来删除考试则不用删除题目

  • 3.图片改成base64存到数据库中
  • 4.题干和选项支持富文本
  • 5.支持批量导入题目
  • 6.新增用户管理、学科管理功能
  • 7.老师能考到所有学生的成绩以及考试的统计信息
  • 8.更多的数据分析功能
  • 9.支持容器化一键式部署(编好Dockerfile)
  • 10.支持移动端最好用uniapp做
  • ......抓紧做吧,争取每周末做一点......