vue+elementUI+nodejs高校教室管理系统-前后端分离-附源码#毕业设计

随着大学里的学生人数增长,为了方便管理和帮助教学人员和学生对教室的更高效率的利用,对当前使用情况的了解,避免教室的不合理使用,可以设计大学教室管理系统来进行统筹管理。大学教室管理的主要目的是为教师,学生提供一个方便的、可快速浏览当前教室使用情况的界面。通过已知的信息,可以避免课时、老师、学生、实验室发生冲突,从而更好的方便学生上课与自习。

 

 

越来越多的学生喜欢把前端Vue+nodejs技术组合当做自己的毕业设计项目.其实是非常新颖的毕设了。在众多毕设项目中也算是给老师眼前一亮。也给自己的加不少分。总比那些java图书管理、进销存系统等几十年不变的系统强上几百倍,至少在老师看来你还算是跟的上互联网潮流了。


本项目Nodejs+express+vue+Elementui+mysql系统,采用vscode软件开发,基于web的B/S架构设计完成,使用Vue-Router和Vuex实现动态路由和全局状态管理,Ajax实现前后端通信,Element UI组件库使页面快速成型。非常适合作为计算机专业的同学参考资料进行学习.主要编程语言为nodejs和mysql。Sequelize 是一个基于 promise 的 Node.js ORM, 目前支持 Postgres, MySQL, MariaDB, SQLite 以及 Microsoft SQL Server. 它具有强大的事务支持, 关联关系, 预读和延迟加载,读取复制等功能。充分保证了系统代码的良好可读性、实用性、易扩展性、通用性、便于后期维护、操作方便以及页面简洁等特点。

 

 

随着社会的发展,社会的各行各业都在利用信息化时代的优势。计算机的优势和普及使得各种信息系统的开发成为必需。
高校教室管理系统,主要的模块包括查看首页、个人中心、教师管理、学生管理、教室信息管理、教师申请管理、学生申请管理、课时表管理、教师取消预约管理、学生取消预约管理等功能。系统中管理员主要是为了安全有效地存储和管理各类信息,还可以对系统进行管理与更新维护等操作,并且对后台有相应的操作权限。

 

import { version } from '../../package.json'
import { Router } from 'express'
import { Sequelize, Op, QueryTypes } from 'sequelize'
import sequelize from '../models/sequelize'
import toRes from '../lib/toRes'
import YonghuModel from '../models/YonghuModel'
import jwt from 'jsonwebtoken'
import moment from 'moment'

export default ({ config, db }) => {
	let api = Router()

	// 用户登录接口
	api.all('/login', async (req, res) => {

		try {

			let userinfo = await YonghuModel.findOne({ where: { zhanghao: req.query.username, mima: req.query.password } })
			if (userinfo === null) {
				toRes.session(res, -1, '用户名或密码错误!')
				return
			}


			const token = jwt.sign(
				{
					id: userinfo.dataValues.id,
					username: userinfo.dataValues.zhanghao,
					role: '用户',
                    loginUserColumn: 'zhanghao',
                    tableName: 'yonghu'
				},
				config.jwtSecret,
				{
					expiresIn: 60 * 60 * 24 * 1
				}
			)

			userinfo.dataValues.token = token
			userinfo.dataValues.role = '用户'
			userinfo.dataValues.loginUserColumn = 'zhanghao'
			userinfo.dataValues.tableName = 'yonghu'
			delete userinfo.dataValues.mima
			req.session.userinfo = userinfo

			toRes.session(res, 0, '登录成功!', token)
		} catch(err) {

			toRes.session(res, 500, '服务器错误!', '', 500)
		}
	})

	// 用户退出接口
	api.all('/logout', (req, res) => {
		
		req.session.destroy(err => {
			toRes.session(res, 0, '退出成功!')
		})
	})

	// 注册接口
	api.post('/register', async (req, res) => {

		try {

			Object.keys(req.body).forEach(item=>{
				if(req.body[item] == '')  delete req.body[item]
			})


			const userinfo = await YonghuModel.create(req.body)

			if (userinfo === null) {

				toRes.session(res, -1, '注册失败!')
			} else {

				toRes.session(res, 0, '注册成功!')
			}
		} catch(err) {
			
			toRes.session(res, -2, '请检查是否正确输入或用户名重复!', '', 200)
		}
	})

	// 获取session接口
	api.all('/session', async (req, res) => {

		try {

			toRes.record(res, 0, await YonghuModel.findOne({ where: { id: req.session.userinfo === undefined ? jwt.decode(req.headers.token).id : req.session.userinfo.id } }))
		} catch(err) {
			
			toRes.session(res, 500, '服务器错误!', '', 500)
		}
	})

	// 忘记密码(找回密码)
	api.all('/resetPass', async (req, res) => {

		try {

			await YonghuModel.update({
				mima: '123456'
			}, {
				where: {
				  zhanghao: req.query.username
				}
			})

			toRes.session(res, 0, '密码已重置为:123456')
		} catch(err) {
			
			toRes.session(res, 500, '服务器错误!', '', 500)
		}
	})

目  录

第一章 概述    1
1.1 研究背景    2
1.2开发意义    3
1.3 研究现状    4
1.4 研究内容    5
1.5论文结构    6
第二章 开发技术介绍    7
2.1 系统开发平台    8
2.2 平台开发相关技术    9
2.2.1  express框架    10
2.2.2  Node.js 语言    11
2.2.3  mysql数据库介绍    12
2.2.4  MySQL环境配置    13
2.2.5  B/S架构    14
第三章 系统分析    15
3.1 可行性分析    16
3.1.1 技术可行性    17
3.1.2 操作可行性    18
3.1.3经济可行性    19
3.2性能需求分析    20
第四章 系统设计    21
4.1功能结构    22
4.2 数据库设计    23
4.2.1 数据库E/R图    24
4.2.2 数据库表    25
第五章 系统功能实现    26
5.1管理员功能模块    27
5.2用户功能模块    28
第六章 系统测试    29
第七章 总结与心得体会    30
7.1总结    31
7.2心得体会    32
致  谢    33
参考文献    34

  • 2
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值