博主主页:猫头鹰源码
博主简介:Java领域优质创作者、CSDN博客专家、公司架构师、全网粉丝5万+、专注Java技术领域和毕业设计项目实战
主要内容:毕业设计(Javaweb项目|小程序等)、简历模板、学习资料、面试题库、技术咨询
文末联系获取
该系统创作于2022年3月,包含详细数据库设计。基于springboot技术,数据层为MyBatis,mysql数据库,具有完整的业务逻辑,适合选题:高校、学生选课、实践、实践成长、大学选课、实践课程等。
- 分为3个角色
-
- 管理员
- 创建课程,选择教师和学生
- 增删改查课程信息,学生信息和教师信息
- 修改学生的课程分数
- 统计各课程各学生的得分情况,可以进行增删改查功能
- 可以对成绩进行统计,图表形式对能力进行分析
-
- 教师
- 登陆注册,查看修改个人信息
- 创建课程,选择学生,取消选择学生,查看学生信息
- 给学生的课程打分,包括专业能力,工程能力,创新能力和其他非技术能力和评价
- 统计该课程学生的分数情况,不及格标红,对学生分数排序,可以进行增删改查功能
-
- 学生
- 登录注册,查看修改个人信息
- 选择加入课程,查看课程信息和分数
- 查看不同课程对应的得分情况
后端:springboot、mybatis
前端:layui,js,css等
开发工具:idea
数据库:mysql 5.7
JDK版本:jdk1.8
下面是登录页面
管理员首页
管理员 对教师进行维护
管理员 对学生进行维护
管理员 课程管理
选课管理
对不同学生进行能力分析
教师添加课程
学生进行选课
拦截器
- @Override
- public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
- HttpSession session = request.getSession();
- if(session.getAttribute("ad") != null){
- return true;
- }
- // 不符合条件的给出提示信息,并转发到主页面
- request.setAttribute("msg", "您还没有登录,请先登录!");
- request.getRequestDispatcher("/gologin.jsp").forward(request, response);
- //返回true通过,返回false拦截
- return false;
- }
登录功能
- /**
- * 登录
- * 将提交数据(username,password)写入Admin对象
- */
- @RequestMapping(value = "/login")
- public String login(Teacher teacher, Model model, HttpSession session, HttpServletRequest request) {
- if(teacher.getUsername()==null || teacher.getUsername().length()<=0 ){
- model.addAttribute("msg", "请输入登录名!");
- return "login";
- }
- if(teacher.getPassword()==null || teacher.getPassword().length()<1){
- model.addAttribute("msg", "请输入密码!");
- return "login";
- }
- if(teacher.getType()==null || teacher.getType().length()<1){
- model.addAttribute("msg", "请选择人员类型!");
- return "login";
- }
- Map mp = new HashMap();
- mp.put("username",teacher.getUsername());
- mp.put("password",teacher.getPassword());
- if(teacher.getType().equals("01")){
- List<Admin> ad = adminService.queryFilter(mp);
- if(ad!=null && ad.size()==1){
- session.setAttribute("ad", ad.get(0));
- session.setAttribute("type", "01");
- return "homepage1";
- }else{
- model.addAttribute("msg", "请确定账户信息是否正确!");
- return "login";
- }
- }else if(teacher.getType().equals("02")){
- List<Teacher> ad = teacherService.queryFilter(mp);
- if(ad!=null && ad.size()==1){
- session.setAttribute("ad", ad.get(0));
- session.setAttribute("type", "02");
- return "homepage2";
- }else{
- model.addAttribute("msg", "请确定账户信息是否正确!");
- return "login";
- }
- }else{
- List<Student> ad = studentService.queryFilter(mp);
- if(ad!=null && ad.size()==1){
- session.setAttribute("ad", ad.get(0));
- session.setAttribute("type", "03");
- return "homepage3";
- }else{
- model.addAttribute("msg", "请确定账户信息是否正确!");
- return "login";
- }
- }
- }
学生相关操作
- /**
- * 分页查询
- * pageIndex 当前页码
- * pageSize 显示条数
- */
- @RequestMapping(value = "/findStudent")
- public String findStudent(Integer pageIndex, Integer pageSize,String realname, Model model,HttpServletRequest request) {
- HttpSession session = request.getSession();
- if(session.getAttribute("ad") == null){
- session.setAttribute("msg", "对不起,请登录!");
- return "login";
- }
- Map mp = new HashMap();
- mp.put("realname",realname);
- PageInfo<Student> pageList = studentService.findPageInfo(pageIndex,pageSize,mp);
- model.addAttribute("pageList",pageList);
- return "StudentList";
- }
-
-
- /**
- * 添加
- */
- @RequestMapping(value = "/addStudent" ,method = RequestMethod.POST)
- @ResponseBody
- public String addStudent( @RequestBody Student student) {
- try{
- List<Student> studentList = studentService.getAll();
- for(int i=0;i<studentList.size();i++){
- if(student.getUsername().equals(studentList.get(i).getUsername())){
- return "202";
- }
- }
- SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
- student.setCreateTime(sf.format(new Date()));
- studentService.addStudent(student);
- return "200";
- }catch (Exception e){
- e.printStackTrace();
- return "201";
- }
- }
-
-
- /**
- * 删除
- */
- @RequestMapping( "/deleteStudent")
- @ResponseBody
- public String deleteStudent(String id) {
- int d = studentService.deleteStudent(id);
- return "StudentList";
- }
-
-
- /**
- * 修改
- */
- @RequestMapping( "/updateStudent")
- @ResponseBody
- public String updateStudent(@RequestBody Student student) {
- try{
- List<Student> studentList = studentService.getAll();
- for(int i=0;i<studentList.size();i++){
- if(student.getUsername().equals(studentList.get(i).getUsername()) && !student.getId().equals(studentList.get(i).getId())){
- return "202";
- }
- }
- studentService.updateStudent(student);
- return "200";
- }catch (Exception e){
- e.printStackTrace();
- return "201";
- }
- }
以上就是部分功能展示,从整体上来看,本系统功能是十分完整的,界面设计简洁大方,交互友好,数据库设计也很合理,规模适中,代码工整,清晰,适合学习使用。
好了,今天就到这儿吧,小伙伴们点赞、收藏、评论,一键三连走起呀,下期见~~