博主介紹:?全網(wǎng)粉絲5W,全棧開發(fā)工程師,從事多年軟件開發(fā),在大廠呆過。持有軟件中級(jí)、六級(jí)等證書。可提供微服務(wù)項(xiàng)目搭建與畢業(yè)項(xiàng)目實(shí)戰(zhàn),博主也曾寫過優(yōu)秀論文,查重率極低,在這方面有豐富的經(jīng)驗(yàn)?
博主作品:《Java項(xiàng)目案例》主要基于SpringBoot+MyBatis/MyBatis-plus+MySQL+Vue等前后端分離項(xiàng)目,可以在左邊的分類專欄找到更多項(xiàng)目。《Uniapp項(xiàng)目案例》有幾個(gè)有uniapp教程,企業(yè)實(shí)戰(zhàn)開發(fā)?!段⒎?wù)實(shí)戰(zhàn)》專欄是本人的實(shí)戰(zhàn)經(jīng)驗(yàn)總結(jié),《Spring家族及微服務(wù)系列》專注Spring、SpringMVC、SpringBoot、SpringCloud系列、Nacos等源碼解讀、熱門面試題、架構(gòu)設(shè)計(jì)等。除此之外還有不少文章等你來細(xì)細(xì)品味,更多驚喜等著你哦
??uniapp微信小程序??面試題軟考題免費(fèi)使用,還可以使用ChatGPT,微信支付,掃碼加群
點(diǎn)擊這里預(yù)覽
??文末獲取聯(lián)系??精彩專欄推薦訂閱???????? 不然下次找不到喲
Java項(xiàng)目案例《100套》
https://blog.csdn.net/qq_57756904/category_12173599.html
uniapp小程序《100套》https://blog.csdn.net/qq_57756904/category_12199600.html
有需求代碼永遠(yuǎn)寫不完,而方法才是破解之道,抖音有實(shí)戰(zhàn)視頻課程,某馬某千等培訓(xùn)都是2萬左右,甚至廣東有本科院校單單一年就得3萬4年就12萬學(xué)費(fèi),而且還沒有包括吃飯的錢。所以很劃算了。另外博客左側(cè)有源碼閱讀專欄,對(duì)于求職有很大幫助,當(dāng)然對(duì)于工作也是有指導(dǎo)意義等。在大城市求職,你面試來回一趟多多少少都在12塊左右,而且一般不會(huì)一次性就通過,還得面試幾家。而如果你對(duì)源碼以及微服務(wù)等有深度認(rèn)識(shí),這無疑給你的面試添磚加瓦更上一層樓。
最后再送一句:最好是學(xué)會(huì)了,而不是學(xué)廢了?。?!
目錄
一、前言
二、系統(tǒng)設(shè)計(jì)
1、系統(tǒng)運(yùn)行環(huán)境
2、系統(tǒng)架構(gòu)設(shè)計(jì)
三、需求分析簡介
1、個(gè)人用戶
2、企業(yè)用戶
3、管理員
四、功能截圖
1、系統(tǒng)首頁
2、求職用戶功能界面
2.1、首頁
2.2、我的收藏
2.3、我的簡歷
2.4、簡歷投遞狀態(tài)
3、企業(yè)用戶功能界面
3.1、首頁?
3.2、企業(yè)信息維護(hù)與認(rèn)證
3.3、發(fā)布職位
3.4、約面試
4、管理員功能界面
4.1、首頁
4.2、企業(yè)認(rèn)證審核
4.3、職位認(rèn)證審核
4.4、權(quán)限管理
五、代碼實(shí)現(xiàn)?
1、ApplicationController控制類
2、ApplicationServiceImpl實(shí)現(xiàn)類
六、源碼獲取
一、前言
? ? 招聘系統(tǒng)將為招聘者和求職者構(gòu)建一個(gè)功能齊全、方便快捷的招聘平臺(tái),減少雙方投入招聘活動(dòng)的成本,為招聘求職雙方帶來便利,系統(tǒng)將實(shí)現(xiàn)如下目標(biāo): (1)針對(duì)系統(tǒng)內(nèi)的不同角色,系統(tǒng)能夠賦予其不同的操作權(quán)限。招聘者和求職者可以通過此系統(tǒng)進(jìn)行招聘和求職工作。招聘者可以在系統(tǒng)進(jìn)行職位的發(fā)布和下架,同時(shí)可以查看收到的投遞簡歷,對(duì)應(yīng)聘簡歷進(jìn)行篩選,對(duì)于符合招聘需求的求職者預(yù)約面試;求職者可以通過此系統(tǒng)進(jìn)行職位查看、收藏、簡歷制作和投遞、查看投遞狀況和面試情況等操作;平臺(tái)管理員能夠管理職位類別和對(duì)企業(yè)信息、職位進(jìn)行審核。
二、系統(tǒng)設(shè)計(jì)
1、系統(tǒng)運(yùn)行環(huán)境
開發(fā)系統(tǒng):Windows10
架構(gòu)模式:MVC/前后端分離
JDK版本:Java JDK1.8
開發(fā)工具:IDEA
數(shù)據(jù)庫版本: mysql5.7
數(shù)據(jù)庫可視化工具: SQL yog或Navicat for MySQL
服務(wù)器:SpringBoot自帶 apache tomcat
主要技術(shù):Java、SpringBoot、MyBatis-plus、MySQL、Html、Vue、Elementui等
2、系統(tǒng)架構(gòu)設(shè)計(jì)
三、需求分析簡介
? ? 招聘平臺(tái)系統(tǒng)的用戶共分為三類:個(gè)人用戶、企業(yè)用戶、管理員。
1、個(gè)人用戶
? ? 求職用戶首先完成注冊(cè)登錄,維護(hù)自己的簡歷信息,也可以實(shí)時(shí)瀏覽企業(yè)發(fā)布的招聘信息,按自己的要求篩選出合適的企業(yè)從而決定投遞簡歷、可以收藏職位、關(guān)注企業(yè),并可以在企業(yè)應(yīng)答之后收到相應(yīng)的回復(fù)、查看面試信息等。求職用戶的用例圖如圖3-1所示。
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 圖3-1 個(gè)人用戶用例圖
2、企業(yè)用戶
? ? 企業(yè)用戶首先注冊(cè)將用戶信息錄入系統(tǒng),登錄后先完成企業(yè)認(rèn)證等待系統(tǒng)管理員審核,審核通過后發(fā)布招聘崗位,也可以實(shí)時(shí)瀏覽求職者投遞的簡歷進(jìn)行篩選,簡歷通過的就可以發(fā)送面試通知。企業(yè)用戶的用例圖如圖3-2所示。
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ??圖3-2 企業(yè)用戶用例圖
3、管理員
? ? 管理員首先完成注冊(cè)登錄,可以進(jìn)行用戶管理、角色管理以及授予系統(tǒng)權(quán)限,手動(dòng)操作企業(yè)認(rèn)證審核的流程、手動(dòng)操作職位認(rèn)證審核以及職位分類的管理維護(hù)。管理員的用例圖如圖3-3所示。
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?圖3-3 管理員用例圖
四、功能截圖
注意:這里只是展示部分功能界面。
項(xiàng)目演示:
點(diǎn)擊這里查看
1、系統(tǒng)首頁
?注意:部分截圖。
2、求職用戶功能界面
2.1、首頁
2.2、我的收藏
2.3、我的簡歷
? ? 求職者填寫完簡歷信息后,點(diǎn)擊簡歷預(yù)覽系統(tǒng)自動(dòng)組裝成簡歷,求職者可以點(diǎn)擊導(dǎo)出簡歷按鈕獲取自己的簡歷去打印。
2.4、簡歷投遞狀態(tài)
3、企業(yè)用戶功能界面
3.1、首頁?
3.2、企業(yè)信息維護(hù)與認(rèn)證
3.3、發(fā)布職位
3.4、約面試
4、管理員功能界面
4.1、首頁
4.2、企業(yè)認(rèn)證審核
4.3、職位認(rèn)證審核
4.4、權(quán)限管理
文章來源:http://www.zghlxwxcb.cn/news/detail-435098.html
五、代碼實(shí)現(xiàn)?
1、ApplicationController控制類
@RestController
@RequestMapping("/recruit/application")
@PermissionModule(value = "申請(qǐng)")
public class ApplicationController {
@Autowired
private ApplicationService applicationService;
@Autowired
private InterviewService interviewService;
/**
* 投遞簡歷——添加申請(qǐng)
* @return CreatedVO
*/
@Logger(template = "投遞簡歷")
@PostMapping("")
@GroupRequired
@PermissionMeta(value = "投遞簡歷")
public CreatedVO create(@RequestBody ApplicationDO applicationDO) {
applicationService.create(applicationDO);
return new CreatedVO(7000);
}
/**
* 根據(jù)申請(qǐng)id修改狀態(tài)state
* @param id id
* @param state state
* @return UpdatedVO
*/
@Logger(template = "處理簡歷")
@PutMapping("/state/{id}")
@GroupRequired
@PermissionMeta(value = "申請(qǐng)審核")
public UpdatedVO update(@PathVariable @Positive(message = "{id.positive}") Integer id,
@RequestParam Integer state) {
// 根據(jù)id查找申請(qǐng)
ApplicationDO applicationDO = applicationService.getById(id);
if (applicationDO == null) {
throw new NotFoundException(70000);
}
// 更新申請(qǐng)狀態(tài)
applicationService.updateState(id, state);
// 若簡歷通過則插入面試表,初始狀態(tài)為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);
}
/**
* 根據(jù)id撤銷申請(qǐng)(只有未處理的申請(qǐng)才可以撤銷,即state=0的申請(qǐng)才可以撤銷)
* @param id id
* @return DeletedVO
*/
@Logger(template = "撤銷職位申請(qǐng)")
@DeleteMapping("/{id}")
@GroupRequired
@PermissionMeta(value = "撤銷申請(qǐng)")
public DeletedVO delete(@PathVariable @Positive(message = "{id.positive}") Integer id) {
// 根據(jù)id查找申請(qǐng)
ApplicationDO applicationDO = applicationService.getById(id);
if (applicationDO == null) {
throw new NotFoundException(70000);
}
applicationService.removeById(id);
return new DeletedVO(7200);
}
/**
* 根據(jù)用戶id和職位id查詢申請(qǐng)表,避免重復(fù)投遞同個(gè)崗位
* @param positionId positionId
* @param userId userId
* @return Boolean
*/
@GetMapping("")
public Boolean get(@RequestParam Integer positionId, @RequestParam Integer userId) {
QueryWrapper<ApplicationDO> wrapper = new QueryWrapper<>();
wrapper.eq("position_id", positionId).eq("user_id", userId);
ApplicationDO applicationDO = applicationService.getOne(wrapper);
if (applicationDO == null) {
return true;
}
return false;
}
/**
* 根據(jù)hr_id查詢?cè)揾r接收到的所有簡歷,并且根據(jù)state區(qū)分申請(qǐng)的狀態(tài)
* @param count count
* @param page page
* @param hrID hrID
* @param state state
* @return 應(yīng)聘簡歷
*/
@Logger(template = "查看應(yīng)聘簡歷")
@GetMapping("/page/{hrID}")
@GroupRequired
@PermissionMeta(value = "簡歷管理")
public PageResponseVO<ApplicationResultDO> 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);
}
/**
* 根據(jù)hr_id查詢?cè)揾r接收到的所有簡歷,并且根據(jù)簡歷的分?jǐn)?shù)進(jìn)行排序
* @param count count
* @param page page
* @param hrID hrID
* @return 簡歷排序
*/
@GroupRequired
@PermissionMeta(value = "簡歷排序")
@GetMapping("/sort/{hrID}")
public PageResponseVO<ApplicationResultDO> 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);
}
/**
* 根據(jù)user_id查詢用戶的所有申請(qǐng),并且根據(jù)state區(qū)分申請(qǐng)的狀態(tài)
* @param count count
* @param page page
* @param userId userId
* @return 我的投遞箱
*/
@Logger(template = "查看簡歷投遞狀況")
@GetMapping("/page/find/{userId}")
@GroupRequired
@PermissionMeta(value = "我的投遞箱")
public PageResponseVO<ApplicationResultDO> 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<ApplicationResultDO> res = applicationService.getByUserId(count, page, userId);
return res;
}
}
2、ApplicationServiceImpl實(shí)現(xiàn)類
@Slf4j
@Service
public class ApplicationServiceImpl extends ServiceImpl<ApplicationMapper, ApplicationDO> implements ApplicationService {
@Resource
private ApplicationMapper applicationMapper;
@Autowired
private ResumeService resumeService;
@Override
public boolean create(ApplicationDO applicationDO) {
UserDO localUser = LocalUser.getLocalUser();
if (localUser == null) {
throw new RuntimeException("用戶信息為空");
}
applicationDO.setUserId(localUser.getId());
applicationDO.setState(1);
LambdaQueryWrapper<ResumeDO> queryWrapper = Wrappers.<ResumeDO>lambdaQuery()
.eq(ResumeDO::getUserId, localUser.getId());
ResumeDO resumeDO = this.resumeService.getBaseMapper().selectOne(queryWrapper);
if (resumeDO == null) {
throw new RuntimeException("求職者簡歷信息不存在,請(qǐng)先填寫簡歷!??!");
}
applicationDO.setResumeId(resumeDO.getId());
return applicationMapper.insert(applicationDO) > 0;
}
@Override
public PageResponseVO<ApplicationResultDO> getByHrId(Integer count,
Integer page,
Integer hrID,
Integer state) {
Page<ApplicationResultDO> pager = new Page<>(page, count);
IPage<ApplicationResultDO> paging = applicationMapper.getByHrId(pager, hrID, state);
return PageUtil.build(paging);
}
@Override
public boolean updateState(Integer id, Integer state) {
return applicationMapper.updateState(id, state);
}
@Override
public PageResponseVO<ApplicationResultDO> sort(Integer count, Integer page, Integer hrID) {
Page<ApplicationResultDO> pager = new Page<>(page, count);
IPage<ApplicationResultDO> paging = applicationMapper.sortByGrade(pager, hrID);
return PageUtil.build(paging);
}
@Override
public PageResponseVO<ApplicationResultDO> getByUserId(Integer count,
Integer page,
Integer userId) {
Page<ApplicationResultDO> pager = new Page<>(page, count);
IPage<ApplicationResultDO> paging = applicationMapper.getByUserId(pager, userId);
return PageUtil.build(paging);
}
}
六、源碼獲取
?大家點(diǎn)贊、收藏、關(guān)注、評(píng)論啦?、關(guān)注下方公眾號(hào)獲取聯(lián)系方式????????文章來源地址http://www.zghlxwxcb.cn/news/detail-435098.html
到了這里,關(guān)于基于Java+SpringBoot+Vue求職招聘系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn)(有50頁論文)的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!