Sistema de exames on-line
ambiente de desenvolvimento
Configurar ambiente
programa | Versão | ilustrar |
---|
Jdk | 1.8.0 161 | Kit de desenvolvimento Java |
MySQL | 5.5.27 | banco de dados relacional |
Redis | 7.0.5 | banco de dados não relacional |
Especialista em Apache | 3.9.0 | Gerenciamento de projetos Java e ferramentas de construção |
Nvm | 1.10 | Gerenciador de versões Node.js. |
Nó | 8.12.0 | Ambiente de execução JavaScript Node.js. |
ferramentas de desenvolvimento
ferramenta | Versão | ilustrar |
---|
IDEIA | 2022.3.2 | IDE de desenvolvimento back-end e front-end |
Git | 2.24.1 | Plataforma de hospedagem de código |
Google Chrome | 75.0.3770.100 | Navegador, ferramentas de depuração front-end |
Navicat | 11.1.13 | Ferramenta de conexão de banco de dados |
Carteiro | 7.1.0 | Ferramentas de teste de interface |
Estação de trabalho VMware Pro | 14.1.3 | Máquina virtual (não usada, talvez você a use) |
PowerDesigner | 15 | Ferramenta de design de banco de dados (não usada, talvez você a use) |
SQLyog | 12.0.3 | Ferramenta de conexão de banco de dados (não usada, talvez você a use) |
Visio | 2013 | Diagramas de sequência, fluxogramas e outras ferramentas de desenho (se não forem usadas, talvez você as use) |
Processo ativado | —— | Ferramentas de desenho, como diagramas de arquitetura (não usados, talvez você os use) |
XMind Zen | 9.2.0 | Ferramenta de mapeamento mental (não usada, talvez você a use) |
RedisDesktop | 0.9.3.817 | ferramenta de conexão do cliente redis (não usada, talvez você a use) |
Padrões de codificação
- Abordagem padronizada: Cumprir rigorosamente as convenções de codificação do Alibaba.
- Nomenclatura unificada: A introdução permite a melhor compreensão possível do nome.
- Subcontratação clara: a hierarquia clara permite localizar rapidamente a localização do código.
- Comentários completos: A alta descritividade reduz bastante a carga de trabalho de leitura de código do desenvolvedor.
- Especificações da ferramenta: Use pacotes jar unificados para evitar conflitos de conteúdo.
- Código limpo: altamente legível e de fácil manutenção.
Estrutura do pacote
- exam -- 整个项目
| +- .idea -- 存放项目的IDE配置文件
| +- exam-admin -- 考试管理模块
| | +- .idea -- 存放考试管理模块的IDE配置文件
| | +- pom.xml -- Maven项目配置文件
| | +- src -- 存放源代码的目录
| | | +- main -- 主要的源代码目录
| | | | +- java -- Java源代码目录
| | | | | +- com.wzz -- 项目的根包名
| | | | | | +- config -- 配置文件目录
| | | | | | | +- AdminInterceptor.java -- 管理员拦截器,用于拦截管理员相关请求
| | | | | | | +- CorsConfig.java -- 跨域配置,用于允许跨域请求
| | | | | | | +- DruidConfig.java -- Druid数据源配置,用于配置数据库连接池
| | | | | | | +- MybatisPlusConfig.java -- MyBatis Plus配置,用于配置MyBatis Plus相关功能
| | | | | | | +- RedisConfig.java -- Redis配置,用于配置Redis连接和操作
| | | | | | | +- StudentInterceptor.java -- 学生拦截器,用于拦截学生相关请求
| | | | | | | +- SwaggerConfig.java -- Swagger配置,用于生成API文档
| | | | | | | +- TeacherInterceptor.java -- 教师拦截器,用于拦截教师相关请求
| | | | | | | +- WebAppConfigurer.java -- Web应用配置,用于配置Web应用相关设置
| | | | | | | +- controller -- 控制器
| | | | | | | | +- AdminController.java -- 管理员相关的控制器
| | | | | | | | +- CommonController.java -- 通用的控制器
| | | | | | | | +- StudentController.java -- 学生相关的控制器
| | | | | | | | +- TeacherController.java -- 教师相关的控制器
| | | | | | | | +- UtilController.java -- 实用工具相关的控制器
| | | | | | | +- entity -- 实体
| | | | | | | | +- Answer.java -- 答案实体类
| | | | | | | | +- Exam.java -- 考试实体类
| | | | | | | | +- ExamQuestion.java -- 考试题目实体类
| | | | | | | | +- ExamRecord.java -- 考试记录实体类
| | | | | | | | +- Question.java -- 题目实体类
| | | | | | | | +- QuestionBank.java -- 题库实体类
| | | | | | | | +- User.java -- 用户实体类
| | | | | | | | +- UserRole.java -- 用户角色实体
| | | | | | | +- ExamAdminApplication.java -- 应用程序的入口点,用于启动整个应用程序
| | | | | | | +- mapper -- 数据库映射接口目录
| | | | | | | | +- AnswerMapper.java -- 答案实体类的数据库映射接口,用于与数据库进行交互
| | | | | | | | +- ExamMapper.java -- 考试实体类的数据库映射接口,用于与数据库进行交互。
| | | | | | | | +- ExamQuestionMapper.java -- 考试题目实体类的数据库映射接口,用于与数据库进行交互。
| | | | | | | | +- ExamRecordMapper.java -- 考试记录实体类的数据库映射接口,用于与数据库进行交互。
| | | | | | | | +- QuestionBankMapper.java -- 题库实体类的数据库映射接口,用于与数据库进行交互。
| | | | | | | | +- QuestionMapper.java -- 题目实体类的数据库映射接口,用于与数据库进行交互。
| | | | | | | | +- UserMapper.java -- 用户实体类的数据库映射接口,用于与数据库进行交互。
| | | | | | | | +- UserRoleMapper.java -- 用户角色实体类的数据库映射接口,用于与数据库进行交互。
| | | | | | | +- service -- 服务接口目录
| | | | | | | | +- AnswerService.java -- 答案相关的服务接口,定义了答案相关的业务逻辑。
| | | | | | | | +- ExamQuestionService.java -- 考试题目相关的服务接口,定义了考试题目相关的业务逻辑。
| | | | | | | | +- ExamRecordService.java -- 考试记录相关的服务接口,定义了考试记录相关的业务逻辑。
| | | | | | | | +- ExamService.java -- 考试相关的服务接口,定义了考试相关的业务逻辑。
| | | | | | | | +- impl -- 服务接口实现类目录
| | | | | | | | | +- AnswerServiceImpl.java -- 答案相关的服务接口的实现类,实现了答案相关的业务逻辑。
| | | | | | | | | +- ExamQuestionServiceImpl.java -- 考试题目相关的服务接口的实现类,实现了考试题目相关的业务逻辑。
| | | | | | | | | +- ExamRecordServiceImpl.java -- 考试记录相关的服务接口的实现类,实现了考试记录相关的业务逻辑。
| | | | | | | | | +- ExamServiceImpl.java -- 考试相关的服务接口的实现类,实现了考试相关的业务逻辑。
| | | | | | | | | +- QuestionBankServiceImpl.java -- 题库相关的服务接口的实现类,实现了题库相关的业务逻辑。
| | | | | | | | | +- QuestionServiceImpl.java -- 题目相关的服务接口的实现类,实现了题目相关的业务逻辑。
| | | | | | | | | +- UserRoleServiceImpl.java -- 用户角色相关的服务接口的实现类,实现了用户角色相关的业务逻辑。
| | | | | | | | | +- UserServiceImpl.java -- 用户相关的服务接口的实现类,实现了用户相关的业务逻辑。
| | | | | | | | +- QuestionBankService.java -- 题库相关的服务接口,定义了题库相关的业务逻辑。
| | | | | | | | +- QuestionService.java -- 题目相关的服务接口,定义了题目相关的业务逻辑。
| | | | | | | | +- UserRoleService.java -- 用户角色相关的服务接口,定义了用户角色相关的业务逻辑
| | | | | | | | +- UserService.java -- 用户相关的服务接口,定义了用户相关的业务逻辑。
| | | | | | | +- Util -- 实用工具目录
| | | | | | | | +- CheckToken.java -- 检查令牌有效性的工具类。
| | | | | | | | +- createVerificationCode.java -- 生成验证码的工具类。
| | | | | | | | +- OSSUtil.java -- OSS 工具类。
| | | | | | | | +- RedisUtil.java -- Redis 工具类。
| | | | | | | | +- SaltEncryption.java -- 加密工具类。
| | | | | | | | +- TokenUtils.java -- 令牌工具类。
| | | | | | | +- vo -- 值对象目录
| | | | | | | | +- AddExamByBankVo.java -- 根据题库添加考试时的请求参数对象。
| | | | | | | | +- AddExamByQuestionVo.java -- 根据题目添加考试时的请求参数对象。
| | | | | | | | +- BankHaveQuestionSum.java -- 题库包含的题目数量信息对象。
| | | | | | | | +- CommonResult.java -- 通用响应结果对象。
| | | | | | | | +- ExamQueryVo.java -- 考试查询请求参数对象。
| | | | | | | | +- QuestionVo.java -- 题目信息对象。
| | | | | | | | +- TokenVo.java -- 令牌信息对象。
| | | | +- resources -- 资源文件目录
| | | +- test -- 测试代码目录
| | | | +- java -- Java 测试代码目录
| | | | | +- com
| | | | | | +- wzz -- 测试代码包名
| | | | | | | +- ExamAdminApplicationTests.java -- 应用程序测试类,用于测试应用程序的正确性。
| | +- target -- 构建输出目录
| +- exam-vue -- 项目前端
| | +- .browserslistrc -- 浏览器兼容性配置文件。
| | +- .editorconfig -- 编辑器配置文件。
| | +- .eslintrc.js -- ESLint 配置文件。
| | +- .gitignore -- Git 忽略文件列表。
| | +- babel.config.js -- Babel 配置文件。
| | +- debug.log -- 调试日志文件。
| | +- dist -- 前端构建输出目录
| | | +- css -- CSS 样式文件目录。
| | | +- favicon.ico -- 网站图标文件。
| | | +- fonts -- 字体文件目录。
| | | +- img -- 图片文件目录。
| | | +- index.html -- 前端应用程序主页面。
| | | +- js -- JavaScript 脚本文件目录。
| | +- node_modules -- Node.js 模块目录。
| | +- package-lock.json -- NPM 包依赖版本锁定文件。
| | +- package.json -- NPM 包管理配置文件。
| | +- public -- 前端公共资源目录
| | | +- favicon.ico -- 网站图标文件。
| | | +- index.html -- 前端应用程序主页面模板文件。
| | +- src -- 前端源代码目录
| | | +- api -- 前端 API 目录
| | | | +- api.js -- 前端 API 定义文件,用于与后端进行交互。
| | | +- App.vue -- Vue.js 应用程序的根组件。
| | | +- assets -- 前端资源目录
| | | | +- css -- CSS 样式文件目录。
| | | | +- imgs -- 图片文件目录。
| | | | +- logo.png -- 前端应用程序的 Logo 图片文件。
| | | +- components -- Vue.js 组件目录。
| | | +- main.js -- Vue.js 应用程序的入口文件。
| | | +- plugins -- Vue.js 插件目录
| | | | +- element.js -- Element UI 插件定义文件。
| | | +- Vue.js 路由目录
| | | | +- Vue.js 路由定义文件。
| | +- vue.config.js -- Vue CLI 配置文件。
| +- README.md -- 项目的说明文档。
| +- sql -- 数据库脚本目录
| | +- exam_system.sql -- 考试系统的数据库脚本。
| +- 图片
Pilha de tecnologia de back-end
tecnologia | Versão | ilustrar |
---|
Pai inicial do Spring Boot | 2.2.7.LIBERAÇÃO | Versão de dependência pai do Spring Boot |
Web inicial do Spring Boot | - | Iniciador da Web Spring Boot |
Conector MySQL/J | - | Controlador de banco de dados MySQL |
Log4j | 1.2.17 | Estrutura de registro |
OSS SDK Aliyun | 2.8.2 | SDK de armazenamento de objetos em nuvem Alibaba |
Lombok | - | Biblioteca de utilitários Java |
JWTJava | 3.8.2 | Biblioteca de implementação JSON Web Token |
Springfox Swagger2 | 2.9.2 | Gerador de documentação da API Swagger |
IU do Springfox Swagger | 2.9.2 | Página da IU do Swagger |
druida | 1.1.22 | Conjunto de conexões de banco de dados |
Redis de dados iniciais do Spring Boot | - | Iniciante do Redis |
MyBatis Plus | 3.0.5 | Ferramentas de aprimoramento MyBatis |
Teste inicial de inicialização Spring | - | Iniciador de teste de inicialização Spring |
Pilha de tecnologia front-end
tecnologia | Versão | ilustrar |
---|
eixos | ^0.20.0 | Cliente de solicitação HTTP baseado em promessa, disponível para navegadores e node.js |
núcleo-js | ^3.6.5 | Implementação modular da biblioteca padrão JavaScript |
gráficos eletrônicos | ^4.9.0 | Biblioteca poderosa e interativa de gráficos e visualização |
elemento-ui | ^2.4.5 | Biblioteca de componentes de UI Vue.js 2.0 para a web |
nó-atrevido | ^4.14.1 | Wrapper Node.js para libsass |
carregador sass | ^10.0.3 | Carregue arquivos Sass/SCSS e compile-os em CSS |
verdade | ^2.6.11 | Estrutura JavaScript progressiva cada vez mais adotada para construção de UI na web |
roteador vue | ^3.2.0 | O roteador oficial para Vue.js |
@vue/cli-plugin-babel | ~4.5.0 | Plug-in Babel para Vue CLI |
@vue/cli-plugin-eslint | ~4.5.0 | Plug-in ESlint para Vue CLI |
@vue/cli-plugin-roteador | ~4.5.0 | Plug-in Vue Router para Vue CLI |
@vue/cli-service | ~4.5.0 | Serviços locais para desenvolvimento e construção |
@vue/eslint-config-standard | ^5.1.2 | Configuração compartilhável ESLint para JavaScript Standard Style |
babel-eslint | ^10.1.0 | Analisador personalizado para ESLint |
componente do plugin babel | ^1.1.1 | Plug-in babel modular personalizável para importar componentes Element-UI sob demanda |
eslint-plugin-importação | ^2.20.2 | Ajuda para verificar plug-ins ESLint importados corretamente |
eslint-plugin-node | ^11.1.0 | Outras regras ESLint para Node.js |
eslint-plugin-promessa | ^4.2.1 | Melhores práticas para fazer cumprir promessas JavaScript |
eslint-plugin-padrão | ^4.0.0 | Plug-in ESLint padrão da comunidade JavaScript |
eslint-plugin-vue | ^6.2.2 | Plug-in ESLint oficial do Vue.js |
elemento vue-cli-plugin | ^1.0.1 | Plug-in Vue CLI para Element-UI |
compilador de modelo vue | ^2.6.11 | Um compilador que compila modelos Vue.js em funções de renderização |
Tutorial de instalação
- Execute o script do banco de dados no navicat para gerar a tabela de banco de dados correspondente
- Altere o nome do banco de dados (Redis/Mysql) ou a senha do banco de dados no arquivo src/main/resources/application.yml
- Execute mvn clean spring-boot:run no diretório pai do arquivo pom.xml para iniciar o back-end
- Para iniciar o front end, você pode executar o seguinte comando no diretório pai do package.json ou clicar diretamente no IDEA para executá-lo. Vale ressaltar que os dois últimos comandos são o comando de empacotamento e o comando de verificação e reparo.
Conta de login
Nome de usuário: admin Senha: 12345
captura de tela