基于Java+SpringBoot+Vue求职招聘系统设计与实现
创始人
2024-05-12 16:39:38
0

博主介绍全网粉丝3W+,全栈开发工程师,从事多年软件开发,在大厂呆过。持有软件中级、六级等证书。可提供微服务项目搭建与毕业项目实战

博主作品:《微服务实战》专栏是本人的实战经验总结,《Spring家族及微服务系列》专注Spring、SpringMVC、SpringBoot、SpringCloud系列、Nacos等源码解读、热门面试题、架构设计等。除此之外还有不少文章等你来细细品味,更多惊喜等着你哦

🍅文末获取联系🍅精彩专栏推荐订阅👇🏻👇🏻 不然下次找不到哟

 ✨【微服务】Nacos为什么丢弃短连接(http)而选择拥抱长连接(gRPC)

目录

一、前言

二、系统设计

1、系统运行环境

2、系统架构设计

三、需求分析简介

1、个人用户

2、企业用户

3、管理员

四、功能截图

1、系统首页

2、求职用户功能界面

2.1、首页

2.2、我的收藏

2.3、我的简历

2.4、简历投递状态

3、企业用户功能界面

3.1、首页 

3.2、企业信息维护与认证

3.3、发布职位

3.4、约面试

4、管理员功能界面

4.1、首页

4.2、企业认证审核

4.3、职位认证审核

4.4、权限管理

五、代码实现 

1、ApplicationController控制类

2、ApplicationServiceImpl实现类

六、源码获取


一、前言

    招聘系统将为招聘者和求职者构建一个功能齐全、方便快捷的招聘平台,减少双方投入招聘活动的成本,为招聘求职双方带来便利,系统将实现如下目标: (1)针对系统内的不同角色,系统能够赋予其不同的操作权限。招聘者和求职者可以通过此系统进行招聘和求职工作。招聘者可以在系统进行职位的发布和下架,同时可以查看收到的投递简历,对应聘简历进行筛选,对于符合招聘需求的求职者预约面试;求职者可以通过此系统进行职位查看、收藏、简历制作和投递、查看投递状况和面试情况等操作;平台管理员能够管理职位类别和对企业信息、职位进行审核。

二、系统设计

1、系统运行环境

开发系统:Windows10

架构模式:MVC/前后端分离

JDK版本:Java JDK1.8

开发工具:IDEA

数据库版本: mysql5.7

数据库可视化工具: SQL yog或Navicat for MySQL

服务器:SpringBoot自带 apache tomcat

主要技术:Java、SpringBoot、MyBatis-plus、MySQL、Html、Vue、Elementui等

2、系统架构设计

三、需求分析简介

    招聘平台系统的用户共分为三类:个人用户、企业用户、管理员。

1、个人用户

    求职用户首先完成注册登录,维护自己的简历信息,也可以实时浏览企业发布的招聘信息,按自己的要求筛选出合适的企业从而决定投递简历、可以收藏职位、关注企业,并可以在企业应答之后收到相应的回复、查看面试信息等。求职用户的用例图如图3-1所示。

                                图3-1 个人用户用例图

2、企业用户

    企业用户首先注册将用户信息录入系统,登录后先完成企业认证等待系统管理员审核,审核通过后发布招聘岗位,也可以实时浏览求职者投递的简历进行筛选,简历通过的就可以发送面试通知。企业用户的用例图如图3-2所示。

                                  图3-2 企业用户用例图

3、管理员

    管理员首先完成注册登录,可以进行用户管理、角色管理以及授予系统权限,手动操作企业认证审核的流程、手动操作职位认证审核以及职位分类的管理维护。管理员的用例图如图3-3所示。

                                 图3-3 管理员用例图

四、功能截图

注意:这里只是展示部分功能界面,想了解更多功能请下载或克隆源码运行起来。

1、系统首页

 注意:部分截图。

2、求职用户功能界面

2.1、首页

2.2、我的收藏

2.3、我的简历

    求职者填写完简历信息后,点击简历预览系统自动组装成简历,求职者可以点击导出简历按钮获取自己的简历去打印。

2.4、简历投递状态

3、企业用户功能界面

3.1、首页 

3.2、企业信息维护与认证

3.3、发布职位

3.4、约面试

4、管理员功能界面

4.1、首页

4.2、企业认证审核

4.3、职位认证审核

4.4、权限管理

五、代码实现 

1、ApplicationController控制类

@RestController
@RequestMapping("/recruit/application")
@PermissionModule(value = "申请")
public class ApplicationController {@Autowiredprivate ApplicationService applicationService;@Autowiredprivate InterviewService interviewService;/*** 投递简历——添加申请* @return CreatedVO*/@Logger(template = "投递简历")@PostMapping("")@GroupRequired@PermissionMeta(value = "投递简历")public CreatedVO create(@RequestBody ApplicationDO applicationDO) {applicationService.create(applicationDO);return new CreatedVO(7000);}/*** 根据申请id修改状态state* @param id id* @param state state* @return UpdatedVO*/@Logger(template = "处理简历")@PutMapping("/state/{id}")@GroupRequired@PermissionMeta(value = "申请审核")public UpdatedVO update(@PathVariable @Positive(message = "{id.positive}") Integer id,@RequestParam Integer state) {// 根据id查找申请ApplicationDO applicationDO = applicationService.getById(id);if (applicationDO == null) {throw new NotFoundException(70000);}// 更新申请状态applicationService.updateState(id, state);// 若简历通过则插入面试表,初始状态为0,未面试if(state==1){InterviewDO interviewDO=new InterviewDO();interviewDO.setResumeId(applicationDO.getResumeId());interviewDO.setHrId(applicationDO.getHrId());interviewDO.setUserId(applicationDO.getUserId());interviewDO.setCompanyId(applicationDO.getCompanyId());interviewDO.setPositionId(applicationDO.getPositionId());interviewDO.setStatus(0);interviewService.getBaseMapper().insert(interviewDO);}return new UpdatedVO(7100);}/*** 根据id撤销申请(只有未处理的申请才可以撤销,即state=0的申请才可以撤销)* @param id id* @return DeletedVO*/@Logger(template = "撤销职位申请")@DeleteMapping("/{id}")@GroupRequired@PermissionMeta(value = "撤销申请")public DeletedVO delete(@PathVariable @Positive(message = "{id.positive}") Integer id) {// 根据id查找申请ApplicationDO applicationDO = applicationService.getById(id);if (applicationDO == null) {throw new NotFoundException(70000);}applicationService.removeById(id);return new DeletedVO(7200);}/*** 根据用户id和职位id查询申请表,避免重复投递同个岗位* @param positionId positionId* @param userId userId* @return Boolean*/@GetMapping("")public Boolean get(@RequestParam Integer positionId, @RequestParam Integer userId) {QueryWrapper wrapper = new QueryWrapper<>();wrapper.eq("position_id", positionId).eq("user_id", userId);ApplicationDO applicationDO = applicationService.getOne(wrapper);if (applicationDO == null) {return true;}return false;}/*** 根据hr_id查询该hr接收到的所有简历,并且根据state区分申请的状态* @param count count* @param page page* @param hrID hrID* @param state state* @return 应聘简历*/@Logger(template = "查看应聘简历")@GetMapping("/page/{hrID}")@GroupRequired@PermissionMeta(value = "简历管理")public PageResponseVO page(@RequestParam(name = "count", required = false, defaultValue = "10")@Min(value = 1, message = "{page.count.min}")@Max(value = 30, message = "{page.count.max}") Integer count,@RequestParam(name = "page", required = false, defaultValue = "0")@Min(value = 0, message = "{page.number.min}") Integer page,@PathVariable(value = "hrID") @Positive(message = "{id.positive}") Integer hrID,@RequestParam Integer state) {return applicationService.getByHrId(count, page, hrID, state);}/*** 根据hr_id查询该hr接收到的所有简历,并且根据简历的分数进行排序* @param count count* @param page page* @param hrID hrID* @return 简历排序*/@GroupRequired@PermissionMeta(value = "简历排序")@GetMapping("/sort/{hrID}")public PageResponseVO sort(@RequestParam(name = "count", required = false, defaultValue = "10")@Min(value = 1, message = "{page.count.min}")@Max(value = 30, message = "{page.count.max}") Integer count,@RequestParam(name = "page", required = false, defaultValue = "0")@Min(value = 0, message = "{page.number.min}") Integer page,@PathVariable(value = "hrID") @Positive(message = "{id.positive}") Integer hrID) {return applicationService.sort(count, page, hrID);}/*** 根据user_id查询用户的所有申请,并且根据state区分申请的状态* @param count count* @param page page* @param userId userId* @return 我的投递箱*/@Logger(template = "查看简历投递状况")@GetMapping("/page/find/{userId}")@GroupRequired@PermissionMeta(value = "我的投递箱")public PageResponseVO pageByUserId(@RequestParam(name = "count", required = false, defaultValue = "10")@Min(value = 1, message = "{page.count.min}")@Max(value = 30, message = "{page.count.max}") Integer count,@RequestParam(name = "page", required = false, defaultValue = "0")@Min(value = 0, message = "{page.number.min}") Integer page,@PathVariable(value = "userId") @Positive(message = "{id.positive}") Integer userId) {PageResponseVO res = applicationService.getByUserId(count, page, userId);return res;}
}

2、ApplicationServiceImpl实现类

@Slf4j
@Service
public class ApplicationServiceImpl extends ServiceImpl implements ApplicationService {@Resourceprivate ApplicationMapper applicationMapper;@Autowiredprivate ResumeService resumeService;@Overridepublic boolean create(ApplicationDO applicationDO) {UserDO localUser = LocalUser.getLocalUser();if (localUser == null) {throw new RuntimeException("用户信息为空");}applicationDO.setUserId(localUser.getId());applicationDO.setState(1);LambdaQueryWrapper queryWrapper = Wrappers.lambdaQuery().eq(ResumeDO::getUserId, localUser.getId());ResumeDO resumeDO = this.resumeService.getBaseMapper().selectOne(queryWrapper);if (resumeDO == null) {throw new RuntimeException("求职者简历信息不存在,请先填写简历!!!");}applicationDO.setResumeId(resumeDO.getId());return applicationMapper.insert(applicationDO) > 0;}@Overridepublic PageResponseVO getByHrId(Integer count,Integer page,Integer hrID,Integer state) {Page pager = new Page<>(page, count);IPage paging = applicationMapper.getByHrId(pager, hrID, state);return PageUtil.build(paging);}@Overridepublic boolean updateState(Integer id, Integer state) {return applicationMapper.updateState(id, state);}@Overridepublic PageResponseVO sort(Integer count, Integer page, Integer hrID) {Page pager = new Page<>(page, count);IPage paging = applicationMapper.sortByGrade(pager, hrID);return PageUtil.build(paging);}@Overridepublic PageResponseVO getByUserId(Integer count,Integer page,Integer userId) {Page pager = new Page<>(page, count);IPage paging = applicationMapper.getByUserId(pager, userId);return PageUtil.build(paging);}}

六、源码获取

 大家点赞、收藏、关注、评论啦 、关注下方公众号获取联系方式👇🏻👇🏻

上一篇:fork函数详解

下一篇:第10章 FreeRTOS

相关内容

热门资讯

常用商务英语口语   商务英语是以适应职场生活的语言要求为目的,内容涉及到商务活动的方方面面。下面是小编收集的常用商务...
六年级上册英语第一单元练习题   一、根据要求写单词。  1.dry(反义词)__________________  2.writ...
复活节英文怎么说 复活节英文怎么说?复活节的英语翻译是什么?复活节:Easter;"Easter,anniversar...
2008年北京奥运会主题曲 2008年北京奥运会(第29届夏季奥林匹克运动会),2008年8月8日到2008年8月24日在中华人...
英语道歉信 英语道歉信15篇  在日常生活中,道歉信的使用频率越来越高,通过道歉信,我们可以更好地解释事情发生的...
六年级英语专题训练(连词成句... 六年级英语专题训练(连词成句30题)  1. have,playhouse,many,I,toy,i...
上班迟到情况说明英语   每个人都或多或少的迟到过那么几次,因为各种原因,可能生病,可能因为交通堵车,可能是因为天气冷,有...
小学英语教学论文 小学英语教学论文范文  引导语:英语教育一直都是每个家长所器重的,那么有关小学英语教学论文要怎么写呢...
英语口语学习必看的方法技巧 英语口语学习必看的方法技巧如何才能说流利的英语? 说外语时,我们主要应做到四件事:理解、回答、提问、...
四级英语作文选:Birth ... 四级英语作文范文选:Birth controlSince the Chinese Governmen...
金融专业英语面试自我介绍 金融专业英语面试自我介绍3篇  金融专业的学生面试时,面试官要求用英语做自我介绍该怎么说。下面是小编...
我的李老师走了四年级英语日记... 我的李老师走了四年级英语日记带翻译  我上了五个学期的小学却换了六任老师,李老师是带我们班最长的语文...
小学三年级英语日记带翻译捡玉... 小学三年级英语日记带翻译捡玉米  今天,我和妈妈去外婆家,外婆家有刚剥的`玉米棒上带有玉米籽,好大的...
七年级英语优秀教学设计 七年级英语优秀教学设计  作为一位兢兢业业的人民教师,常常要写一份优秀的教学设计,教学设计是把教学原...
我的英语老师作文 我的英语老师作文(通用21篇)  在日常生活或是工作学习中,大家都有写作文的经历,对作文很是熟悉吧,...
英语老师教学经验总结 英语老师教学经验总结(通用19篇)  总结是指社会团体、企业单位和个人对某一阶段的学习、工作或其完成...
初一英语暑假作业答案 初一英语暑假作业答案  英语练习一(基础训练)第一题1.D2.H3.E4.F5.I6.A7.J8.C...
大学生的英语演讲稿 大学生的英语演讲稿范文(精选10篇)  使用正确的写作思路书写演讲稿会更加事半功倍。在现实社会中,越...
VOA美国之音英语学习网址 VOA美国之音英语学习推荐网址 美国之音网站已经成为语言学习最重要的资源站点,在互联网上还有若干网站...
商务英语期末试卷 Part I Term Translation (20%)Section A: Translate ...