作者主页:夜未央5788
简介:Java领域优质创作者、Java项目、学习资料、技术互助
文末获取源码
项目介绍
管理员:
登录,修改密码和个人资料,管理员用户用户,教师管理,学生管理,课程管理等功能。
学生角色包含以下功能:
学生登录注册,修改信息和密码,教师查询,学生管理,课程管理等功能。
由于本程序规模不大,可供课程设计,毕业设计学习演示之用
环境需要
1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。
2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA;
3.tomcat环境:Tomcat 7.x,8.x,9.x版本均可
4.硬件环境:windows 7/8/10 1G内存以上;或者 Mac OS;
5.数据库:MySql 5.7版本;
技术栈
1. 后端:mysql+Spring+hibernate+spring mcv
2. 前端:HTML+CSS+JavaScript+jsp
使用说明
1. 使用Navicat或者其它工具,在mysql中创建对应名称的数据库,并导入项目的sql文件;
2. 使用IDEA/Eclipse/MyEclipse导入项目,Eclipse/MyEclipse导入时,若为maven项目请选择maven;若为maven项目,导入成功后请执行maven clean;maven install命令,然后运行;
3. 将项目中application.yml配置文件中的数据库配置改为自己的配置;
4. 运行项目,输入localhost:8080/ 登录
运行截图
相关代码
管理员控制器
@Controller
@RequestMapping("/manage/")
public class ManageController {
@Autowired
private ManageService manageService;
private static final Logger log = LoggerFactory.getLogger(ManageController.class);
/**
* @author 张靖烽
* @description 管理员登录
* @createtime 2017-12-27 12:45
*/
@RequestMapping(value = "login.do", method = RequestMethod.POST)
@ResponseBody
public ServerResponse login(String username, String password, HttpSession session, HttpServletResponse response) {
//验证用户登录信息是否正确
ServerResponse sr = manageService.login(username, password);
//验证通过,将当前用户信息放入session
if (sr.isSuccess()) {
CookieUtil.writeCookie(response, session.getId());
RedisPoolUtil.setEx(session.getId(), JacksonUtil.objToString(sr.getData()), 60 * 30);
}
return sr;
}
/**
* @author 张靖烽
* @description 获取教师信息&&查询教师
* @createtime 2018-01-17 15:01
*/
@RequestMapping("queryTeacher.do")
@ResponseBody
public ServerResponse queryTeacher(HttpServletRequest request, Teacher teacher,
@RequestParam(value = "pageNum", defaultValue = "1") int pageNum,
@RequestParam(value = "pageSize", defaultValue = "10") int pageSize) {
//判断登录
// String token = CookieUtil.readCookie(request);
// if (StringUtils.isEmpty(token)) {
// return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
// }
// String manageStr = RedisPoolUtil.get(token);
// Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
// if (manager == null) {
// return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
// }
// //判断权限,业务处理
// if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
return manageService.queryTeacher(teacher, pageNum, pageSize);
// }
// return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
/**
* @author 张靖烽
* @description 新增或修改教师信息
* @createtime 2018-01-05 10:12
*/
@RequestMapping("addOrUpdateTeacher.do")
@ResponseBody
public ServerResponse addOrUpdateTeacher(HttpServletRequest request, Teacher teacher) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String manageStr = RedisPoolUtil.get(token);
Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
if (manager == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
//判断权限,业务处理
if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
return manageService.addOrModifyTeacher(teacher, manager);
}
return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
/**
* @author 张靖烽
* @description 获取单条教师信息
* @createtime 2018-01-05 10:12
*/
@RequestMapping("getTeacherInfo.do")
@ResponseBody
public ServerResponse getTeacherInfo(HttpServletRequest request, Integer pkTeacher) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String manageStr = RedisPoolUtil.get(token);
Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
if (manager == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
//判断权限,业务处理
if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
return manageService.getTeacherInfo(pkTeacher);
}
return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
/**
* @author 张靖烽
* @description 删除教师
* @createtime 2018-01-05 10:12
*/
@RequestMapping("delTeacher.do")
@ResponseBody
public ServerResponse delTeacher(HttpServletRequest request, Integer pkTeacher) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String manageStr = RedisPoolUtil.get(token);
Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
if (manager == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
//判断权限,业务处理
if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
return manageService.delTeacher(pkTeacher);
}
return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
/**
* @author 张靖烽
* @description 查询学生
* @createtime 2018-01-17 15:01
*/
@RequestMapping("queryStudent.do")
@ResponseBody
public ServerResponse queryStudent(HttpServletRequest request, Student student,
@RequestParam(value = "pageNum", defaultValue = "1") int pageNum,
@RequestParam(value = "pageSize", defaultValue = "10") int pageSize) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String manageStr = RedisPoolUtil.get(token);
Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
if (manager == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
//判断权限,业务处理
if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
return manageService.queryStudent(student, pageNum, pageSize);
}
return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
/**
* @author 张靖烽
* @description 新增或修改学生信息
* @createtime 2018-01-05 10:12
*/
@RequestMapping("addOrUpdateStudent.do")
@ResponseBody
public ServerResponse addOrUpdateStudent(HttpServletRequest request, Student student) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String manageStr = RedisPoolUtil.get(token);
Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
if (manager == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
//判断权限,业务处理
if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
return manageService.addOrModifyStudent(student, manager);
}
return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
/**
* @author 张靖烽
* @description 获取单条学生信息
* @createtime 2018-01-05 10:18
*/
@RequestMapping("getStudentInfo.do")
@ResponseBody
public ServerResponse getStudentInfo(HttpServletRequest request, Integer pkStudent) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String manageStr = RedisPoolUtil.get(token);
Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
if (manager == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
//判断权限,业务处理
if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
return manageService.getStudentInfo(pkStudent);
}
return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
/**
* @author 张靖烽
* @description 删除学生
* @createtime 2018-01-05 10:18
*/
@RequestMapping("delStudent.do")
@ResponseBody
public ServerResponse delStudent(HttpServletRequest request, Integer pkStudent) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String manageStr = RedisPoolUtil.get(token);
Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
if (manager == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
//判断权限,业务处理
if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
return manageService.delStudent(pkStudent);
}
return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
/**
* @author 张靖烽
* @description 查看教师关联班级
* @createtime 2018-01-05 10:12
*/
@RequestMapping("getRelTeacherMajor.do")
@ResponseBody
public ServerResponse getRelTeacherMajor(HttpServletRequest request, Integer pkTeacher) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String manageStr = RedisPoolUtil.get(token);
Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
if (manager == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
//判断权限,业务处理
if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
return manageService.getRelTeacherMajor(pkTeacher);
}
return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
/**
* @author 张靖烽
* @description 新增教师关联班级
* @createtime 2018-01-05 10:12
*/
@RequestMapping("addRelTeacherMajor.do")
@ResponseBody
public ServerResponse addRelTeacherMajor(HttpServletRequest request, Integer pkTeacher, Integer pkMajor) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String manageStr = RedisPoolUtil.get(token);
Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
if (manager == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
//判断权限,业务处理
if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
return manageService.addRelTeacherMajor(pkTeacher, pkMajor, manager);
}
return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
/**
* @author 张靖烽
* @description 删除教师关联班级
* @createtime 2018-01-05 10:12
*/
@RequestMapping("delRelTeacherMajor.do")
@ResponseBody
public ServerResponse delRelTeacherMajor(HttpServletRequest request, Integer pkTeacher, Integer pkMajor) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String manageStr = RedisPoolUtil.get(token);
Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
if (manager == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
//判断权限,业务处理
if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
log.info(manager.getPkManager() + "执行了删除教师:" + pkTeacher + " 关联的:" + pkMajor + " 专业的操作");
return manageService.delRelTeacherMajor(pkTeacher, pkMajor);
}
return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
/**
* @author 张靖烽
* @description 获取年级
* @createtime 2018-02-01 22:46
*/
@RequestMapping("getGrade.do")
@ResponseBody
public ServerResponse getGrade(HttpServletRequest request) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String manageStr = RedisPoolUtil.get(token);
Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
if (manager == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
//判断权限,业务处理
if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
return manageService.getGrade();
}
return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
/**
* @author 张靖烽
* @description 获取指定年级下专业
* @createtime 2018-02-01 22:46
*/
@RequestMapping("getMajor.do")
@ResponseBody
public ServerResponse getMajor(HttpServletRequest request, String grade) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String manageStr = RedisPoolUtil.get(token);
Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
if (manager == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
//判断权限,业务处理
if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
return manageService.getMajor(grade);
}
return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
/**
* @author 张靖烽
* @description 获取教师关联的专业信息
* @createtime 2018-02-02 13:34
*/
@RequestMapping("getTeacherMajor.do")
@ResponseBody
public ServerResponse getTeacherMajor(HttpServletRequest request, Integer pkTeacher,
@RequestParam(value = "pageNum", defaultValue = "1") int pageNum,
@RequestParam(value = "pageSize", defaultValue = "5") int pageSize) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String manageStr = RedisPoolUtil.get(token);
Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
if (manager == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
//判断权限,业务处理
if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
return manageService.getTeacherMajor(pkTeacher, pageNum, pageSize);
}
return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
/**
* @author 张靖烽
* @description 获取专业信息&&查询专业
* @createtime 2018-01-17 15:01
*/
@RequestMapping("queryMajor.do")
@ResponseBody
public ServerResponse queryMajor(HttpServletRequest request, Major major,
@RequestParam(value = "pageNum", defaultValue = "1") int pageNum,
@RequestParam(value = "pageSize", defaultValue = "10") int pageSize) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String manageStr = RedisPoolUtil.get(token);
Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
if (manager == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
//判断权限,业务处理
if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
return manageService.queryMajor(major, pageNum, pageSize);
}
return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
/**
* @author 张靖烽
* @description 查看单条专业信息
* @createtime 2018-01-05 10:27
*/
@RequestMapping("getMajorInfo.do")
@ResponseBody
public ServerResponse getMajorInfo(HttpServletRequest request, Integer pkMajor) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String manageStr = RedisPoolUtil.get(token);
Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
if (manager == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
//判断权限,业务处理
if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
return manageService.getMajorInfo(pkMajor);
}
return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
/**
* @author 张靖烽
* @description 新增或修改年级专业信息
* @createtime 2018-01-05 10:27
*/
@RequestMapping("addOrUpdateMajor.do")
@ResponseBody
public ServerResponse addOrUpdateMajor(HttpServletRequest request, Major major) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String manageStr = RedisPoolUtil.get(token);
Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
if (manager == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
//判断权限,业务处理
if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
return manageService.addOrModifyMajor(major, manager);
}
return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
/**
* @author 张靖烽
* @description 删除年级专业信息
* @createtime 2018-01-05 10:27
*/
@RequestMapping("delMajor.do")
@ResponseBody
public ServerResponse delMajor(HttpServletRequest request, Integer pkMajor) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String manageStr = RedisPoolUtil.get(token);
Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
if (manager == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
//判断权限,业务处理
if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
return manageService.delMajor(pkMajor);
}
return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
/**
* @author 张靖烽
* @description 重置教师密码
* @createtime 2018-01-17 11:19
*/
@RequestMapping("resetTeacherPwd.do")
@ResponseBody
public ServerResponse resetTeacherPwd(HttpServletRequest request, Integer pkTeacher) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String manageStr = RedisPoolUtil.get(token);
Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
if (manager == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
//判断权限,业务处理
if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
return manageService.resetTeacherPwd(pkTeacher);
}
return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
/**
* @author 张靖烽
* @description 重置学生密码
* @createtime 2018-01-17 11:19
*/
@RequestMapping("resetStudentPwd.do")
@ResponseBody
public ServerResponse resetStudentPwd(HttpServletRequest request, Integer pkStudent) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String manageStr = RedisPoolUtil.get(token);
Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
if (manager == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
//判断权限,业务处理
if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
return manageService.resetStudentPwd(pkStudent);
}
return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
}
通知管理控制器
@Controller
@RequestMapping("/notice/")
public class NoticeController {
@Autowired
private NoticeService noticeService;
/**
* @author 张靖烽
* @description 获取有效通知内容,用于首页展示
* @createtime 2017-12-29 12:44
*/
@RequestMapping("showNotice.do")
@ResponseBody
public ServerResponse showNotice(HttpServletRequest request, Notice notice,
@RequestParam(value = "pageNum", defaultValue = "1") int pageNum,
@RequestParam(value = "pageSize", defaultValue = "100") int pageSize) {
//判断用户是否登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String userStr = RedisPoolUtil.get(token);
if (StringUtils.isBlank(userStr)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
notice.setFlag("Y");
return noticeService.queryNotice(notice, pageNum, pageSize);
}
/**
* @author 张靖烽
* @description 查询通知
* @createtime 2017-12-29 12:44
*/
@RequestMapping("queryNotice.do")
@ResponseBody
public ServerResponse queryNotice(HttpServletRequest request, Notice notice,
@RequestParam(value = "pageNum", defaultValue = "1") int pageNum,
@RequestParam(value = "pageSize", defaultValue = "10") int pageSize) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String manageStr = RedisPoolUtil.get(token);
Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
if (manager == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
//判断权限,业务处理
if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
return noticeService.queryNotice(notice, pageNum, pageSize);
}
return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
/**
* @author 张靖烽
* @description 新增或更新通知
* @createtime 2017-12-29 12:51
*/
@RequestMapping("addOrModifyNotice.do")
@ResponseBody
public ServerResponse addOrModifyNotice(HttpServletRequest request, Notice notice) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String manageStr = RedisPoolUtil.get(token);
Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
if (manager == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
//判断权限,业务处理
if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
return noticeService.addOrModifyNotice(notice, manager);
}
return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
/**
* @author 张靖烽
* @description 获取单条通知内容
* @createtime 2018-01-04 8:54
*/
@RequestMapping("getNotice.do")
@ResponseBody
public ServerResponse getNotice(HttpServletRequest request, Integer pkNotice) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String manageStr = RedisPoolUtil.get(token);
Manager manager = JacksonUtil.stringToObj(manageStr, Manager.class);
if (manager == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
//判断权限,业务处理
if (Constant.Role.ROLE_ADMIN.equals(manager.getRole())) {
return noticeService.getNotice(pkNotice);
}
return ServerResponse.createByErrorMessage("不是管理员,无法操作");
}
}
学生管理控制器
@Controller
@RequestMapping("/student/")
public class StudentController {
private static final Logger log = LoggerFactory.getLogger(StudentController.class);
@Autowired
private StudentService studentService;
/**
* @author 张靖烽
* @description 用户登录
* @createtime 2017-12-27 12:45
*/
@RequestMapping(value = "login.do", method = RequestMethod.POST)
@ResponseBody
public ServerResponse login1(String username, String password, HttpSession session,HttpServletResponse response) {
//验证用户登录信息是否正确
ServerResponse sr = studentService.login(username, password);
//验证通过,将当前用户信息放入session
if (sr.isSuccess()) {
CookieUtil.writeCookie(response, session.getId());
RedisPoolUtil.setEx(session.getId(), JacksonUtil.objToString(sr.getData()), 60 * 30);
}
return sr;
}
/**
* @author 张靖烽
* @description 获取用户信息
* @createtime 2018-01-09 14:02
*/
@RequestMapping(value = "getUserName.do", method = RequestMethod.POST)
@ResponseBody
public ServerResponse getUserName(HttpServletRequest request) {
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String studentStr = RedisPoolUtil.get(token);
Student student = JacksonUtil.stringToObj(studentStr, Student.class);
if (student != null) {
StudentVO studentVO = studentService.setStudentVO(student);
return ServerResponse.createBySuccess(studentVO);
}
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
/**
* @author 张靖烽
* @description 未登录:忘记密码,获取问题
* @createtime 2018-01-12 12:48
*/
@RequestMapping(value = "forgetGetQuestion.do", method = RequestMethod.POST)
@ResponseBody
public ServerResponse<String> forgetGetQuestion(String username) {
return studentService.selectQuestion(username);
}
/**
* @author 张靖烽
* @description 未登录:忘记密码,检查答案是否正确
* @createtime 2018-01-12 12:48
*/
@RequestMapping(value = "forgetCheckAnswer.do", method = RequestMethod.POST)
@ResponseBody
public ServerResponse<String> forgetCheckAnswer(String username, String question, String answer) {
return studentService.checkAnswer(username, question, answer);
}
/**
* @author 张靖烽
* @description 未登录:忘记密码,重置密码
* @createtime 2018-01-12 12:48
*/
@RequestMapping(value = "forgetResetPassword.do", method = RequestMethod.POST)
@ResponseBody
public ServerResponse<String> forgetRestPassword(String username, String passwordNew, String forgetToken) {
return studentService.forgetResetPassword(username, passwordNew, forgetToken);
}
/**
* @author 张靖烽
* @description 已登录,重置密码
* @createtime 2018-01-12 12:49
*/
@RequestMapping(value = "resetPassword.do", method = RequestMethod.POST)
@ResponseBody
public ServerResponse<String> resetPassword(HttpServletRequest request, String passwordOld, String passwordNew) {
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String studentStr = RedisPoolUtil.get(token);
Student student = JacksonUtil.stringToObj(studentStr, Student.class);
if (student == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
return studentService.resetStudentPassword(passwordNew, passwordOld, student);
}
/**
* @author 张靖烽
* @description 设置或更新找回密码问题和答案
* @createtime 2018-01-12 12:49
*/
@RequestMapping(value = "updateStudentInformation.do", method = RequestMethod.POST)
@ResponseBody
public ServerResponse updateStudentInformation(HttpServletRequest request, String question, String answer) {
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String studentStr = RedisPoolUtil.get(token);
Student student = JacksonUtil.stringToObj(studentStr, Student.class);
if (student == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
return studentService.updateStudentInformation(question, answer, student);
}
/**
* @author 张靖烽
* @description 查询待完成的试卷
* @createtime 2018-01-12 12:49
*/
@RequestMapping(value = "getUnfinishedPaper.do", method = RequestMethod.POST)
@ResponseBody
public ServerResponse getUnfinishedPaper(HttpServletRequest request) {
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String studentStr = RedisPoolUtil.get(token);
Student student = JacksonUtil.stringToObj(studentStr, Student.class);
if (student == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
return studentService.getUnfinishedPaper(student);
}
/**
* @author 张靖烽
* @description 获取试卷内容
* @createtime 2018-03-29 19:36
*/
@RequestMapping("getPaperDetail.do")
@ResponseBody
public ServerResponse getPaperDetail(HttpServletRequest request, Integer pkPaper) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String studentStr = RedisPoolUtil.get(token);
Student student = JacksonUtil.stringToObj(studentStr, Student.class);
if (student == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
return studentService.getPaperDetail(pkPaper, student);
}
/**
* @author 张靖烽
* @description 学生交卷,计算分数
* @createtime 2018-03-29 20:23
*/
@RequestMapping("submitPaper.do")
@ResponseBody
public ServerResponse submitPaper(HttpServletRequest request, Integer pkPaper, String testsAndAnswer) {
//判断登录
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String studentStr = RedisPoolUtil.get(token);
Student student = JacksonUtil.stringToObj(studentStr, Student.class);
if (student == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
return studentService.submitPaper(pkPaper, student, testsAndAnswer);
}
/**
* @author 张靖烽
* @description 学生查询成绩
* @createtime 2018-04-03 9:39
*/
@RequestMapping("inquiryScore.do")
@ResponseBody
public ServerResponse inquiryScore(HttpServletRequest request) {
//判断登录
try {
String token = CookieUtil.readCookie(request);
if (StringUtils.isEmpty(token)) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
String studentStr = RedisPoolUtil.get(token);
Student student = JacksonUtil.stringToObj(studentStr, Student.class);
if (student == null) {
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "请先登录");
}
return studentService.inquiryScore(student);
} catch (Exception e) {
log.error("学生查询成绩:" + e);
return ServerResponse.createByErrorCodeMessage(ResponseCode.NEED_LOGIN.getCode(), "未登录或无权限");
}
}
}
如果也想学习本系统,下面领取。关注并回复:087ssh