java项目:学生管理系统(java+springboot+maven+mybatis+vue+mysql)(代码片段)

qq_1334611189 qq_1334611189     2023-03-09     768

关键词:

一、项目简述


本系统功能包括:
学生管理,教师管理,课程管理,成绩管理,系统管理等等。


二、项目运行

环境配置:


Jdk1.8 + Tomcat8.5 + Mysql + HBuilderX(Webstorm也行)+ Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。


项目技术:


Springboot + Maven + mybatis+ Vue 等等组成,B/S模式 + Maven管理等等。


用户管理控制器:

/**
 * 用户管理控制器
 */
@RequestMapping("/user/")
@Controller
public class UserController 
    @Autowired
    private IUserService userService;
    @Autowired
    private IRoleService roleService;

    @Resource
    private ProcessEngineConfiguration configuration;
    @Resource
    private ProcessEngine engine;

    @GetMapping("/index")
    @ApiOperation("跳转用户页接口")
    @PreAuthorize("hasRole('管理员')")
    public String index(String menuid,Model model)
        List<Role> roles = queryAllRole();
        model.addAttribute("roles",roles);
        model.addAttribute("menuid",menuid);
        //用户首页
        return "views/user/user_list";
    

    @GetMapping("/listpage")
    @ApiOperation("查询用户分页数据接口")
    @ApiImplicitParams(
            @ApiImplicitParam(name = "UserQuery", value = "用户查询对象", defaultValue = "userQuery对象")
    )
    @ResponseBody
    @PreAuthorize("hasRole('管理员')")
    public PageList listpage(UserQuery userQuery)
        return  userService.listpage(userQuery);
    

    //添加用户
    @PostMapping("/addUser")
    @ApiOperation("添加用户接口")
    @ResponseBody
    public Map<String,Object> addUser(User user)
        Map<String, Object> ret = new HashMap<>();
        ret.put("code",-1);
        if(StringUtils.isEmpty(user.getUsername()))
            ret.put("msg","请填写用户名");
            return ret;
        
        if(StringUtils.isEmpty(user.getPassword()))
            ret.put("msg","请填写密码");
            return ret;
        
        if(StringUtils.isEmpty(user.getEmail()))
            ret.put("msg","请填写邮箱");
            return ret;
        
        if(StringUtils.isEmpty(user.getTel()))
            ret.put("msg","请填写手机号");
            return ret;
        
        if(StringUtils.isEmpty(user.getHeadImg()))
            ret.put("msg","请上传头像");
            return ret;
        
        if(userService.addUser(user)<=0) 
            ret.put("msg", "添加用户失败");
            return ret;
        
        ret.put("code",0);
        ret.put("msg","添加用户成功");
        return ret;
    

    /**
     * 修改用户信息操作
     * @param user
     * @return
     */
    @PostMapping("/editSaveUser")
    @ApiOperation("修改用户接口")
    @PreAuthorize("hasRole('管理员')")
    @ResponseBody
    public Message editSaveUser(User user)
        if(StringUtils.isEmpty(user.getUsername()))
          return Message.error("请填写用户名");
        
        if(StringUtils.isEmpty(user.getEmail()))
            return Message.error("请填写邮箱");
        
        if(StringUtils.isEmpty(user.getTel()))
            return Message.error("请填写手机号");
        
        try 
            userService.editSaveUser(user);
            return Message.success();
         catch (Exception e) 
            e.printStackTrace();
            return Message.error("修改用户信息失败");
        

    

    //添加用户
    @GetMapping("/deleteUser")
    @ApiOperation("删除用户接口")
    @ApiImplicitParams(
            @ApiImplicitParam(name = "id", value = "如:88",required = true)
    )
    @PreAuthorize("hasRole('管理员')")
    @ResponseBody
    public AjaxResult deleteUser(@RequestParam(required = true) Long id)
        AjaxResult ajaxResult = new AjaxResult();
        try 
            userService.deleteUser(id);
         catch (Exception e) 
            e.printStackTrace();
            return new AjaxResult("删除失败");
        

        return ajaxResult;
    

    @PostMapping(value="/deleteBatchUser")
    @ApiOperation("批量删除用户接口")
    @PreAuthorize("hasRole('管理员')")
    @ResponseBody
    public AjaxResult deleteBatchUser(String ids)
        String[] idsArr = ids.split(",");
        List list = new ArrayList();
        for(int i=0;i<idsArr.length;i++)
            list.add(idsArr[i]);
        
        try
            userService.batchRemove(list);
            return new AjaxResult();
        catch(Exception e)
           return new AjaxResult("批量删除失败");
        
    

    //查询所有角色
    public List<Role> queryAllRole()
        return roleService.queryAll();
    

    //添加用户的角色
    @PostMapping("/addUserRole")
    @ApiOperation("添加用户角色接口")
    @ApiImplicitParams(
            @ApiImplicitParam(name = "paramMap", value = "如:userId:1,[1,2,3,4]]")
    )
    @ResponseBody
    public AjaxResult addUserRole(@RequestBody Map paramMap)
        AjaxResult ajaxResult = new AjaxResult();
        String userId = (String)paramMap.get("userId");
        List roleIds = (List) paramMap.get("roleIds");
        try 
            //添加用户对应的角色
            roleService.addUserRole(userId,roleIds);
            return ajaxResult;
        catch (Exception e)
            e.printStackTrace();
            return new AjaxResult("保存角色失败");
        

    




    //添加用户
    @RequestMapping("/regSaveUser")
    @ResponseBody
    public Long addTeacher(User user)
        System.out.println("保存用户...."+user);
        userService.addUser(user);

        //保存工作流程操作
        IdentityService is = engine.getIdentityService();
        // 添加用户组
        org.activiti.engine.identity.User userInfo = userService.saveUser(is, user.getUsername());
        // 添加用户对应的组关系
        Group stuGroup = new GroupEntityImpl();
        stuGroup.setId("stuGroup");
        Group tGroup = new GroupEntityImpl();
        tGroup.setId("tGroup");
        if(user.getType() == 2) 
            //保存老师组
            userService.saveRel(is, userInfo, tGroup);
        
        if(user.getType() == 3) 
            //保存学生组
            userService.saveRel(is, userInfo, stuGroup);
        

        Long userId = user.getId();
        return userId;
    

    /**
     * 修改密码页面
     * @return
     */
    @RequestMapping(value="/update_pwd",method=RequestMethod.GET)
    public String updatePwd()
        return "views/user/update_pwd";
    

    /**
     * 修改密码操作
     * @param oldPwd
     * @param newPwd
     * @return
     */
    @ResponseBody
    @PostMapping("/update_pwd")
    public Message updatePassword(@RequestParam(name="oldPwd",required=true)String oldPwd,
                                  @RequestParam(name="newPwd",required=true)String newPwd)
        String username = CommonUtils.getLoginUser().getUsername();
        User userByUserName = userService.findUserByUserName(username);
        if(userByUserName!=null)
            String password = userByUserName.getPassword();
            BCryptPasswordEncoder bCryptPasswordEncoder = new BCryptPasswordEncoder();
            boolean matches = bCryptPasswordEncoder.matches(oldPwd, password);
            if(!matches)
                return Message.error("旧密码不正确");//true
            
            userByUserName.setPassword(bCryptPasswordEncoder.encode(newPwd));

            if(userService.editUserPassword(userByUserName)<=0)
                return Message.error("密码修改失败");
            
        
        return Message.success();
    

    /**
     * 清除缓存
     * @param request
     * @param response
     * @return
     */
    @ResponseBody
    @PostMapping("/clear_cache")
    public Message clearCache(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException 
        response.setHeader("Cache-Control","no-store");
        response.setHeader("Pragrma","no-cache");
        response.setDateHeader("Expires",0);
      return  Message.success();
    

角色控制层:

@Controller
public class RoleController 

    @Autowired
    private IRoleService roleService;

    @Autowired
    private IPermissionService permissionService;




    @PreAuthorize("hasRole('管理员')")
    @ResponseBody
    @RequestMapping("/role/doAdd")
    public String doAdd(Role role)
        //角色添加
        return "ok";
    
    //添加角色
    @RequestMapping("/role/addRole")
    @PreAuthorize("hasRole('管理员')")
    @ResponseBody
    public AjaxResult addRole(Role role)
        System.out.println("保存角色...."+role);
        try 
            roleService.saveRole(role);
            return new AjaxResult();
         catch (Exception e) 
            e.printStackTrace();
            return new AjaxResult("操作失败");
        
    

    @PreAuthorize("hasRole('管理员')")
    @RequestMapping("/role/index")
    public String index(Model model)
        List<Permission> permisisons = permissionService.findAllPermisisons();
        model.addAttribute("permissions",permisisons);
        //返回角色
        return "views/role/role_list";
    

    @RequestMapping("/role/listpage")
    @ResponseBody
    public PageList listpage(RoleQuery roleQuery)
        System.out.println("传递参数:"+roleQuery);
        return  roleService.listpage(roleQuery);
    


    //修改用户editSaveUser
    @RequestMapping("/role/editSaveRole")
    @ResponseBody
    public AjaxResult editSaveRole(Role role)
        System.out.println("修改角色...."+role);
        try 
            roleService.editSaveRole(role);
            return new AjaxResult();
         catch (Exception e) 
            e.printStackTrace();
        
        return new AjaxResult("修改失败");
    

    //添加角色
    @RequestMapping("/role/deleteRole")
    @ResponseBody
    public AjaxResult deleteRole(Long id)
        System.out.println("删除角色...."+id);
        AjaxResult ajaxResult = new AjaxResult();
        try 
            roleService.deleteRole(id);
         catch (Exception e) 
            e.printStackTrace();
            return new AjaxResult("删除失败");
        
        return ajaxResult;
    

    //添加角色权限 addRolePermission
    @RequestMapping("/role/addRolePermission")
    @ResponseBody
    public AjaxResult addRolePermission(@RequestBody Map paramMap)
        AjaxResult ajaxResult = new AjaxResult();
        String roleId = (String)paramMap.get("roleId");
        List permissionIds = (List) paramMap.get("permissionIds");
        try 
            //添加角色对应的权限
            roleService.addRolePermission(roleId,permissionIds);
            return ajaxResult;
        catch (Exception e)
            e.printStackTrace();
            return new AjaxResult("保存权限失败");
        

    


 

权限维护Controller:

/**
 *  权限维护Controller
 */
@RequestMapping("/permission")
@Controller
public class PermissionController 

    @Autowired
    private IPermissionService permissionService;

    @PreAuthorize("hasRole('管理员')")
    @RequestMapping("/index")
    public String index(Model model)
        List<Permission> allPermisisons = permissionService.findAllPermisisons();
        model.addAttribute("permissions",allPermisisons);
        //返回菜单页面
        return "views/permission/permission_list";
    

    //添加顶级菜单 addTopMenu
    @PreAuthorize("hasRole('管理员')")
    @RequestMapping("/addBtnPermisison")
    @ResponseBody
    public AjaxResult addBtnPermission(@RequestBody Permission permission)
        AjaxResult ajaxResult = new AjaxResult();
        try
            //name:xxx,pid:xxx,title:xxx
            permissionService.addBtnPermisison(permission);
            return ajaxResult;
        catch(Exception e)
            e.printStackTrace();
            return new AjaxResult("保存失败");
        
    

    /**
     * 编辑数据操作
     * @param id
     * @return
     */
    @PreAuthorize("hasRole('管理员')")
    @GetMapping("/editPermission")
    @ResponseBody
    public Map<String,Object> editPermission(@RequestParam("id")Long id)
        Map<String, Object> ret = new HashMap<>();
        ret.put("code","-1");
        Permission byId = permissionService.findById(id);
        if(byId==null)
            ret.put("msg","未找到该权限");
            return ret;
        
        ret.put("code",0);
        ret.put("data",byId);
        return ret;
    


    /**
     * 编辑权限数据操作
     * @param permission
     * @return
     */
    @PreAuthorize("hasRole('管理员')")
    @PostMapping("/editPermission")
    @ResponseBody
    public Map<String,Object> editPermission(Permission permission)
        Map<String, Object> ret = new HashMap<>();
        ret.put("code","-1");
        if(StringUtils.isEmpty(permission.getName()))
            ret.put("msg","请填写权限值");
            return ret;
        
        if(StringUtils.isEmpty(permission.getTitle()))
            ret.put("msg","请填写权限名称");
            return ret;
        
        if(permissionService.edit(permission)<=0)
            ret.put("msg","权限编辑失败");
            return ret;
        
        ret.put("code",0);
        return ret;
    

    /**
     * 根据id删除权限
     * @param id
     * @return
     */
    @PreAuthorize("hasRole('管理员')")
    @ResponseBody
    @PostMapping("/deletePermission")
    public Map<String,Object> deletePermission(@RequestParam("id")Long id)
        Map<String, Object> ret = new HashMap<>();
        ret.put("code","-1");
        try
            permissionService.deleteById(id);
        catch (Exception e)
            ret.put("msg","删除失败,存在关联数据");
            return ret;
        
        ret.put("code",0);
        return ret;
    



java项目:教务管理系统(java+jsp+spring+springboot+layui+maven)

...目简述功能包括:三角色教师管理员,学生教务管理系统,包括院系管理,课题综合管理,信息管理,以及差旅管理,学生选题等等。二、项目运行环境配置:Jdk1.8+Tomcat8.5+mysql+Eclispe(... 查看详情

java项目:教务管理系统(java+jsp+spring+springboot+layui+maven)

...目简述功能包括:三角色教师管理员,学生教务管理系统,包括院系管理,课题综合管理,信息管理,以及差旅管理,学生选题等等。二、项目运行环境配置:Jdk1.8+Tomcat8.5+mysql+Eclispe(... 查看详情

2020年java实训项目gui学生信息管理系统目录

Java实训项目1:GUI学生信息管理系统-实训概述Java实训项目2:GUI学生信息管理系统-系统概述Java实训项目3:GUI学生信息管理系统-涉及知识点Java实训项目4:GUI学生信息管理系统-项目结构图Java实训项目5:GUI学生信息管理系统-实现... 查看详情

java项目:教材领取和发放管理系统源(java+spring+springmvc+mybatis+mysql)(代码片段)

主要有三个角色:分别是管理员、学生、教师。管理员权限:学生、教师管理专业、课程、班级、学院、年级管理、供应商、教材出入库管理、个人信息管理、付款记录等学生:领取教材、教材缴费、教材退货等。老师... 查看详情

java项目:学生宿舍管理系统设计和实现(javaweb+jsp+servlet)

主要技术:spring、jsp、servlet、mysql、tomcat  、jsp、jquery、css、c390、cookie、session技术,实现功能:不同角色登录、宿舍管理员管理、学生信息管理、宿舍信息管理、学生缺勤管理、修改密码和退出功能。系统功能截图如下&... 查看详情

java项目:宿舍管理系统(java+jsp+ssm+spring+mysql)

 一、项目简述功能:包括学生管理,班级管理,宿舍管理,人员信息维护。维修登记,卫生管理,访客管理等等。二、项目运行环境配置:Jdk1.8+Tomcat8.5+mysql+ldea2019(IntelliJIDEA,Eclispe,MyEclispe,Sts... 查看详情

java精品项目源码前后端分离项目第13期学生管理系统

Java精品项目源码前后端分离项目第13期学生管理系统大家好,小辰今天给大家介绍一个基于SpringBoot+Vue实现的学生管理系统,演示视频文章末尾公众号(小辰哥的java)对号查询观看即可文章目录Java精品项目源... 查看详情

java项目:学生信息管理系统(java+ssm+jsp+mysql+maven)(代码片段)

一、项目简述功能包括:用户的登录注册,学生信息管理,教师信息管理,班级信息管理,采用mvcx项目架构,覆盖增删改查,包括学生,教币班级的信息导出上传导入等等功能。二、项目运行环境... 查看详情

java精品项目源码第43期一体化学生考勤系统

Java精品项目源码第43期一体化学生考勤系统大家好,小辰今天给大家介绍一个一体化学生考勤系统,演示视频公众号(小辰哥的java)对号查询观看即可文章目录Java精品项目源码第43期一体化学生考勤系统难度指数... 查看详情

java项目:学生信息管理系统(java+ssm+jsp+layui+maven+mysql)

 一、项目简述功能包括:三角色管理:学生,教师,管理员,在线选课,成绩录入,学生管理,选课管理,教室管理等等。学生管理可以查看所有学生并操作、添加学生;查看学生选报课程详情... 查看详情

基于java+spring+vue+elementui大学生求职招聘系统详细设计实现(代码片段)

.../阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌🍅文末获取联系🍅精彩专栏推荐订阅👇🏻👇🏻不然下次找不到哟 java项目精品实战案例《100套》Java微信小程序项目实战《100套》Java... 查看详情

手把手搭建java学生信息管理系统附源码

基于JavaWeb的学生信息管理系统的设计与实现一、系统简介本课程演示的是一套基于JavaWeb实现的学生信息管理系统,主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的java人群。详细介绍了学生信息管理系统的实... 查看详情

java项目:学生管理系统(java+springboot+maven+mybatis+vue+mysql)

 一、项目简述本系统功能包括:学生管理,教师管理,课程管理,成绩管理,系统管理等等。二、项目运行环境配置:Jdk1.8+Tomcat8.5+Mysql+HBuilderX(Webstorm也行)+Eclispe(IntelliJIDEA,Ec 查看详情

基于java开发幼儿园管理系统项目教程(附源码)

...战教学,提示项目开发能力。课程简介:幼儿园管理系统,共分为三种角色,管理员、家长、教师。管理员角色具有功能:系统管理-用户管理、页面管理、角色管理校园管理-老师管理、工资管理、物资管理、... 查看详情

基于java+spring+mysql+jquery实现学生管理系统(代码片段)

🍅作者主页:Java李杨勇 🍅简介:Java领域优质创作者🏆、【java李杨勇】公号作者✌ 简历模板、学习资料、面试题库【关注我,都给你】🍅文末获取源码联系🍅 临近学期结束,还是毕业设... 查看详情

java项目:学生成绩管理(java+springboot+maven+mysql)(代码片段)

使用框架SpringBoot+Mybatis发布每日会员绩效管理系统项目功能有:教师端:学生管理、成绩管理、学生总成绩查询学生端:学生信息管理、成绩查询、总成绩查询运行环境:windows/Linux内核、jdk1.8、mysql5.7、idea/ecli... 查看详情

java课程设计--学生成绩管理系统

一、团队名称:团队成员林艺薇201721123032网络1712黄毓颖201721123033网络1712唐川201721123034网络1712梁才玉201721123038网络1712任务分配二、项目git地址https://gitee.com/ev32/keshe/tree/master三、项目git提交记录截图四、项目功能架构图与主要功... 查看详情

java项目:星月宿舍学生管理系统(java+ssm+jsp+mysql+easyui)

系统分为前台和后台,前台功能有:综合信息查询、宿舍查询、住宿查询。后台管理员功能有:班级管理、学生管理、信息管理、住宿管理、宿舍管理等。运行环境:jdk1.8、mysql5.x、tomcat7.0\\8.5、eclipse     了解... 查看详情