基于SpringBoot+Vue的OA管理系统

计算机毕设项目资讯获取:

大家点赞、收藏、关注、评论啦 、查看👇🏻👇🏻👇🏻获取项目下载链接,博主联系方式👇🏻👇🏻👇🏻

链接点击直达:下载链接


一、项目背景介绍:

办公自动化(Office Automation,简称OA),是将计算机、通信等现代化技术运用到传统办公方式,进而形成的一种新型办公方式。办公自动化利用现代化设备和信息化技术,代替办公人员传统的部分手动或重复性业务活动,优质而高效地处理办公事务和业务信息,实现对信息资源的高效利用,进而达到提高生产率、辅助决策的目的,最大限度地提高工作效率和质量、改善工作环境

二、项目技术简介:

  1. JAVA:Java是一门面向对象编程语言,不仅吸收了C++语言的各种优点,还摒弃了C++里难以理解的多继承、指针等概念,因此Java语言具有功能强大和简单易用两个特征。Java语言作为静态面向对象编程语言的代表,极好地实现了面向对象理论,允许程序员以优雅的思维方式进行复杂的编程。
  2. Vue:Vue (发音为 /vjuː/,类似 view) 是一款用于构建用户界面的JavaScript框架。它基于标准HTML、CSS和JavaScript构建,并提供了一套声明式的、组件化的编程模型,帮助开发者高效地开发用户界面。
    Vue是一个独立的社区驱动的项目,它是由尤雨溪在2014年作为其个人项目创建, 是一个成熟的、经历了无数实战考验的框架,它是目前生产环境中使用最广泛的JavaScript框架之一,可以轻松处理大多数web应用的场景,并且几乎不需要手动优化,并且Vue完全有能力处理大规模的应用。
  3. Element-UI:Element,一套为开发者、设计师和产品经理准备的基于 Vue 2.0 的桌面端组件库。
  4. SpringBoot:Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。通过这种方式,Spring Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导者。
  5. Mybatis-Plus:MyBatis-Plus(简称 MP)是一个 MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为 简化开发、提高效率而生。

三、系统功能模块介绍:

功能模块图

四、数据库设计:

1:‘报销管理’(claim)

字段名类型默认值列注释
idbigintNULL主键ID
emp_idbigintNULL员工ID
infovarcharNULL申请理由
append_urlvarcharNULL附件链接
create_timedatetimeNULL申请时间
totalvarcharNULL申请金额
statusintNULL状态[0:已提交,1:申请通过,2:申请驳回,3已撤回]
leave_infovarcharNULL拒绝理由

2:‘员工表’(emps)

字段名类型默认值列注释
idbigintNULL主键ID
namevarcharNULL姓名
sexintNULL性别[0:男,1:女,2:未知]
birthdaydatetimeNULL出生日期
id_cardvarcharNULL身份证号
addressvarcharNULL家庭住址
ageintNULL年龄
phonevarcharNULL联系方式
work_statevarcharNULL就职状态[0:在职,1:离职]
join_timedatetimeNULL入职时间
leave_timedatetimeNULL离职时间
salaryvarcharNULL基本工资
create_timedatetimeNULL创建时间
user_namevarcharNULL账号
pass_wordvarcharNULL密码
imgvarcharNULL照片
bank_novarcharNULL银行卡号
leader_idbigintNULL组长id
positionvarcharNULL职务[前端开发,后端开发,UI测试]

3:‘文件资源信息表’(file)

字段名类型默认值列注释
idbigintNULL主键
create_timedatetimeNULL发布时间
create_namevarcharNULL创建人姓名
file_namevarcharNULL文件名称
filevarcharNULL文件

4:‘组长表’(leader)

字段名类型默认值列注释
idbigintNULL主键ID
namevarcharNULL姓名
sexintNULL性别[0:男,1:女,2:未知]
birthdaydatetimeNULL出生日期
id_cardvarcharNULL身份证号
addressvarcharNULL家庭住址
ageintNULL年龄
phonevarcharNULL联系方式
work_statevarcharNULL就职状态[0:在职,1:离职]
join_timedatetimeNULL入职时间
leave_timedatetimeNULL离职时间
salaryvarcharNULL基本工资
create_timedatetimeNULL创建时间
user_namevarcharNULL账号
pass_wordvarcharNULL密码
imgvarcharNULL照片
bank_novarcharNULL银行卡号
positionvarcharNULL职务[前端开发,后端开发,UI测试]

5:‘员工请假表’(leaves)

字段名类型默认值列注释
idbigintNULL主键ID
emp_idbigintNULL员工ID
start_timedatetimeNULL开始时间
end_timedatetimeNULL结束时间
infotextNULL申请理由
statusintNULL状态[0:未审批,1:通过,2:拒绝,3:撤回]
refused_indovarcharNULL拒绝理由
create_timedatetimeNULL创建时间

6:‘管理员表’(manage)

字段名类型默认值列注释
idbigintNULL主键ID
user_namevarcharNULL用户名
pass_wordvarcharNULL密码
head_imgvarcharNULL头像
nick_namevarcharNULL昵称
create_timedatetimeNULL创建时间

7:‘会议表’(meets)

字段名类型默认值列注释
idbigintNULL主键ID
titlevarcharNULL会议标题
append_urlvarcharNULL附件链接
statusintNULL状态[0:未发送,1:已发送]
create_timedatetimeNULL创建时间

8:‘通知表’(noticle)

字段名类型默认值列注释
idbigintNULL主键ID
notice_infotextNULL通知内容
titlevarcharNULL通知标题
create_timedatetimeNULL创建时间
stausintNULL状态[0:已发送,1:未发送]

9:‘打卡表’(punchs)

字段名类型默认值列注释
idbigintNULL主键ID
emp_idbigintNULL员工ID
handle_timedateNULL日期
typeintNULL状态[0:正常,1:请假]

10:‘报告表’(reports)

字段名类型默认值列注释
idbigintNULL主键ID
emp_idbigintNULL员工ID
contenttextNULL报告内容
typeintNULL类型[0:日报,1:周报,2:月报]
append_urlvarcharNULL附件URL
create_timedateNULL汇报时间

11:‘工资表’(salary)

字段名类型默认值列注释
idbigintNULL主键ID
emp_idbigintNULL员工ID
totalvarcharNULL工资总额
basicvarcharNULL基本工资
with_holdvarcharNULL扣款
add_moneyvarcharNULL其他金额
month_timevarcharNULL月份
infovarcharNULL说明

12:‘员工日程表’(schedules)

字段名类型默认值列注释
idbigintNULL主键ID
emp_idbigintNULL员工ID
contenttextNULL日程内容
create_timedateNULL创建时间

五、功能模块:

  1. 考勤模块:员工可通过系统进行每日打卡,请假,请假需要管理员进行审核,管理员可以拒绝亦可以通过,拒绝时可以填写拒绝理由

    考勤模块

  2. 会议通知模块:管理员可以向员工发布会议通知,以及日常通知,会议通知则可以添加附件,而普通通知则会以markdown的格式向员工进行展示多样化的内容,并且员工可以实时收取到通知

    会议通知模块

  3. 日程模块:员工可以给自己添加每日计划来提醒自己,然后也可以编写日报周报或者年报,管理员则可以查看员工填写的内容

    日程模块

  4. 报销工资模块:员工可以提交报销申请,管理员进行审核,管理员通过每个月员工的考勤状况,报销情况为员工进行工资录入

    报销工资模块

  5. 文件资源上传:管理员和组长可以上传资源,员只能查看下载

    文件资源上传

  6. 报告查看:查看报告信息,管理员可以查看所有的,其他员工只能查看自己的报告信息

    报告查看

  7. 打卡记录查看:管理员可以查看所有的打卡记录信息

    打卡记录查看

  8. 首页信息:在系统首页可以查看打卡记录,今日打卡,试试刷新通知和会议信息

    首页信息

六、代码示例:

考勤模块
@Override
    protected void beforeSave(PunchsDTO entity) throws Exception {
        String formatNow = LocalDateTimeUtils.formatNow(LocalDateTimeUtils.yyyy_MM_dd);
        LambdaQueryWrapper<PunchsDTO> queryWrapper = new LambdaQueryWrapper<>();
        queryWrapper.eq(PunchsDTO::getHandleTime, formatNow);
        List<PunchsDTO> punchsDTOS = this.baseService.list(queryWrapper);
        if (CollectionUtil.isNotEmpty(punchsDTOS)) throw new Exception("当日已打卡,不可重复打卡!");
        entity.setHandleTime(new Date());
        super.beforeSave(entity);
    }
会议通知模块
 /**
     * 员工获取会议
     *
     * @return
     */
    @GetMapping("/emp")
    public ReturnMsg getEmpNotice() {
        LambdaQueryWrapper<MeetsDTO> queryWrapper = new LambdaQueryWrapper<>();
        queryWrapper.eq(MeetsDTO::getStatus, 1).orderByDesc(MeetsDTO::getCreateTime).last("limit 5");
        return ReturnMsg.ok(this.baseService.list(queryWrapper));
    }
日程模块
 @GetMapping("/all/emps")
    public ReturnMsg allEmps() {
        List<BaseSelectEntity> list = new ArrayList<>();
        List<EmpsDTO> dtos = empsService.list();
        for (EmpsDTO dto : dtos) {
            BaseSelectEntity baseSelectEntity = new BaseSelectEntity();
            baseSelectEntity.setKey(dto.getId());
            baseSelectEntity.setValue(dto.getName());
            list.add(baseSelectEntity);
        }
        return ReturnMsg.ok(list);
    }

    @GetMapping("/current/{empId}")
    public ReturnMsg current(@PathVariable Long empId) {
        LambdaQueryWrapper<SchedulesDTO> queryWrapper = new LambdaQueryWrapper<>();
        queryWrapper.eq(SchedulesDTO::getEmpId,empId).eq(SchedulesDTO::getCreateTime, LocalDateTimeUtils.formatNow(LocalDateTimeUtils.yyyy_MM_dd)).last("limit 1");
        return ReturnMsg.ok(baseService.getOne(queryWrapper));
    }
    /**
     * 生成验证码
     */
    @GetMapping("/captchaImage")
    public AjaxResult getCode(HttpServletResponse response) throws IOException
    {
        AjaxResult ajax = AjaxResult.success();
        boolean captchaEnabled = configService.selectCaptchaEnabled();
        ajax.put("captchaEnabled", captchaEnabled);
        if (!captchaEnabled)
        {
            return ajax;
        }

        // 保存验证码信息
        String uuid = IdUtils.simpleUUID();
        String verifyKey = CacheConstants.CAPTCHA_CODE_KEY + uuid;

        String capStr = null, code = null;
        BufferedImage image = null;

        // 生成验证码
        String captchaType = RuoYiConfig.getCaptchaType();
        if ("math".equals(captchaType))
        {
            String capText = captchaProducerMath.createText();
            capStr = capText.substring(0, capText.lastIndexOf("@"));
            code = capText.substring(capText.lastIndexOf("@") + 1);
            image = captchaProducerMath.createImage(capStr);
        }
        else if ("char".equals(captchaType))
        {
            capStr = code = captchaProducer.createText();
            image = captchaProducer.createImage(capStr);
        }

        redisCache.setCacheObject(verifyKey, code, Constants.CAPTCHA_EXPIRATION, TimeUnit.MINUTES);
        // 转换流信息写出
        FastByteArrayOutputStream os = new FastByteArrayOutputStream();
        try
        {
            ImageIO.write(image, "jpg", os);
        }
        catch (IOException e)
        {
            return AjaxResult.error(e.getMessage());
        }

        ajax.put("uuid", uuid);
        ajax.put("img", Base64.encode(os.toByteArray()));
        return ajax;
    }
    /**
     * 通用的本地文件上传
     *
     * @param multipartFile 文件对象
     * @return 文件访问链接URL
     */
    @PostMapping("/file")
    public SimpleResponse uploadImg(@RequestParam("file") MultipartFile file) {
        // 文件后缀
        String suffix = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".") + 1);
        File savePathFile = new File(newTomcatFolder);
        if (!savePathFile.exists()) {
            // 若不存在该目录,则创建目录
            savePathFile.mkdir();
        }
        // 通过UUID生成唯一文件名
        String filename = UUID.randomUUID() + "." + suffix;
        try {
            // 将文件保存指定目录
            file.transferTo(new File(newTomcatFolder + filename));
        } catch (Exception e) {
            e.printStackTrace();
            return SimpleResponse.error("保存文件异常");
        }
        // 返回访问链接
        return SimpleResponse.success(newTomcatHost + filename);
    }
    @PostMapping("/login")
    public ReturnMsg manageLogin(@RequestBody Map<String, String> param) {
        if (StrUtil.isEmpty(param.get("username")) || StrUtil.isEmpty(param.get("password"))) {
            return ReturnMsg.error("用户名或密码错误!");
        }
        ManageDTO manageDTO = new ManageDTO();
        manageDTO.setUserName(param.get("username"));
        manageDTO.setPassWord(param.get("password"));
        QueryWrapper<ManageDTO> manageDTOQueryWrapper = new QueryWrapper<>(manageDTO);
        manageDTOQueryWrapper.last("limit 1");
        ManageDTO adminDTOS = manageService.getOne(manageDTOQueryWrapper);
        if (adminDTOS == null) return ReturnMsg.error("用户名或密码错误!");
        Map<String, Object> map = new HashMap<>();
        map.put("avatar", StrUtil.isNotBlank(adminDTOS.getPhotoImg()) ? adminDTOS.getPhotoImg() : "https://wpimg.wallstcn.com/f778738c-e4f8-4870-b634-56703b4acafe.gif");
        map.put("introduction", adminDTOS.getName() + ",你好!");
        map.put("name", adminDTOS.getName());
        map.put("roles", Arrays.asList("admin"));
        map.put("type", adminDTOS.getStatus());
        Map<String, String> returnMap = new HashMap<>();
        String uuid = UUID.randomUUID().toString();
        returnMap.put("token", uuid);
        userInfoMap.put(uuid, JSON.toJSONString(map));
        return ReturnMsg.ok(returnMap);
    }

七、项目总结:

作为毕业设计,分配给本系统的设计与制作时间还是不足的,所以,OA系统还有许多需要完善的地方。

    第一个就是本系统的编程代码问题,各个程序文件的代码存在冗余的地方非常多,导致代码不够简洁,同时对代码的注释也比较麻烦。编码期间,对于很多页面可以共享的函数与方法都没有单独列出来,而是在需要用到函数和方法的页面上都重新编写了代码,通过后期的技术学习,以及对编码过程的分析总结,发现可以把共用的函数或方法编写在同一个页面上,在之后的页面中,需要使用此函数的页面,则可以直接调用函数,无需再编写代码了,这样可以简化代码,也能节省时间和存储空间。

    第二个就是对数据库的设计不够好,在数据处理中,影响程序运行速度。因此需要对数据库的性能进行优化。通过这方面知识的学习,在某个开发技术类的博客中,发现可以用数据库连接池技术来解决数据库的性能问题,另外还需规范数据库里面的关系模式,降低数据库的冗余率,提高运行速度。

    如果说平时的作业也是检查对知识的掌握情况,那么制作毕业设计,将是对自身所有知识的一个全面检测。因为系统能够制作完成则是经历了很多阶段,正如文中所展示的那样,先有可行性分析,对功能的分析,对功能的设计,对数据库的设计,对程序功能的编码实现,对完成编码程序的测试等,这些环节缺一不可,而且还都需要认真对待,大学学到的所有知识在制作系统时,才会发现不够用。所以这个项目制作,在检测自身能力的同时,也对问题分析,资料搜集,问题解决等能力进行了培养。
  • 19
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SpringBoot是一个开发框架,能够简化Java应用的开发过程,而Vue是一种用于构建用户界面的JavaScript框架。OA(Office Automation)则是办公自动化的缩写,是指利用信息技术来实现办公流程的自动化,包括工作流程、协同办公、文档管理等。 SpringBootVue可以结合使用来开发OA系统。首先,我们可以使用SpringBoot来构建后端的服务,提供API接口给前端调用。SpringBoot可以帮助我们快速搭建项目结构,集成数据库访问、认证授权、消息队列等常用功能。同时,SpringBoot还有丰富的第三方依赖库和插件,可以方便地集成其他的组件和工具。 而Vue则可以作为前端的框架,用于构建用户界面和处理用户交互。Vue有着良好的响应式设计和组件化开发模式,可以提高开发效率和代码复用性。Vue可以与SpringBoot通过API进行数据交互,实现前后端的数据传输和状态管理。 对于OA流程的实现,可以使用工作流引擎来管理流程,如Activiti。Activiti是一个开源的BPM(Business Process Management)平台,可以帮助我们实现流程定义、流程实例管理和任务分配等功能。通过Activiti,我们可以将整个OA流程进行建模,包括流程图的设计、任务节点的定义和流程变量的设置。 OA流程的源码可以通过使用SpringBootVue来进行开发。后端可以使用SpringBoot来构建API接口,并集成Activiti来实现流程管理。前端可以使用Vue来构建用户界面,并通过API调用后端的服务。通过这种方式,我们可以利用SpringBootVue的优势来快速开发和部署OA流程应用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值