• SpringBoot+Vue实现前后端分离OA办公管理系统


    文末获取源码

    开发语言:Java

    使用框架:spring boot

    前端技术:JavaScript、Vue.js 、css3

    开发工具:IDEA/MyEclipse/Eclipse、Visual Studio Code

    数据库:MySQL 5.7/8.0

    数据库管理工具:phpstudy/Navicat

    JDK版本:Java jdk8

    Maven:apache-maven 3.8.1-bin

    目录

    一、前言介绍

    二、数据库设计

    2.1考勤统计E-R图

    2.2职员OA审批E-R图

    三、管理员功能模块 

    3.1系统登陆页面

    3.2职员用户添加模块

    3.3职员考勤模块

    3.4职员任务管理模块

    3.5职员OA审批模块

    四、职员用户模块 

    4.1通知公告模块

    4.2职员考勤模块

    五、部分核心代码

    5.1用户管理关键代码

    5.2考勤信息管理关键代码

    5.3登录关键代码


    一、前言介绍

    一个企业实现办公自动化的程度是衡量其实现现代化管理的标准。办公自动化就是采用Internet技术,基于工作流的概念,使企业内部人员方便快捷地共享信息,高效协同工作。

    OA办公管理系统主要功能模块包括管理员、职员用户、管理层用户、通知公告、职员考勤、管理层考勤、职员任务管理、管理层任务管理、职员OA审批、管理员OA审批、笔记心得等,采取面对对象的开发模式进行软件的开发和硬体的架设,能很好的满足实际使用的需求,完善了对应的软体架设以及程序编码的工作,采取MySQL作为后台数据的主要存储单元,采用SringBoot框架、Java技术、Ajax技术进行业务系统的编码及其开发,实现了本系统的全部功能。本次报告,首先分析了研究的背景、作用、意义,为研究工作的合理性打下了基础。针对OA办公管理系统的各项需求以及技术问题进行分析,证明了系统的必要性和技术可行性,然后对设计系统需要使用的技术软件以及设计思想做了基本的介绍,最后来实现OA办公管理系统和部署运行使用它。

    二、数据库设计

    数据库是整个软件编程中最重要的一个步骤,对于数据库问题主要是判定数据库的数量和结构公式的创建。展示系统使用的是Mysql进行对数据库进行管理,进行保证数据的安全性、稳定性等。

    概念模型的设计是为了抽象真实世界的信息,并对信息世界进行建模。它是数据库设计的强大工具。数据库概念模型设计可以通过E-R图描述现实世界的概念模型。系统的E-R图显示了系统中实体之间的链接。而且Mysql数据库是自我保护能力比较强的数据库,下图主要是对数据库实体的E-R图:

    2.1考勤统计E-R图

    2.2职员OA审批E-R图

    三、管理员功能模块 

    3.1系统登陆页面

    3.2职员用户添加模块

    3.3职员考勤模块

    3.4职员任务管理模块

    3.5职员OA审批模块

    四、职员用户模块 

    4.1通知公告模块

    4.2职员考勤模块

    五、部分核心代码

    5.1用户管理关键代码

    1. @RequestMapping(value = "/del")
    2. @Transactional
    3. public Map del(HttpServletRequest request) {
    4. service.delete(service.readQuery(request), service.readConfig(request));
    5. return success(1);
    6. }

    5.2考勤信息管理关键代码

    1. @PostMapping("/add")
    2. @Transactional
    3. public Map<String, Object> add(HttpServletRequest request) throws IOException {
    4. service.insert(service.readBody(request.getReader()));
    5. return success(1);
    6. }
    7. @Transactional
    8. public Map<String, Object> addMap(Map<String,Object> map){
    9. service.insert(map);
    10. return success(1);
    11. }

    5.3登录关键代码

    1. /**
    2. * 登录
    3. * @param data
    4. * @param httpServletRequest
    5. * @return
    6. */
    7. @PostMapping("login")
    8. public Map<String, Object> login(@RequestBody Map<String, String> data, HttpServletRequest httpServletRequest) {
    9. log.info("[执行登录接口]");
    10. String username = data.get("username");
    11. String email = data.get("email");
    12. String phone = data.get("phone");
    13. String password = data.get("password");
    14. List resultList = null;
    15. QueryWrapper wrapper = new QueryWrapper<User>();
    16. Map<String, String> map = new HashMap<>();
    17. if(username != null && "".equals(username) == false){
    18. map.put("username", username);
    19. resultList = service.selectBaseList(service.select(map, new HashMap<>()));
    20. }
    21. else if(email != null && "".equals(email) == false){
    22. map.put("email", email);
    23. resultList = service.selectBaseList(service.select(map, new HashMap<>()));
    24. }
    25. else if(phone != null && "".equals(phone) == false){
    26. map.put("phone", phone);
    27. resultList = service.selectBaseList(service.select(map, new HashMap<>()));
    28. }else{
    29. return error(30000, "账号或密码不能为空");
    30. }
    31. if (resultList == null || password == null) {
    32. return error(30000, "账号或密码不能为空");
    33. }
    34. //判断是否有这个用户
    35. if (resultList.size()<=0){
    36. return error(30000,"用户不存在");
    37. }
    38. User byUsername = (User) resultList.get(0);
    39. Map<String, String> groupMap = new HashMap<>();
    40. groupMap.put("name",byUsername.getUserGroup());
    41. List groupList = userGroupService.selectBaseList(userGroupService.select(groupMap, new HashMap<>()));
    42. if (groupList.size()<1){
    43. return error(30000,"用户组不存在");
    44. }
    45. UserGroup userGroup = (UserGroup) groupList.get(0);
    46. //查询用户审核状态
    47. if (!StringUtils.isEmpty(userGroup.getSourceTable())){
    48. String res = service.selectExamineState(userGroup.getSourceTable(),byUsername.getUserId());
    49. if (res==null){
    50. return error(30000,"用户不存在");
    51. }
    52. if (!res.equals("已通过")){
    53. return error(30000,"该用户审核未通过");
    54. }
    55. }
    56. //查询用户状态
    57. if (byUsername.getState()!=1){
    58. return error(30000,"用户非可用状态,不能登录");
    59. }
    60. String md5password = service.encryption(password);
    61. if (byUsername.getPassword().equals(md5password)) {
    62. // 存储Token到数据库
    63. AccessToken accessToken = new AccessToken();
    64. accessToken.setToken(UUID.randomUUID().toString().replaceAll("-", ""));
    65. accessToken.setUser_id(byUsername.getUserId());
    66. tokenService.save(accessToken);
    67. // 返回用户信息
    68. JSONObject user = JSONObject.parseObject(JSONObject.toJSONString(byUsername));
    69. user.put("token", accessToken.getToken());
    70. JSONObject ret = new JSONObject();
    71. ret.put("obj",user);
    72. return success(ret);
    73. } else {
    74. return error(30000, "账号或密码不正确");
    75. }
    76. }
    77. public String select(Map<String,String> query,Map<String,String> config){
    78. StringBuffer sql = new StringBuffer("select ");
    79. sql.append(config.get(FindConfig.FIELD) == null || "".equals(config.get(FindConfig.FIELD)) ? "*" : config.get(FindConfig.FIELD)).append(" ");
    80. sql.append("from ").append("`").append(table).append("`").append(toWhereSql(query, "0".equals(config.get(FindConfig.LIKE))));
    81. if (config.get(FindConfig.GROUP_BY) != null && !"".equals(config.get(FindConfig.GROUP_BY))){
    82. sql.append("group by ").append(config.get(FindConfig.GROUP_BY)).append(" ");
    83. }
    84. if (config.get(FindConfig.ORDER_BY) != null && !"".equals(config.get(FindConfig.ORDER_BY))){
    85. sql.append("order by ").append(config.get(FindConfig.ORDER_BY)).append(" ");
    86. }
    87. if (config.get(FindConfig.PAGE) != null && !"".equals(config.get(FindConfig.PAGE))){
    88. int page = config.get(FindConfig.PAGE) != null && !"".equals(config.get(FindConfig.PAGE)) ? Integer.parseInt(config.get(FindConfig.PAGE)) : 1;
    89. int limit = config.get(FindConfig.SIZE) != null && !"".equals(config.get(FindConfig.SIZE)) ? Integer.parseInt(config.get(FindConfig.SIZE)) : 10;
    90. sql.append(" limit ").append( (page-1)*limit ).append(" , ").append(limit);
    91. }
    92. log.info("[{}] - 查询操作,sql: {}",table,sql);
    93. return sql.toString();
    94. }
    95. public List selectBaseList(String select) {
    96. List<Map<String,Object>> mapList = baseMapper.selectBaseList(select);
    97. List<E> list = new ArrayList<>();
    98. for (Map<String,Object> map:mapList) {
    99. list.add(JSON.parseObject(JSON.toJSONString(map),eClass));
    100. }
    101. return list;
    102. }
  • 相关阅读:
    pyflink连接iceberg 实践
    varchar与char区别,以及最大长度
    ES定期清理索引
    中国之声广播在线收听,云听“正直播”在路上
    线程池处理异常的方法
    MySQL——子查询和嵌套查询
    郑州中创|业绩下滑、股价大跌……Meta为何继续坚持元宇宙
    PTA 7-3 插松枝(单调栈)
    产品经理看过来,2023年NPDP考试日期来了!
    spark 窗口滑动用于在不同的数据块之间执行操作
  • 原文地址:https://blog.csdn.net/m0_49113107/article/details/127415005