末获取源码
开发语言:Java
开发工具:IDEA /Eclipse
数据库:MYSQL5.7
应用服务:Tomcat7/Tomcat8
使用框架ssm+vue
JDK版本:jdk1.8
高校课程评价的需求和管理上的不断提升,高校课程评价管理的潜力将无限扩大,高校课程评价系统在业界被广泛关注,本系统对此进行总体分析,将高校课程评价信息管理的发展提供参考。高校课程评价系统对高校课程有着明显的带动效应,尤其对当地高校课程评价的管理帮助更大。
本系统主要包括管理员、学生、专家和教师四个用户角色;主要包括首页,个人中心,指标信息管理,课程管理,院系管理,专业管理,班级管理,教师管理,专家管理,学生管理,课程信息管理等功能的系统。
考虑到实际在高校课程评价管理方面的需要以及对该系统认真的分析,将系统权限按管理员、学生、专家和教师这四类涉及用户划分。
(1)管理员功能需求
管理员登陆后,主要模块包括首页,个人中心,指标信息管理,课程管理,院系管理,专业管理,班级管理,教师管理,专家管理,学生管理,课程信息管理,等功能。管理员用例图如图
(2)教师功能需求
教师登陆后,主要模块包括首页,个人中心,指标信息管理,课程信息管理,教师自评管理等功能。教师用例图如图
(3)学生功能需求
学生登陆后,主要模块包括首页,个人中心,课程信息管理,学生评价管理等功能。学生用例图如图
(4)专家功能需求
专家登陆后,主要模块包括首页,个人中心,指标信息管理,课程信息管理,专家评价管理等功能。专家用例图如图
为了更好的去理清本系统整体思路,对该系统以结构图的形式表达出来,设计实现该高校课程评价系统的功能结构图如下所示:
系统登录,管理员、学生、专家和教师进入系统前在登录页面根据要求填写账号,密码,验证码和选择角色等信息,点击登录进行登录操作,如图
管理员登陆系统后,可以查看首页,个人中心,指标信息管理,课程管理,院系管理,专业管理,班级管理,教师管理,专家管理,学生管理,课程信息管理,等功能,还能对每个功能逐一进行相应操作,如图
在指标信息管理页面可以对索引,名称,课程,班级,课程图片,教学大纲,课程进度,课程视频,教师工号,教师姓名,联系电话等内容进行详情,修改和删除等操作,如图
在教师管理页面可以对索引,教师工号,教师姓名,性别,照片,院系,专业,职务,联系电话,教师邮箱等内容进行详情,修改和删除等操作,如图
在专家管理页面可以对索引,专家账号,专家姓名,性别,照片,职称,联系电话等内容进行详情,修改和删除等操作,如图
在学生管理页面可以对索引,学号,姓名,性别,头像,手机,院系,专业,班级,邮箱等内容进行详情,修改和删除等操作,如图
在课程信息管理页面可以对索引,名称,课程,班级,课程图片,教学大纲,课程进度,课程视频,教师工号,教师姓名,联系电话等内容进行详情,修改和删除等操作,如图
学生登陆系统,可以查看首页,个人中心,课程信息管理,学生评价管理等功能,还能对每个功能逐一进行相应操作,如图
在个人信息页面通过填写学号,姓名,性别,头像,手机,院系,专业,班级,邮箱等内容进行个人信息修改操作,如图
教师登陆系统,可以对首页,个人中心,指标信息管理,课程信息管理,教师自评管理等功能进行详细操作,如图
在指标信息管理页面可以对索引,名称,课程,班级,课程图片,教学大纲,课程进度,课程视频,教师工号,教师姓名,联系电话等内容进行详情,教师自评操作,如图
在课程信息管理页面可以对索引,名称,课程,班级,课程图片,教学大纲,课程进度,课程视频,教师工号,教师姓名,联系电话等内容进行详情,教师自评,如图
在教师自评管理页面可以对索引,课程互动性,课程评分,总体评分,评价日期,教师工号等内容进行详情操作,如图
专家登陆系统,可以对首页,个人中心,指标信息管理,课程信息管理,专家评价管理等功能进行详细操作,如图
在专家评价管理页面可以对索引,课程,教学能力,教学效果,学生状态,教学评分,教学评级,教师工号,教师姓名,评价日期,专家账号,专家姓名等内容进行详情操作,如图
/**
* 教师自评
* 后端接口
* @author
* @email
* @date 2022-03-28 19:33:54
*/
@RestController
@RequestMapping("/jiaoshiziping")
public class JiaoshizipingController {
@Autowired
private JiaoshizipingService jiaoshizipingService;
/**
* 后端列表
*/
@RequestMapping("/page")
public R page(@RequestParam Map params,JiaoshizipingEntity jiaoshiziping,
HttpServletRequest request){
String tableName = request.getSession().getAttribute("tableName").toString();
if(tableName.equals("jiaoshi")) {
jiaoshiziping.setJiaoshigonghao((String)request.getSession().getAttribute("username"));
}
EntityWrapper ew = new EntityWrapper();
PageUtils page = jiaoshizipingService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jiaoshiziping), params), params));
return R.ok().put("data", page);
}
/**
* 前端列表
*/
@IgnoreAuth
@RequestMapping("/list")
public R list(@RequestParam Map params,JiaoshizipingEntity jiaoshiziping,
HttpServletRequest request){
EntityWrapper ew = new EntityWrapper();
PageUtils page = jiaoshizipingService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jiaoshiziping), params), params));
return R.ok().put("data", page);
}
/**
* 列表
*/
@RequestMapping("/lists")
public R list( JiaoshizipingEntity jiaoshiziping){
EntityWrapper ew = new EntityWrapper();
ew.allEq(MPUtil.allEQMapPre( jiaoshiziping, "jiaoshiziping"));
return R.ok().put("data", jiaoshizipingService.selectListView(ew));
}
/**
* 查询
*/
@RequestMapping("/query")
public R query(JiaoshizipingEntity jiaoshiziping){
EntityWrapper< JiaoshizipingEntity> ew = new EntityWrapper< JiaoshizipingEntity>();
ew.allEq(MPUtil.allEQMapPre( jiaoshiziping, "jiaoshiziping"));
JiaoshizipingView jiaoshizipingView = jiaoshizipingService.selectView(ew);
return R.ok("查询教师自评成功").put("data", jiaoshizipingView);
}
/**
* 后端详情
*/
@RequestMapping("/info/{id}")
public R info(@PathVariable("id") Long id){
JiaoshizipingEntity jiaoshiziping = jiaoshizipingService.selectById(id);
return R.ok().put("data", jiaoshiziping);
}
/**
* 前端详情
*/
@IgnoreAuth
@RequestMapping("/detail/{id}")
public R detail(@PathVariable("id") Long id){
JiaoshizipingEntity jiaoshiziping = jiaoshizipingService.selectById(id);
return R.ok().put("data", jiaoshiziping);
}
/**
* 后端保存
*/
@RequestMapping("/save")
public R save(@RequestBody JiaoshizipingEntity jiaoshiziping, HttpServletRequest request){
jiaoshiziping.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
//ValidatorUtils.validateEntity(jiaoshiziping);
jiaoshizipingService.insert(jiaoshiziping);
return R.ok();
}
/**
* 前端保存
*/
@RequestMapping("/add")
public R add(@RequestBody JiaoshizipingEntity jiaoshiziping, HttpServletRequest request){
jiaoshiziping.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
//ValidatorUtils.validateEntity(jiaoshiziping);
jiaoshizipingService.insert(jiaoshiziping);
return R.ok();
}
/**
* 修改
*/
@RequestMapping("/update")
public R update(@RequestBody JiaoshizipingEntity jiaoshiziping, HttpServletRequest request){
//ValidatorUtils.validateEntity(jiaoshiziping);
jiaoshizipingService.updateById(jiaoshiziping);//全部更新
return R.ok();
}
/**
* 删除
*/
@RequestMapping("/delete")
public R delete(@RequestBody Long[] ids){
jiaoshizipingService.deleteBatchIds(Arrays.asList(ids));
return R.ok();
}
/**
* 提醒接口
*/
@RequestMapping("/remind/{columnName}/{type}")
public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request,
@PathVariable("type") String type,@RequestParam Map map) {
map.put("column", columnName);
map.put("type", type);
if(type.equals("2")) {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
Calendar c = Calendar.getInstance();
Date remindStartDate = null;
Date remindEndDate = null;
if(map.get("remindstart")!=null) {
Integer remindStart = Integer.parseInt(map.get("remindstart").toString());
c.setTime(new Date());
c.add(Calendar.DAY_OF_MONTH,remindStart);
remindStartDate = c.getTime();
map.put("remindstart", sdf.format(remindStartDate));
}
if(map.get("remindend")!=null) {
Integer remindEnd = Integer.parseInt(map.get("remindend").toString());
c.setTime(new Date());
c.add(Calendar.DAY_OF_MONTH,remindEnd);
remindEndDate = c.getTime();
map.put("remindend", sdf.format(remindEndDate));
}
}
Wrapper wrapper = new EntityWrapper();
if(map.get("remindstart")!=null) {
wrapper.ge(columnName, map.get("remindstart"));
}
if(map.get("remindend")!=null) {
wrapper.le(columnName, map.get("remindend"));
}
String tableName = request.getSession().getAttribute("tableName").toString();
if(tableName.equals("jiaoshi")) {
wrapper.eq("jiaoshigonghao", (String)request.getSession().getAttribute("username"));
}
int count = jiaoshizipingService.selectCount(wrapper);
return R.ok().put("count", count);
}
}