Compare commits
	
		
			68 Commits
		
	
	
		
			6d6439fbd9
			...
			main
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| a28354f95c | |||
| 267d010ce7 | |||
| 5ee26b01d0 | |||
| 4c7331427a | |||
| 1ed62647de | |||
| ef44b1a19b | |||
| d4683f1299 | |||
| 115f47118f | |||
| 802ea1fe76 | |||
| f65ca791b5 | |||
| d21a9cf882 | |||
| 8b3b7f63f9 | |||
| 9b9e80dc62 | |||
| 7752c74063 | |||
| f4730c60fb | |||
| d57ce9e3fc | |||
| 8988c52594 | |||
| ba3e66a3c4 | |||
| aa55276a81 | |||
| 8c5ec3e0b3 | |||
| c795e63e96 | |||
| 9281eb700b | |||
| 8cf753ad54 | |||
| 65487c073f | |||
| 4c28d07bc3 | |||
| a6d43c0bca | |||
| 070239d1d5 | |||
| 6680622a85 | |||
| 0eee50be78 | |||
| 2616b60283 | |||
| be0b432140 | |||
| fca00d41a2 | |||
| b4da3c25a5 | |||
| b7686c31b1 | |||
| a6b5c06e63 | |||
| 44ec48c49d | |||
| e56a8a285d | |||
| 418c22d78d | |||
| d5473d922c | |||
| c0aa835d19 | |||
| dcc96bf689 | |||
| a4cc7d8dbb | |||
| 7defcb6158 | |||
| 47351f41eb | |||
| da48a9c33a | |||
| ac2d427a71 | |||
| 7994112283 | |||
| 2502d9726b | |||
| 5e1012a3fb | |||
| 64e991155d | |||
| 32424bc404 | |||
| fcb421f97d | |||
| 1181ef0b1c | |||
| 5a6cfd695b | |||
| e3975f557e | |||
| 1ddb62166a | |||
| 98f9182d43 | |||
| d843197e5b | |||
| 60a9445e6f | |||
| 86b28f0071 | |||
| 73d8bdd402 | |||
| 7ee0b08b0d | |||
| db413c57aa | |||
| 0076eeeb48 | |||
| 2f28aa9c4d | |||
| 27746bd727 | |||
| 439b2b65af | |||
| 9df9b42d20 | 
| @@ -2,11 +2,12 @@ package com.ruoyi.web.controller.system; | |||||||
|  |  | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Set; | import java.util.Set; | ||||||
|  |  | ||||||
|  | import com.ruoyi.common.annotation.BussinessLog; | ||||||
|  | import com.ruoyi.common.core.domain.model.RegisterBody; | ||||||
|  | import io.swagger.annotations.ApiOperation; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.web.bind.annotation.GetMapping; | import org.springframework.web.bind.annotation.*; | ||||||
| import org.springframework.web.bind.annotation.PostMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RequestBody; |  | ||||||
| import org.springframework.web.bind.annotation.RestController; |  | ||||||
| import com.ruoyi.common.constant.Constants; | import com.ruoyi.common.constant.Constants; | ||||||
| import com.ruoyi.common.core.domain.AjaxResult; | import com.ruoyi.common.core.domain.AjaxResult; | ||||||
| import com.ruoyi.common.core.domain.entity.SysMenu; | import com.ruoyi.common.core.domain.entity.SysMenu; | ||||||
| @@ -59,6 +60,15 @@ public class SysLoginController | |||||||
|         ajax.put(Constants.TOKEN, token); |         ajax.put(Constants.TOKEN, token); | ||||||
|         return ajax; |         return ajax; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @PostMapping("/app/appLogin") | ||||||
|  |     public AjaxResult appLogin(@RequestBody LoginBody loginBody) | ||||||
|  |     { | ||||||
|  |         AjaxResult ajax = AjaxResult.success(); | ||||||
|  |         ajax=loginService.appLogin(loginBody); | ||||||
|  |         return ajax; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 获取用户信息 |      * 获取用户信息 | ||||||
|      *  |      *  | ||||||
| @@ -91,4 +101,27 @@ public class SysLoginController | |||||||
|         List<SysMenu> menus = menuService.selectMenuTreeByUserId(userId); |         List<SysMenu> menus = menuService.selectMenuTreeByUserId(userId); | ||||||
|         return AjaxResult.success(menuService.buildMenus(menus)); |         return AjaxResult.success(menuService.buildMenus(menus)); | ||||||
|     } |     } | ||||||
|  |     @GetMapping("/sso/callback") | ||||||
|  |     public String ssoCallback(@RequestParam("ticket") String ticket) { | ||||||
|  |         String frontendIndexUrl = "http://domain.com"; | ||||||
|  |  | ||||||
|  |         String ruoyiJwtToken = loginService.loginOss(ticket); | ||||||
|  |  | ||||||
|  |         String redirectUrl = frontendIndexUrl + "/index?token=" + ruoyiJwtToken; | ||||||
|  |  | ||||||
|  |         // 返回 "redirect:" 即可触发 302 重定向 | ||||||
|  |         return "redirect:" + redirectUrl; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 保存简历-重新返回token | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("保存注册信息") | ||||||
|  |     @PostMapping("/registerUser") | ||||||
|  |     @BussinessLog(title = "保存简历") | ||||||
|  |     public AjaxResult registerUser(@RequestBody RegisterBody registerBody) | ||||||
|  |     { | ||||||
|  |         String token=loginService.registerAppUser(registerBody); | ||||||
|  |         return AjaxResult.success().put("token",token); | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -4,9 +4,8 @@ import java.util.List; | |||||||
| import java.util.stream.Collectors; | import java.util.stream.Collectors; | ||||||
| import javax.servlet.http.HttpServletResponse; | import javax.servlet.http.HttpServletResponse; | ||||||
|  |  | ||||||
| import com.ruoyi.cms.domain.Company; | import com.ruoyi.common.core.domain.entity.Company; | ||||||
| import com.ruoyi.cms.service.ICompanyService; | import com.ruoyi.cms.service.ICompanyService; | ||||||
| import io.swagger.annotations.Api; |  | ||||||
| import io.swagger.annotations.ApiOperation; | import io.swagger.annotations.ApiOperation; | ||||||
| import org.apache.commons.lang3.ArrayUtils; | import org.apache.commons.lang3.ArrayUtils; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| @@ -264,17 +263,24 @@ public class SysUserController extends BaseController | |||||||
|     @ApiOperation("企业资质审核") |     @ApiOperation("企业资质审核") | ||||||
|     @PreAuthorize("@ss.hasPermi('app:company:approval:list')") |     @PreAuthorize("@ss.hasPermi('app:company:approval:list')") | ||||||
|     @PostMapping("/approval") |     @PostMapping("/approval") | ||||||
|     public AjaxResult approval(Company company) |     public AjaxResult approval(@RequestBody Company company) | ||||||
|     { |     { | ||||||
|         Company company1 = companyService.approval(company); |         Company company1 = companyService.approval(company); | ||||||
|         SysUser sysUser = new SysUser(); |         SysUser sysUser = new SysUser(); | ||||||
|         sysUser.setUserName(company1.getContactPersonPhone()); |  | ||||||
|         sysUser.setNickName(company1.getContactPerson()); |         sysUser.setNickName(company1.getContactPerson()); | ||||||
|         sysUser.setPhonenumber(company1.getContactPersonPhone()); |  | ||||||
|         sysUser.setDeptId(101L); |         sysUser.setDeptId(101L); | ||||||
|         String contactPersonPhone = company1.getContactPersonPhone(); |         String contactPersonPhone = company1.getContactPersonPhone(); | ||||||
|         String lastSixDigits = contactPersonPhone.substring(contactPersonPhone.length() - 6); |         if(StringUtils.isNotEmpty(contactPersonPhone)){ | ||||||
|         sysUser.setPassword(lastSixDigits); |             String lastSixDigits = contactPersonPhone.substring(contactPersonPhone.length() - 6); | ||||||
|  |             sysUser.setPassword(lastSixDigits); | ||||||
|  |             sysUser.setUserName(company1.getContactPersonPhone()); | ||||||
|  |             sysUser.setPhonenumber(company1.getContactPersonPhone()); | ||||||
|  |             sysUser.setNickName(company1.getContactPersonPhone()); | ||||||
|  |         }else{ | ||||||
|  |             sysUser.setPassword("123456"); | ||||||
|  |             sysUser.setUserName(company1.getName()); | ||||||
|  |             sysUser.setNickName(company1.getName()); | ||||||
|  |         } | ||||||
|         sysUser.setPhonenumber(getUsername()); |         sysUser.setPhonenumber(getUsername()); | ||||||
|         Long[] postIds = {1L}; |         Long[] postIds = {1L}; | ||||||
|         Long[] roleIds = {100L}; |         Long[] roleIds = {100L}; | ||||||
|   | |||||||
| @@ -92,3 +92,5 @@ easy-es: | |||||||
|         process-index-mode: manual |         process-index-mode: manual | ||||||
|         db-config: |         db-config: | ||||||
|             refresh-policy: immediate |             refresh-policy: immediate | ||||||
|  |     username: elastic | ||||||
|  |     password: zkr2024@@.com | ||||||
| @@ -89,3 +89,5 @@ easy-es: | |||||||
|         process-index-mode: manual |         process-index-mode: manual | ||||||
|         db-config: |         db-config: | ||||||
|             refresh-policy: immediate |             refresh-policy: immediate | ||||||
|  |     username: elastic | ||||||
|  |     password: zkr2024@@.com | ||||||
|   | |||||||
| @@ -0,0 +1,58 @@ | |||||||
|  | package com.ruoyi.cms.controller.app; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | import com.ruoyi.cms.domain.vo.CompanyContactVo; | ||||||
|  | import com.ruoyi.cms.service.CompanyContactService; | ||||||
|  | import com.ruoyi.cms.util.ListUtil; | ||||||
|  | import com.ruoyi.common.annotation.BussinessLog; | ||||||
|  | import com.ruoyi.common.core.controller.BaseController; | ||||||
|  | import com.ruoyi.common.core.domain.AjaxResult; | ||||||
|  | import com.ruoyi.common.core.domain.entity.CompanyContact; | ||||||
|  | import com.ruoyi.common.core.page.TableDataInfo; | ||||||
|  | import io.swagger.annotations.Api; | ||||||
|  | import io.swagger.annotations.ApiOperation; | ||||||
|  | import org.springframework.beans.factory.annotation.Autowired; | ||||||
|  | import org.springframework.web.bind.annotation.*; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 公司联系人 | ||||||
|  |  * | ||||||
|  |  * @author  | ||||||
|  |  * @email  | ||||||
|  |  * @date 2025-09-30 15:57:06 | ||||||
|  |  */ | ||||||
|  | @RestController | ||||||
|  | @RequestMapping("/app/companycontact") | ||||||
|  | @Api(tags = "移动端:公司联系人") | ||||||
|  | public class AppCompanyContactController extends BaseController { | ||||||
|  |     @Autowired | ||||||
|  |     private CompanyContactService companyContactService; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 列表 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("公司联系人列表") | ||||||
|  |     @GetMapping("/list") | ||||||
|  |     public TableDataInfo list(CompanyContact companyContact){ | ||||||
|  |         List<CompanyContact> list=companyContactService.getSelectList(companyContact); | ||||||
|  |         return getDataTable(list); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @BussinessLog(title = "移动端保存企业联系人") | ||||||
|  |     @PostMapping("/batchInsertUpdate") | ||||||
|  |     public AjaxResult batchInsertUpdate(@RequestBody CompanyContactVo contactVo) | ||||||
|  |     { | ||||||
|  |         if (contactVo == null) { | ||||||
|  |             return AjaxResult.error("请求参数不能为空"); | ||||||
|  |         } | ||||||
|  |         List<CompanyContact> contactList = contactVo.getCompanyContactList(); | ||||||
|  |         if (ListUtil.isListObjectEmptyOrNull(contactList)) { // 假设 ListUtil 工具类判断 null 或空集合 | ||||||
|  |             return AjaxResult.error("请至少填写一条联系人信息"); | ||||||
|  |         } | ||||||
|  |         companyContactService.insertUpadteCompanyContact(contactList); | ||||||
|  |         return success(); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -1,7 +1,7 @@ | |||||||
| package com.ruoyi.cms.controller.app; | package com.ruoyi.cms.controller.app; | ||||||
|  |  | ||||||
|  |  | ||||||
| import com.ruoyi.cms.domain.Company; | import com.ruoyi.common.core.domain.entity.Company; | ||||||
| import com.ruoyi.cms.domain.CompanyCard; | import com.ruoyi.cms.domain.CompanyCard; | ||||||
| import com.ruoyi.cms.domain.query.LabelQuery; | import com.ruoyi.cms.domain.query.LabelQuery; | ||||||
| import com.ruoyi.cms.mapper.CompanyCardMapper; | import com.ruoyi.cms.mapper.CompanyCardMapper; | ||||||
| @@ -12,6 +12,7 @@ import com.ruoyi.common.annotation.BussinessLog; | |||||||
| import com.ruoyi.common.core.controller.BaseController; | import com.ruoyi.common.core.controller.BaseController; | ||||||
| import com.ruoyi.common.core.domain.AjaxResult; | import com.ruoyi.common.core.domain.AjaxResult; | ||||||
| import com.ruoyi.common.core.page.TableDataInfo; | import com.ruoyi.common.core.page.TableDataInfo; | ||||||
|  | import com.ruoyi.common.utils.StringUtils; | ||||||
| import io.swagger.annotations.Api; | import io.swagger.annotations.Api; | ||||||
| import io.swagger.annotations.ApiOperation; | import io.swagger.annotations.ApiOperation; | ||||||
| import io.swagger.annotations.ApiParam; | import io.swagger.annotations.ApiParam; | ||||||
| @@ -133,4 +134,22 @@ public class AppCompanyController extends BaseController | |||||||
|         Company status = companyService.registerStatus(); |         Company status = companyService.registerStatus(); | ||||||
|         return AjaxResult.success(status); |         return AjaxResult.success(status); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @GetMapping("/queryCodeCompany") | ||||||
|  |     @ApiOperation("根据社会信用代码查询企业") | ||||||
|  |     public AjaxResult queryCodeCompany(@RequestParam("code") String code) | ||||||
|  |     { | ||||||
|  |         if (!StringUtils.hasText(code)) { | ||||||
|  |             return AjaxResult.error("社会信用代码不能为空"); | ||||||
|  |         } | ||||||
|  |         return AjaxResult.success(companyService.queryCodeCompany(code)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @ApiOperation("模糊查询公司列表") | ||||||
|  |     @GetMapping("/likeList") | ||||||
|  |     public TableDataInfo likeList(Company company) | ||||||
|  |     { | ||||||
|  |         List<Company> list = companyService.selectLikeCompanyList(company); | ||||||
|  |         return getDataTable(list); | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,18 +1,20 @@ | |||||||
| package com.ruoyi.cms.controller.app; | package com.ruoyi.cms.controller.app; | ||||||
|  |  | ||||||
|  | import com.ruoyi.cms.domain.File; | ||||||
| import com.ruoyi.cms.service.IFileService; | import com.ruoyi.cms.service.IFileService; | ||||||
| import com.ruoyi.common.annotation.BussinessLog; | import com.ruoyi.common.annotation.BussinessLog; | ||||||
|  | import com.ruoyi.common.core.controller.BaseController; | ||||||
| import com.ruoyi.common.core.domain.AjaxResult; | import com.ruoyi.common.core.domain.AjaxResult; | ||||||
|  | import com.ruoyi.common.core.page.TableDataInfo; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.web.bind.annotation.PostMapping; | import org.springframework.web.bind.annotation.*; | ||||||
| import org.springframework.web.bind.annotation.RequestMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RequestParam; |  | ||||||
| import org.springframework.web.bind.annotation.RestController; |  | ||||||
| import org.springframework.web.multipart.MultipartFile; | import org.springframework.web.multipart.MultipartFile; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
| @RestController | @RestController | ||||||
| @RequestMapping("/app/file") | @RequestMapping("/app/file") | ||||||
| public class AppFileController { | public class AppFileController extends BaseController { | ||||||
|     @Autowired |     @Autowired | ||||||
|     private IFileService fileService; |     private IFileService fileService; | ||||||
|     @BussinessLog(title = "上传文件") |     @BussinessLog(title = "上传文件") | ||||||
| @@ -20,4 +22,12 @@ public class AppFileController { | |||||||
|     public AjaxResult uploadFile(@RequestParam("file") MultipartFile file, @RequestParam(value = "bussinessId",required = false) Long bussinessId) { |     public AjaxResult uploadFile(@RequestParam("file") MultipartFile file, @RequestParam(value = "bussinessId",required = false) Long bussinessId) { | ||||||
|        return fileService.uploadFile(file,bussinessId); |        return fileService.uploadFile(file,bussinessId); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @BussinessLog(title = "获取附件列表") | ||||||
|  |     @GetMapping("/list") | ||||||
|  |     public TableDataInfo list(File file) | ||||||
|  |     { | ||||||
|  |         List<File> results = fileService.selectFileList(file); | ||||||
|  |         return getDataTable(results); | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -3,9 +3,12 @@ package com.ruoyi.cms.controller.app; | |||||||
| import com.ruoyi.cms.domain.ESJobDocument; | import com.ruoyi.cms.domain.ESJobDocument; | ||||||
| import com.ruoyi.cms.domain.Job; | import com.ruoyi.cms.domain.Job; | ||||||
| import com.ruoyi.cms.domain.query.ESJobSearch; | import com.ruoyi.cms.domain.query.ESJobSearch; | ||||||
|  | import com.ruoyi.cms.service.ICompanyService; | ||||||
| import com.ruoyi.cms.service.IESJobSearchService; | import com.ruoyi.cms.service.IESJobSearchService; | ||||||
| import com.ruoyi.cms.service.IJobCollectionService; | import com.ruoyi.cms.service.IJobCollectionService; | ||||||
| import com.ruoyi.cms.service.IJobService; | import com.ruoyi.cms.service.IJobService; | ||||||
|  | import com.ruoyi.cms.util.RoleUtils; | ||||||
|  | import com.ruoyi.cms.util.sensitiveWord.SensitiveWordChecker; | ||||||
| import com.ruoyi.common.annotation.BussinessLog; | import com.ruoyi.common.annotation.BussinessLog; | ||||||
| import com.ruoyi.common.core.controller.BaseController; | import com.ruoyi.common.core.controller.BaseController; | ||||||
| import com.ruoyi.common.core.domain.AjaxResult; | import com.ruoyi.common.core.domain.AjaxResult; | ||||||
| @@ -13,6 +16,7 @@ import com.ruoyi.common.core.page.TableDataInfo; | |||||||
| import io.swagger.annotations.Api; | import io.swagger.annotations.Api; | ||||||
| import io.swagger.annotations.ApiOperation; | import io.swagger.annotations.ApiOperation; | ||||||
| import io.swagger.annotations.ApiParam; | import io.swagger.annotations.ApiParam; | ||||||
|  | import org.apache.commons.lang3.ArrayUtils; | ||||||
| import org.dromara.easyes.core.biz.EsPageInfo; | import org.dromara.easyes.core.biz.EsPageInfo; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.web.bind.annotation.*; | import org.springframework.web.bind.annotation.*; | ||||||
| @@ -36,6 +40,10 @@ public class AppJobController extends BaseController | |||||||
|     private IJobCollectionService jobCollectionService; |     private IJobCollectionService jobCollectionService; | ||||||
|     @Autowired |     @Autowired | ||||||
|     private IESJobSearchService esJobSearchService; |     private IESJobSearchService esJobSearchService; | ||||||
|  |     @Autowired | ||||||
|  |     private SensitiveWordChecker sensitiveWordChecker; | ||||||
|  |     @Autowired | ||||||
|  |     private ICompanyService companyService; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 查询岗位列表 |      * 查询岗位列表 | ||||||
| @@ -66,6 +74,9 @@ public class AppJobController extends BaseController | |||||||
|     @GetMapping("/recommend") |     @GetMapping("/recommend") | ||||||
|     public AjaxResult recommend(ESJobSearch esJobSearch) |     public AjaxResult recommend(ESJobSearch esJobSearch) | ||||||
|     { |     { | ||||||
|  |         if (RoleUtils.getAppCurrentUseridCard() != null) { | ||||||
|  |             esJobSearch.setCode(RoleUtils.getAppCurrentUseridCard()); | ||||||
|  |         } | ||||||
|         List<ESJobDocument> jobList = jobService.recommend(esJobSearch); |         List<ESJobDocument> jobList = jobService.recommend(esJobSearch); | ||||||
|         return success(jobList); |         return success(jobList); | ||||||
|     } |     } | ||||||
| @@ -192,7 +203,34 @@ public class AppJobController extends BaseController | |||||||
|     @PostMapping("/publishJob") |     @PostMapping("/publishJob") | ||||||
|     public AjaxResult fix(@RequestBody Job job) |     public AjaxResult fix(@RequestBody Job job) | ||||||
|     { |     { | ||||||
|  |         // 校验描述中的敏感词 | ||||||
|  |         List<String> sensitiveWords = sensitiveWordChecker.checkSensitiveWords(job.getDescription()); | ||||||
|  |         if (!sensitiveWords.isEmpty()) { | ||||||
|  |             String errorMsg = "描述中包含敏感词:" + String.join("、", sensitiveWords); | ||||||
|  |             return AjaxResult.error(errorMsg); | ||||||
|  |         } | ||||||
|         jobService.publishJob(job); |         jobService.publishJob(job); | ||||||
|         return success(); |         return success(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @GetMapping("/jobCompare") | ||||||
|  |     @ApiOperation("根据多个岗位id查询岗位详情") | ||||||
|  |     public AjaxResult jobCompare(@ApiParam("岗位ID数组") @RequestParam("jobIds") Long[] jobIds) { | ||||||
|  |         if (ArrayUtils.isEmpty(jobIds)) { | ||||||
|  |             return AjaxResult.error("请传递岗位ID参数(jobIds),多个ID用&分隔"); | ||||||
|  |         } | ||||||
|  |         if (jobIds.length > 5) { | ||||||
|  |             return AjaxResult.error("最多支持对比5个岗位,请减少参数数量"); | ||||||
|  |         } | ||||||
|  |         return success(esJobSearchService.selectByIds(jobIds)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @GetMapping("/applyJobList") | ||||||
|  |     @ApiOperation("根据岗位id查询岗位申请人员") | ||||||
|  |     public AjaxResult applyJobList(@ApiParam("岗位id") @RequestParam("jobId") Long jobId) { | ||||||
|  |         if (jobId==null) { | ||||||
|  |             return AjaxResult.error("请传递岗位ID"); | ||||||
|  |         } | ||||||
|  |         return success(jobService.selectApplyJobUserList(jobId)); | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,81 @@ | |||||||
|  | package com.ruoyi.cms.controller.app; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | import com.ruoyi.cms.service.AppSkillService; | ||||||
|  | import com.ruoyi.common.core.controller.BaseController; | ||||||
|  | import com.ruoyi.common.core.domain.AjaxResult; | ||||||
|  | import com.ruoyi.common.core.domain.entity.AppSkill; | ||||||
|  | import com.ruoyi.common.core.page.TableDataInfo; | ||||||
|  | import io.swagger.annotations.Api; | ||||||
|  | import io.swagger.annotations.ApiOperation; | ||||||
|  | import io.swagger.annotations.ApiParam; | ||||||
|  | import org.springframework.beans.factory.annotation.Autowired; | ||||||
|  | import org.springframework.web.bind.annotation.*; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 用户技能信息 | ||||||
|  |  * | ||||||
|  |  * @author  | ||||||
|  |  * @email  | ||||||
|  |  * @date 2025-10-21 12:22:09 | ||||||
|  |  */ | ||||||
|  | @RestController | ||||||
|  | @RequestMapping("/appskill/list") | ||||||
|  | @Api(tags = "移动端:用户技能") | ||||||
|  | public class AppSkillController extends BaseController { | ||||||
|  |     @Autowired | ||||||
|  |     private AppSkillService appSkillService; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 列表 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("获取工作经历详细信息") | ||||||
|  |     @GetMapping("/list") | ||||||
|  |     public TableDataInfo list(AppSkill appSkill){ | ||||||
|  |         startPage(); | ||||||
|  |         List<AppSkill> list=appSkillService.getList(appSkill); | ||||||
|  |         return getDataTable(list); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 信息 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("获取工作经历详细信息") | ||||||
|  |     @GetMapping(value = "/{id}") | ||||||
|  |     public AjaxResult info(@PathVariable("id") Long id){ | ||||||
|  |         return success(appSkillService.getAppskillById(id)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 保存 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("获取工作经历详细信息") | ||||||
|  |     @PostMapping("/add") | ||||||
|  |     public AjaxResult save(@RequestBody AppSkill appSkill){ | ||||||
|  |         return toAjax(appSkillService.insertAppskill(appSkill)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 修改 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("获取工作经历详细信息") | ||||||
|  |     @PutMapping("/edit") | ||||||
|  |     public AjaxResult update(@RequestBody AppSkill appSkill){ | ||||||
|  |         return toAjax(appSkillService.updateAppskillById(appSkill)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 删除 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("获取工作经历详细信息") | ||||||
|  |     @DeleteMapping("/{id}") | ||||||
|  |     public AjaxResult delete(@ApiParam("主键id") @PathVariable Long id){ | ||||||
|  |         return toAjax(appSkillService.removeAppskillIds(new Long[]{id})); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -1,7 +1,7 @@ | |||||||
| package com.ruoyi.cms.controller.app; | package com.ruoyi.cms.controller.app; | ||||||
|  |  | ||||||
| import com.ruoyi.cms.domain.AppUser; | import com.ruoyi.common.core.domain.entity.AppUser; | ||||||
| import com.ruoyi.cms.domain.Company; | import com.ruoyi.common.core.domain.entity.Company; | ||||||
| import com.ruoyi.cms.domain.Job; | import com.ruoyi.cms.domain.Job; | ||||||
| import com.ruoyi.cms.domain.JobFair; | import com.ruoyi.cms.domain.JobFair; | ||||||
| import com.ruoyi.cms.domain.query.MineJobQuery; | import com.ruoyi.cms.domain.query.MineJobQuery; | ||||||
| @@ -9,8 +9,9 @@ import com.ruoyi.cms.service.*; | |||||||
| import com.ruoyi.common.annotation.BussinessLog; | import com.ruoyi.common.annotation.BussinessLog; | ||||||
| import com.ruoyi.common.core.controller.BaseController; | import com.ruoyi.common.core.controller.BaseController; | ||||||
| import com.ruoyi.common.core.domain.AjaxResult; | import com.ruoyi.common.core.domain.AjaxResult; | ||||||
|  | import com.ruoyi.common.core.domain.model.RegisterBody; | ||||||
| import com.ruoyi.common.core.page.TableDataInfo; | import com.ruoyi.common.core.page.TableDataInfo; | ||||||
| import com.ruoyi.common.utils.SecurityUtils; | import com.ruoyi.common.utils.SiteSecurityUtils; | ||||||
| import io.swagger.annotations.Api; | import io.swagger.annotations.Api; | ||||||
| import io.swagger.annotations.ApiOperation; | import io.swagger.annotations.ApiOperation; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| @@ -45,20 +46,30 @@ public class AppUserController extends BaseController | |||||||
|     /** |     /** | ||||||
|      * 查询岗位列表 |      * 查询岗位列表 | ||||||
|      */ |      */ | ||||||
|  |     @ApiOperation("保存注册信息") | ||||||
|  |     @PostMapping("/registerUser") | ||||||
|  |     @BussinessLog(title = "保存简历") | ||||||
|  |     public AjaxResult registerUser(@RequestBody RegisterBody registerBody) | ||||||
|  |     { | ||||||
|  |         appUserService.registerAppUser(registerBody); | ||||||
|  |         return AjaxResult.success(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @ApiOperation("保存简历") |     @ApiOperation("保存简历") | ||||||
|     @PostMapping("/resume") |     @PostMapping("/resume") | ||||||
|     @BussinessLog(title = "保存简历") |     @BussinessLog(title = "保存简历") | ||||||
|     public AjaxResult saveResume(@RequestBody AppUser appUser) |     public AjaxResult saveResume(@RequestBody AppUser appUser) | ||||||
|     { |     { | ||||||
|         appUser.setUserId(SecurityUtils.getUserId()); |         appUser.setUserId(SiteSecurityUtils.getUserId()); | ||||||
|         appUserService.updateAppUser(appUser); |         appUserService.updateAppUser(appUser); | ||||||
|         return AjaxResult.success(); |         return AjaxResult.success(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @ApiOperation("查看简历") |     @ApiOperation("查看简历") | ||||||
|     @GetMapping("/resume") |     @GetMapping("/resume") | ||||||
|     public AjaxResult getResume() |     public AjaxResult getResume() | ||||||
|     { |     { | ||||||
|         AppUser appUser = appUserService.selectAppUserByUserId(SecurityUtils.getUserId()); |         AppUser appUser = appUserService.selectAppUserByUserId(SiteSecurityUtils.getUserId()); | ||||||
|         return AjaxResult.success(appUser); |         return AjaxResult.success(appUser); | ||||||
|     } |     } | ||||||
|     @ApiOperation("我的浏览") |     @ApiOperation("我的浏览") | ||||||
| @@ -116,4 +127,12 @@ public class AppUserController extends BaseController | |||||||
|         HashMap<String,Integer> result = jobApplyService.statistics(); |         HashMap<String,Integer> result = jobApplyService.statistics(); | ||||||
|         return AjaxResult.success(result); |         return AjaxResult.success(result); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @ApiOperation("根据条件查询用户信息") | ||||||
|  |     @GetMapping("/list") | ||||||
|  |     public AjaxResult getUserList(AppUser appUser) | ||||||
|  |     { | ||||||
|  |         List<AppUser> list = appUserService.selectAppUserList(appUser); | ||||||
|  |         return AjaxResult.success(list); | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,88 @@ | |||||||
|  | package com.ruoyi.cms.controller.app; | ||||||
|  |  | ||||||
|  | import com.ruoyi.common.core.domain.entity.UserWorkExperiences; | ||||||
|  | import com.ruoyi.cms.service.UserWorkExperiencesService; | ||||||
|  | import com.ruoyi.common.core.controller.BaseController; | ||||||
|  | import com.ruoyi.common.core.domain.AjaxResult; | ||||||
|  | import com.ruoyi.common.core.page.TableDataInfo; | ||||||
|  | import com.ruoyi.common.utils.SiteSecurityUtils; | ||||||
|  | import io.swagger.annotations.Api; | ||||||
|  | import io.swagger.annotations.ApiOperation; | ||||||
|  | import io.swagger.annotations.ApiParam; | ||||||
|  | import org.springframework.beans.factory.annotation.Autowired; | ||||||
|  | import org.springframework.web.bind.annotation.*; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 用户工作经历表 | ||||||
|  |  * | ||||||
|  |  * @author  | ||||||
|  |  * @email  | ||||||
|  |  * @date 2025-10-10 16:26:26 | ||||||
|  |  */ | ||||||
|  | @RestController | ||||||
|  | @RequestMapping("/app/userworkexperiences") | ||||||
|  | @Api(tags = "移动端:用户工作经历") | ||||||
|  | public class AppUserWorkExperiencesController extends BaseController { | ||||||
|  |  | ||||||
|  |     @Autowired | ||||||
|  |     private UserWorkExperiencesService userWorkExperiencesService; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 列表 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("工作经历列表信息") | ||||||
|  |     @GetMapping("/list") | ||||||
|  |     public TableDataInfo list(UserWorkExperiences userWorkExperiences){ | ||||||
|  |         if(userWorkExperiences.getUserId()==null){ | ||||||
|  |             userWorkExperiences.setUserId(SiteSecurityUtils.getUserId()); | ||||||
|  |         } | ||||||
|  |         startPage(); | ||||||
|  |         List<UserWorkExperiences> list=userWorkExperiencesService.getWorkExperiencesList(userWorkExperiences); | ||||||
|  |         return getDataTable(list); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取详细信息 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("获取工作经历详细信息") | ||||||
|  |     @GetMapping(value = "/{id}") | ||||||
|  |     public AjaxResult query(@PathVariable("id") Long id){ | ||||||
|  |         return success(userWorkExperiencesService.getWorkExperiencesById(id)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 保存 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("新增工作经历") | ||||||
|  |     @PostMapping("/add") | ||||||
|  |     public AjaxResult add(@RequestBody UserWorkExperiences userWorkExperiences){ | ||||||
|  |         if(userWorkExperiences.getUserId()==null){ | ||||||
|  |             userWorkExperiences.setUserId(SiteSecurityUtils.getUserId()); | ||||||
|  |         } | ||||||
|  |         return toAjax(userWorkExperiencesService.insertWorkExperiences(userWorkExperiences)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 修改 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("修改工作经历") | ||||||
|  |     @PutMapping("/edit") | ||||||
|  |     public AjaxResult update(@RequestBody UserWorkExperiences userWorkExperiences){ | ||||||
|  |         return toAjax(userWorkExperiencesService.updateWorkExperiencesById(userWorkExperiences)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 删除 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("删除工作经历") | ||||||
|  |     @DeleteMapping("/{id}") | ||||||
|  |     public AjaxResult remove(@ApiParam("招聘会id") @PathVariable Long id){ | ||||||
|  |  | ||||||
|  |         return toAjax(userWorkExperiencesService.deleteWorkExperiencesIds(new Long[]{id})); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -18,7 +18,7 @@ import com.ruoyi.common.core.domain.AjaxResult; | |||||||
| import com.ruoyi.common.enums.BusinessType; | import com.ruoyi.common.enums.BusinessType; | ||||||
| import io.swagger.annotations.Api; | import io.swagger.annotations.Api; | ||||||
| import io.swagger.annotations.ApiOperation; | import io.swagger.annotations.ApiOperation; | ||||||
| import com.ruoyi.cms.domain.AppUser; | import com.ruoyi.common.core.domain.entity.AppUser; | ||||||
| import com.ruoyi.cms.service.IAppUserService; | import com.ruoyi.cms.service.IAppUserService; | ||||||
| import com.ruoyi.common.utils.poi.ExcelUtil; | import com.ruoyi.common.utils.poi.ExcelUtil; | ||||||
| import com.ruoyi.common.core.page.TableDataInfo; | import com.ruoyi.common.core.page.TableDataInfo; | ||||||
| @@ -41,7 +41,7 @@ public class CmsAppUserController extends BaseController | |||||||
|      * 查询APP用户列表 |      * 查询APP用户列表 | ||||||
|      */ |      */ | ||||||
|     @ApiOperation("查询APP用户列表") |     @ApiOperation("查询APP用户列表") | ||||||
|     @PreAuthorize("@ss.hasPermi('bussiness:user:list')") |     @PreAuthorize("@ss.hasPermi('cms:appUser:list')") | ||||||
|     @GetMapping("/list") |     @GetMapping("/list") | ||||||
|     public TableDataInfo list(AppUser appUser) |     public TableDataInfo list(AppUser appUser) | ||||||
|     { |     { | ||||||
| @@ -54,7 +54,7 @@ public class CmsAppUserController extends BaseController | |||||||
|      * 导出APP用户列表 |      * 导出APP用户列表 | ||||||
|      */ |      */ | ||||||
|     @ApiOperation("导出APP用户列表") |     @ApiOperation("导出APP用户列表") | ||||||
|     @PreAuthorize("@ss.hasPermi('bussiness:user:export')") |     @PreAuthorize("@ss.hasPermi('cms:appUser:export')") | ||||||
|     @Log(title = "APP用户", businessType = BusinessType.EXPORT) |     @Log(title = "APP用户", businessType = BusinessType.EXPORT) | ||||||
|     @PostMapping("/export") |     @PostMapping("/export") | ||||||
|     public void export(HttpServletResponse response, AppUser appUser) |     public void export(HttpServletResponse response, AppUser appUser) | ||||||
|   | |||||||
| @@ -2,11 +2,15 @@ package com.ruoyi.cms.controller.cms; | |||||||
|  |  | ||||||
| import com.ruoyi.cms.domain.Job; | import com.ruoyi.cms.domain.Job; | ||||||
| import com.ruoyi.cms.domain.vo.CandidateVO; | import com.ruoyi.cms.domain.vo.CandidateVO; | ||||||
|  | import com.ruoyi.cms.service.ICompanyService; | ||||||
| import com.ruoyi.cms.service.IJobService; | import com.ruoyi.cms.service.IJobService; | ||||||
|  | import com.ruoyi.cms.util.RoleUtils; | ||||||
|  | import com.ruoyi.cms.util.sensitiveWord.SensitiveWordChecker; | ||||||
| import com.ruoyi.common.annotation.Anonymous; | import com.ruoyi.common.annotation.Anonymous; | ||||||
| import com.ruoyi.common.annotation.Log; | import com.ruoyi.common.annotation.Log; | ||||||
| import com.ruoyi.common.core.controller.BaseController; | import com.ruoyi.common.core.controller.BaseController; | ||||||
| import com.ruoyi.common.core.domain.AjaxResult; | import com.ruoyi.common.core.domain.AjaxResult; | ||||||
|  | import com.ruoyi.common.core.domain.entity.Company; | ||||||
| import com.ruoyi.common.core.page.TableDataInfo; | import com.ruoyi.common.core.page.TableDataInfo; | ||||||
| import com.ruoyi.common.enums.BusinessType; | import com.ruoyi.common.enums.BusinessType; | ||||||
| import com.ruoyi.common.utils.poi.ExcelUtil; | import com.ruoyi.common.utils.poi.ExcelUtil; | ||||||
| @@ -18,6 +22,7 @@ import org.springframework.web.bind.annotation.*; | |||||||
|  |  | ||||||
| import javax.servlet.http.HttpServletResponse; | import javax.servlet.http.HttpServletResponse; | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  | import java.util.Objects; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * 岗位Controller |  * 岗位Controller | ||||||
| @@ -33,14 +38,22 @@ public class CmsJobController extends BaseController | |||||||
| { | { | ||||||
|     @Autowired |     @Autowired | ||||||
|     private IJobService jobService; |     private IJobService jobService; | ||||||
|  |     @Autowired | ||||||
|  |     SensitiveWordChecker sensitiveWordChecker; | ||||||
|  |     @Autowired | ||||||
|  |     private ICompanyService companyService; | ||||||
|     /** |     /** | ||||||
|      * 查询岗位列表 |      * 查询岗位列表 | ||||||
|      */ |      */ | ||||||
|     @ApiOperation("查询岗位列表") |     @ApiOperation("查询岗位列表") | ||||||
|     @PreAuthorize("@ss.hasPermi('bussiness:job:list')") |     @PreAuthorize("@ss.hasPermi('cms:job:list')") | ||||||
|     @GetMapping("/list") |     @GetMapping("/list") | ||||||
|     public TableDataInfo list(Job job) |     public TableDataInfo list(Job job) | ||||||
|     { |     { | ||||||
|  |         if (RoleUtils.isCompanyAdmin()) { | ||||||
|  |             Company company = companyService.queryCodeCompany(RoleUtils.getCurrentUseridCard()); | ||||||
|  |             job.setCompanyId(Objects.nonNull(company) ? company.getCompanyId() : null); | ||||||
|  |         } | ||||||
|         startPage(); |         startPage(); | ||||||
|         List<Job> list = jobService.selectJobList(job); |         List<Job> list = jobService.selectJobList(job); | ||||||
|         return getDataTable(list); |         return getDataTable(list); | ||||||
| @@ -79,6 +92,13 @@ public class CmsJobController extends BaseController | |||||||
|     @PostMapping |     @PostMapping | ||||||
|     public AjaxResult add(@RequestBody Job job) |     public AjaxResult add(@RequestBody Job job) | ||||||
|     { |     { | ||||||
|  |         // 校验描述中的敏感词 | ||||||
|  |         List<String> sensitiveWords = sensitiveWordChecker.checkSensitiveWords(job.getDescription()); | ||||||
|  |         if (!sensitiveWords.isEmpty()) { | ||||||
|  |             String errorMsg = "描述中包含敏感词:" + String.join("、", sensitiveWords); | ||||||
|  |             return AjaxResult.error(errorMsg); | ||||||
|  |         } | ||||||
|  |         // 无敏感词,执行插入 | ||||||
|         return toAjax(jobService.insertJob(job)); |         return toAjax(jobService.insertJob(job)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -91,6 +111,12 @@ public class CmsJobController extends BaseController | |||||||
|     @PutMapping |     @PutMapping | ||||||
|     public AjaxResult edit(@RequestBody Job job) |     public AjaxResult edit(@RequestBody Job job) | ||||||
|     { |     { | ||||||
|  |         // 校验描述中的敏感词 | ||||||
|  |         List<String> sensitiveWords = sensitiveWordChecker.checkSensitiveWords(job.getDescription()); | ||||||
|  |         if (!sensitiveWords.isEmpty()) { | ||||||
|  |             String errorMsg = "描述中包含敏感词:" + String.join("、", sensitiveWords); | ||||||
|  |             return AjaxResult.error(errorMsg); | ||||||
|  |         } | ||||||
|         return toAjax(jobService.updateJob(job)); |         return toAjax(jobService.updateJob(job)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| package com.ruoyi.cms.controller.cms; | package com.ruoyi.cms.controller.cms; | ||||||
|  |  | ||||||
|  |  | ||||||
| import com.ruoyi.cms.domain.CompanyContact; | import com.ruoyi.common.core.domain.entity.CompanyContact; | ||||||
| import com.ruoyi.cms.service.CompanyContactService; | import com.ruoyi.cms.service.CompanyContactService; | ||||||
| import com.ruoyi.common.core.controller.BaseController; | import com.ruoyi.common.core.controller.BaseController; | ||||||
| import com.ruoyi.common.core.page.TableDataInfo; | import com.ruoyi.common.core.page.TableDataInfo; | ||||||
|   | |||||||
| @@ -1,8 +1,8 @@ | |||||||
| package com.ruoyi.cms.controller.cms; | package com.ruoyi.cms.controller.cms; | ||||||
|  |  | ||||||
|  |  | ||||||
| import com.ruoyi.cms.domain.Company; | import com.ruoyi.cms.util.RoleUtils; | ||||||
| import com.ruoyi.cms.service.ICompanyCollectionService; | import com.ruoyi.common.core.domain.entity.Company; | ||||||
| import com.ruoyi.cms.service.ICompanyService; | import com.ruoyi.cms.service.ICompanyService; | ||||||
| import com.ruoyi.common.annotation.Log; | import com.ruoyi.common.annotation.Log; | ||||||
| import com.ruoyi.common.core.controller.BaseController; | import com.ruoyi.common.core.controller.BaseController; | ||||||
| @@ -12,7 +12,6 @@ import com.ruoyi.common.enums.BusinessType; | |||||||
| import com.ruoyi.common.utils.poi.ExcelUtil; | import com.ruoyi.common.utils.poi.ExcelUtil; | ||||||
| import io.swagger.annotations.Api; | import io.swagger.annotations.Api; | ||||||
| import io.swagger.annotations.ApiOperation; | import io.swagger.annotations.ApiOperation; | ||||||
| import io.swagger.annotations.ApiParam; |  | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.security.access.prepost.PreAuthorize; | import org.springframework.security.access.prepost.PreAuthorize; | ||||||
| import org.springframework.web.bind.annotation.*; | import org.springframework.web.bind.annotation.*; | ||||||
| @@ -38,10 +37,13 @@ public class CompanyController extends BaseController | |||||||
|      * 查询公司列表 |      * 查询公司列表 | ||||||
|      */ |      */ | ||||||
|     @ApiOperation("查询公司列表") |     @ApiOperation("查询公司列表") | ||||||
|     @PreAuthorize("@ss.hasPermi('app:company:list')") |     @PreAuthorize("@ss.hasPermi('cms:company:list')") | ||||||
|     @GetMapping("/list") |     @GetMapping("/list") | ||||||
|     public TableDataInfo list(Company company) |     public TableDataInfo list(Company company) | ||||||
|     { |     { | ||||||
|  |         if (RoleUtils.isCompanyAdmin()) { | ||||||
|  |             company.setCode(RoleUtils.getCurrentUseridCard()); | ||||||
|  |         } | ||||||
|         startPage(); |         startPage(); | ||||||
|         List<Company> list = companyService.selectCompanyList(company); |         List<Company> list = companyService.selectCompanyList(company); | ||||||
|         return getDataTable(list); |         return getDataTable(list); | ||||||
|   | |||||||
| @@ -0,0 +1,71 @@ | |||||||
|  | package com.ruoyi.cms.controller.cms; | ||||||
|  |  | ||||||
|  | import com.ruoyi.cms.domain.EmployeeConfirm; | ||||||
|  | import com.ruoyi.cms.service.EmployeeConfirmService; | ||||||
|  | import com.ruoyi.common.annotation.Log; | ||||||
|  | import com.ruoyi.common.core.controller.BaseController; | ||||||
|  | import com.ruoyi.common.core.domain.AjaxResult; | ||||||
|  | import com.ruoyi.common.core.page.TableDataInfo; | ||||||
|  | import com.ruoyi.common.enums.BusinessType; | ||||||
|  | import io.swagger.annotations.Api; | ||||||
|  | import io.swagger.annotations.ApiOperation; | ||||||
|  | import org.springframework.beans.factory.annotation.Autowired; | ||||||
|  | import org.springframework.security.access.prepost.PreAuthorize; | ||||||
|  | import org.springframework.web.bind.annotation.*; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 新入职员工确认信息 | ||||||
|  |  * | ||||||
|  |  * @author  | ||||||
|  |  * @email  | ||||||
|  |  * @date 2025-10-10 10:42:16 | ||||||
|  |  */ | ||||||
|  | @RestController | ||||||
|  | @RequestMapping("/cms/employeeConfirm") | ||||||
|  | @Api(tags = "后台:新入职员工确认信息") | ||||||
|  | public class EmployeeConfirmController extends BaseController { | ||||||
|  |     @Autowired | ||||||
|  |     private EmployeeConfirmService employeeConfirmService; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 列表 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("新入职员工确认信息列表") | ||||||
|  |     @PreAuthorize("@ss.hasPermi('cms:employeeConfirm:list')") | ||||||
|  |     @RequestMapping("/list") | ||||||
|  |     public TableDataInfo list(EmployeeConfirm employeeConfirm){ | ||||||
|  |         List<EmployeeConfirm> list=employeeConfirmService.getEmployeeConfirmList(employeeConfirm); | ||||||
|  |         return getDataTable(list); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 保存 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("新增新入职员工确认信息") | ||||||
|  |     @PreAuthorize("@ss.hasPermi('cms:employeeConfirm:add')") | ||||||
|  |     @Log(title = "职员工确认信息", businessType = BusinessType.INSERT) | ||||||
|  |     @PostMapping | ||||||
|  |     public AjaxResult add(@RequestBody EmployeeConfirm employeeConfirm){ | ||||||
|  |         return toAjax(employeeConfirmService.insertEmployeeConfirm(employeeConfirm)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @ApiOperation("修改新入职员工确认信息") | ||||||
|  |     @PreAuthorize("@ss.hasPermi('cms:employeeConfirm:edit')") | ||||||
|  |     @Log(title = "职员工确认信息", businessType = BusinessType.UPDATE) | ||||||
|  |     @PutMapping | ||||||
|  |     public AjaxResult edit(@RequestBody EmployeeConfirm employeeConfirm){ | ||||||
|  |         return toAjax(employeeConfirmService.updateEmployeeConfirm(employeeConfirm)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @ApiOperation("删除新入职员工确认信息") | ||||||
|  |     @PreAuthorize("@ss.hasPermi('app:employeeConfirm:remove')") | ||||||
|  |     @Log(title = "公司", businessType = BusinessType.DELETE) | ||||||
|  |     @DeleteMapping("/{employeeConfirmIds}") | ||||||
|  |     public AjaxResult remove(@PathVariable Long[] employeeConfirmIds) | ||||||
|  |     { | ||||||
|  |         return toAjax(employeeConfirmService.deleteEmployeeConfirmIds(employeeConfirmIds)); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -0,0 +1,68 @@ | |||||||
|  | package com.ruoyi.cms.controller.cms; | ||||||
|  |  | ||||||
|  | import com.ruoyi.cms.domain.Job; | ||||||
|  | import com.ruoyi.cms.domain.JobApply; | ||||||
|  | import com.ruoyi.cms.domain.vo.CandidateVO; | ||||||
|  | import com.ruoyi.cms.service.IJobApplyService; | ||||||
|  | import com.ruoyi.cms.util.RoleUtils; | ||||||
|  | import com.ruoyi.common.annotation.Log; | ||||||
|  | import com.ruoyi.common.core.controller.BaseController; | ||||||
|  | import com.ruoyi.common.core.domain.AjaxResult; | ||||||
|  | import com.ruoyi.common.core.domain.entity.AppUser; | ||||||
|  | import com.ruoyi.common.core.domain.entity.Company; | ||||||
|  | import com.ruoyi.common.core.page.TableDataInfo; | ||||||
|  | import com.ruoyi.common.enums.BusinessType; | ||||||
|  | import com.ruoyi.common.utils.poi.ExcelUtil; | ||||||
|  | import io.swagger.annotations.Api; | ||||||
|  | import io.swagger.annotations.ApiOperation; | ||||||
|  | import org.springframework.beans.factory.annotation.Autowired; | ||||||
|  | import org.springframework.security.access.prepost.PreAuthorize; | ||||||
|  | import org.springframework.web.bind.annotation.*; | ||||||
|  |  | ||||||
|  | import javax.servlet.http.HttpServletResponse; | ||||||
|  | import java.util.HashMap; | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | @RestController | ||||||
|  | @RequestMapping("/cms/jobApply") | ||||||
|  | @Api(tags = "后台:岗位申请") | ||||||
|  | public class JobApplyController extends BaseController { | ||||||
|  |  | ||||||
|  |     @Autowired | ||||||
|  |     IJobApplyService iJobApplyService; | ||||||
|  |  | ||||||
|  |     @GetMapping("/trendChart") | ||||||
|  |     public AjaxResult trendChart(JobApply jobApply) | ||||||
|  |     { | ||||||
|  |         HashMap<String,Integer> result = iJobApplyService.trendChart(jobApply); | ||||||
|  |         return success(result); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 导出APP用户列表 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("导出岗位申请APP用户") | ||||||
|  |     @PreAuthorize("@ss.hasPermi('cms:jobApply:export')") | ||||||
|  |     @Log(title = "APP用户", businessType = BusinessType.EXPORT) | ||||||
|  |     @PostMapping("/export") | ||||||
|  |     public void export(HttpServletResponse response, Job job) | ||||||
|  |     { | ||||||
|  |         List<CandidateVO> list = iJobApplyService.selectAppUserList(job); | ||||||
|  |         ExcelUtil<CandidateVO> util = new ExcelUtil<CandidateVO>(CandidateVO.class); | ||||||
|  |         util.exportExcel(response, list, "APP用户数据"); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @ApiOperation("获取求职者列表") | ||||||
|  |     @PreAuthorize("@ss.hasPermi('cms:jobApply:applyJobUserList')") | ||||||
|  |     @GetMapping("/applyJobUserList") | ||||||
|  |     public TableDataInfo applyJobList(AppUser appUser) | ||||||
|  |     { | ||||||
|  |         if (RoleUtils.isCompanyAdmin()) { | ||||||
|  |             Company company=new Company(); | ||||||
|  |             company.setCode(RoleUtils.getCurrentUseridCard()); | ||||||
|  |         } | ||||||
|  |         startPage(); | ||||||
|  |         List<CandidateVO> list = iJobApplyService.selectApplyJobUserList(appUser); | ||||||
|  |         return getDataTable(list); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -0,0 +1,114 @@ | |||||||
|  | package com.ruoyi.cms.controller.cms; | ||||||
|  |  | ||||||
|  | import com.ruoyi.cms.domain.SensitiveWordData; | ||||||
|  | import com.ruoyi.cms.service.SensitiveWordDataService; | ||||||
|  | import com.ruoyi.cms.util.EasyExcelUtils; | ||||||
|  | import com.ruoyi.common.annotation.Log; | ||||||
|  | import com.ruoyi.common.core.controller.BaseController; | ||||||
|  | import com.ruoyi.common.core.domain.AjaxResult; | ||||||
|  | import com.ruoyi.common.core.page.TableDataInfo; | ||||||
|  | import com.ruoyi.common.enums.BusinessType; | ||||||
|  | import io.swagger.annotations.Api; | ||||||
|  | import io.swagger.annotations.ApiOperation; | ||||||
|  | import org.springframework.beans.factory.annotation.Autowired; | ||||||
|  | import org.springframework.security.access.prepost.PreAuthorize; | ||||||
|  | import org.springframework.web.bind.annotation.*; | ||||||
|  | import org.springframework.web.multipart.MultipartFile; | ||||||
|  |  | ||||||
|  | import java.io.InputStream; | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 敏感词库 | ||||||
|  |  * | ||||||
|  |  * @author  | ||||||
|  |  * @email  | ||||||
|  |  * @date 2025-10-10 10:42:16 | ||||||
|  |  */ | ||||||
|  | @RestController | ||||||
|  | @RequestMapping("/cms/sensitiveworddata") | ||||||
|  | @Api(tags = "后台:敏感词库") | ||||||
|  | public class SensitiveWordDataController extends BaseController { | ||||||
|  |     @Autowired | ||||||
|  |     private SensitiveWordDataService sensitiveWordDataService; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 列表 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("敏感词库详细信息") | ||||||
|  |     @PreAuthorize("@ss.hasPermi('cms:sensitiveworddata:list')") | ||||||
|  |     @GetMapping("/list") | ||||||
|  |     public TableDataInfo list(SensitiveWordData sensitiveWordData){ | ||||||
|  |         startPage(); | ||||||
|  |         List<SensitiveWordData> list = sensitiveWordDataService.selectSensitiveworddataList(sensitiveWordData); | ||||||
|  |         return getDataTable(list); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取详细信息 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("获取敏感词库详细信息") | ||||||
|  |     @PreAuthorize("@ss.hasPermi('cms:sensitiveworddata:query')") | ||||||
|  |     @GetMapping(value = "/{id}") | ||||||
|  |     public AjaxResult list(@PathVariable("id") Long id){ | ||||||
|  |         return success(sensitiveWordDataService.selectById(id)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 保存 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("新增敏感词") | ||||||
|  |     @PreAuthorize("@ss.hasPermi('cms:sensitiveworddata:add')") | ||||||
|  |     @Log(title = "敏感词", businessType = BusinessType.INSERT) | ||||||
|  |     @PostMapping | ||||||
|  |     public AjaxResult save(@RequestBody SensitiveWordData sensitiveWordData){ | ||||||
|  |  | ||||||
|  |         return toAjax(sensitiveWordDataService.insertSensitiveworddata(sensitiveWordData)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 修改 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("修改敏感词") | ||||||
|  |     @PreAuthorize("@ss.hasPermi('cms:sensitiveworddata:edit')") | ||||||
|  |     @Log(title = "敏感词", businessType = BusinessType.UPDATE) | ||||||
|  |     @PutMapping | ||||||
|  |     public AjaxResult edit(@RequestBody SensitiveWordData sensitiveWordData){ | ||||||
|  |         return toAjax(sensitiveWordDataService.updateSensitiveworddata(sensitiveWordData)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 删除敏感词 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("删除敏感词") | ||||||
|  |     @PreAuthorize("@ss.hasPermi('cms:sensitiveworddata:remove')") | ||||||
|  |     @Log(title = "敏感词", businessType = BusinessType.DELETE) | ||||||
|  |     @DeleteMapping("/{ids}") | ||||||
|  |     public AjaxResult remove(@PathVariable Long[] ids) | ||||||
|  |     { | ||||||
|  |         return toAjax(sensitiveWordDataService.deleteSensitiveworddataIds(ids)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 通用上传请求(单个) | ||||||
|  |      */ | ||||||
|  |     @PostMapping("/exoprt") | ||||||
|  |     public AjaxResult uploadFile(@RequestParam("file") MultipartFile file) throws Exception | ||||||
|  |     { | ||||||
|  |         try | ||||||
|  |         { | ||||||
|  |             InputStream inputStream = file.getInputStream(); | ||||||
|  |             EasyExcelUtils.readExcelByBatch(inputStream, SensitiveWordData.class, 100, list -> { | ||||||
|  |                 // 处理逻辑:如批量保存到数据库 | ||||||
|  |                 sensitiveWordDataService.batchInsert(list); | ||||||
|  |             }); | ||||||
|  |         } | ||||||
|  |         catch (Exception e) | ||||||
|  |         { | ||||||
|  |             return AjaxResult.error(e.getMessage()); | ||||||
|  |         } | ||||||
|  |         return AjaxResult.success(); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -0,0 +1,93 @@ | |||||||
|  | package com.ruoyi.cms.controller.cms; | ||||||
|  |  | ||||||
|  | import com.ruoyi.common.core.domain.entity.UserWorkExperiences; | ||||||
|  | import com.ruoyi.cms.service.UserWorkExperiencesService; | ||||||
|  | import com.ruoyi.common.annotation.Log; | ||||||
|  | import com.ruoyi.common.core.controller.BaseController; | ||||||
|  | import com.ruoyi.common.core.domain.AjaxResult; | ||||||
|  | import com.ruoyi.common.core.page.TableDataInfo; | ||||||
|  | import com.ruoyi.common.enums.BusinessType; | ||||||
|  | import io.swagger.annotations.Api; | ||||||
|  | import io.swagger.annotations.ApiOperation; | ||||||
|  | import org.springframework.beans.factory.annotation.Autowired; | ||||||
|  | import org.springframework.security.access.prepost.PreAuthorize; | ||||||
|  | import org.springframework.web.bind.annotation.*; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 用户工作经历表 | ||||||
|  |  * | ||||||
|  |  * @author  | ||||||
|  |  * @email  | ||||||
|  |  * @date 2025-10-10 16:26:26 | ||||||
|  |  */ | ||||||
|  | @RestController | ||||||
|  | @RequestMapping("/cms/userworkexperiences") | ||||||
|  | @Api(tags = "后台:用户工作经历") | ||||||
|  | public class UserWorkExperiencesController extends BaseController { | ||||||
|  |  | ||||||
|  |     @Autowired | ||||||
|  |     private UserWorkExperiencesService userWorkExperiencesService; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 列表 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("工作经历列表信息") | ||||||
|  |     @PreAuthorize("@ss.hasPermi('cms:userworkexperiences:list')") | ||||||
|  |     @GetMapping("/list") | ||||||
|  |     public TableDataInfo list(UserWorkExperiences userWorkExperiences){ | ||||||
|  |         startPage(); | ||||||
|  |         List<UserWorkExperiences> list=userWorkExperiencesService.getWorkExperiencesList(userWorkExperiences); | ||||||
|  |         return getDataTable(list); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 信息 | ||||||
|  |      */ | ||||||
|  |     /** | ||||||
|  |      * 获取详细信息 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("获取工作经历详细信息") | ||||||
|  |     @PreAuthorize("@ss.hasPermi('cms:userworkexperiences:query')") | ||||||
|  |     @GetMapping(value = "/{id}") | ||||||
|  |     public AjaxResult query(@PathVariable("id") Long id){ | ||||||
|  |         return success(userWorkExperiencesService.getWorkExperiencesById(id)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 保存 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("新增工作经历") | ||||||
|  |     @PreAuthorize("@ss.hasPermi('cms:userworkexperiences:add')") | ||||||
|  |     @Log(title = "工作经历", businessType = BusinessType.INSERT) | ||||||
|  |     @PostMapping | ||||||
|  |     public AjaxResult add(@RequestBody UserWorkExperiences userWorkExperiences){ | ||||||
|  |         return toAjax(userWorkExperiencesService.insertWorkExperiences(userWorkExperiences)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 修改 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("修改工作经历") | ||||||
|  |     @PreAuthorize("@ss.hasPermi('cms:userworkexperiences:edit')") | ||||||
|  |     @Log(title = "工作经历", businessType = BusinessType.UPDATE) | ||||||
|  |     @PutMapping | ||||||
|  |     public AjaxResult update(@RequestBody UserWorkExperiences userWorkExperiences){ | ||||||
|  |         return toAjax(userWorkExperiencesService.updateWorkExperiencesById(userWorkExperiences)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 删除 | ||||||
|  |      */ | ||||||
|  |     @ApiOperation("删除工作经历") | ||||||
|  |     @PreAuthorize("@ss.hasPermi('cms:sensitiveworddata:remove')") | ||||||
|  |     @Log(title = "工作经历", businessType = BusinessType.DELETE) | ||||||
|  |     @DeleteMapping("/{ids}") | ||||||
|  |     public AjaxResult remove(Long[] ids){ | ||||||
|  |         return toAjax(userWorkExperiencesService.deleteWorkExperiencesIds(ids)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -2,6 +2,7 @@ package com.ruoyi.cms.domain; | |||||||
|  |  | ||||||
| import com.fasterxml.jackson.annotation.JsonFormat; | import com.fasterxml.jackson.annotation.JsonFormat; | ||||||
| import com.fasterxml.jackson.annotation.JsonIgnore; | import com.fasterxml.jackson.annotation.JsonIgnore; | ||||||
|  | import com.ruoyi.common.core.domain.entity.Company; | ||||||
| import io.swagger.annotations.ApiModelProperty; | import io.swagger.annotations.ApiModelProperty; | ||||||
| import lombok.Data; | import lombok.Data; | ||||||
| import org.dromara.easyes.annotation.IndexField; | import org.dromara.easyes.annotation.IndexField; | ||||||
| @@ -139,4 +140,13 @@ public class ESJobDocument | |||||||
|  |  | ||||||
|     @ApiModelProperty("视频封面URL") |     @ApiModelProperty("视频封面URL") | ||||||
|     private String cover; |     private String cover; | ||||||
|  |  | ||||||
|  |     @ApiModelProperty("岗位类型 0疆内 1疆外") | ||||||
|  |     private String jobType; | ||||||
|  |  | ||||||
|  |     @ApiModelProperty("类型 0常规岗位 1就业见习岗位 2实习实训岗位 3社区实践岗位 对应字段字典position_type") | ||||||
|  |     private String type; | ||||||
|  |  | ||||||
|  |     @ApiModelProperty("信用代码") | ||||||
|  |     private String code; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,71 @@ | |||||||
|  | package com.ruoyi.cms.domain; | ||||||
|  |  | ||||||
|  | import com.baomidou.mybatisplus.annotation.IdType; | ||||||
|  | import com.baomidou.mybatisplus.annotation.TableField; | ||||||
|  | import com.baomidou.mybatisplus.annotation.TableId; | ||||||
|  | import com.baomidou.mybatisplus.annotation.TableName; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | import com.ruoyi.common.core.domain.BaseEntity; | ||||||
|  | import io.swagger.annotations.ApiModelProperty; | ||||||
|  | import lombok.Data; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 新入职员工确认信息 | ||||||
|  |  *  | ||||||
|  |  * @author  | ||||||
|  |  * @email  | ||||||
|  |  * @date 2025-10-10 10:42:16 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | @TableName("employee_confirm") | ||||||
|  | public class EmployeeConfirm extends BaseEntity { | ||||||
|  | 	@TableField(exist = false) | ||||||
|  | 	private static final long serialVersionUID = 1L; | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * 主键id | ||||||
|  | 	 */ | ||||||
|  | 	@TableId(value = "id",type = IdType.AUTO) | ||||||
|  | 	@ApiModelProperty("id") | ||||||
|  | 	private Long id; | ||||||
|  | 	/** | ||||||
|  | 	 * 企业id | ||||||
|  | 	 */ | ||||||
|  | 	@ApiModelProperty("企业id") | ||||||
|  | 	private Long companyId; | ||||||
|  | 	/** | ||||||
|  | 	 * 姓名 | ||||||
|  | 	 */ | ||||||
|  | 	@ApiModelProperty("姓名") | ||||||
|  | 	private String contactPerson; | ||||||
|  | 	/** | ||||||
|  | 	 * 身份证 | ||||||
|  | 	 */ | ||||||
|  | 	@ApiModelProperty("身份证") | ||||||
|  | 	private String idCard; | ||||||
|  | 	/** | ||||||
|  | 	 * 入职日期 | ||||||
|  | 	 */ | ||||||
|  | 	@ApiModelProperty("入职日期") | ||||||
|  | 	private String entryDate; | ||||||
|  | 	/** | ||||||
|  | 	 * 联系电话 | ||||||
|  | 	 */ | ||||||
|  | 	@ApiModelProperty("联系电话") | ||||||
|  | 	private String contactPersonPhone; | ||||||
|  | 	/** | ||||||
|  | 	 * 劳动合同期限 | ||||||
|  | 	 */ | ||||||
|  | 	@ApiModelProperty("劳动合同期限") | ||||||
|  | 	private String contractTerm; | ||||||
|  |  | ||||||
|  | 	@ApiModelProperty("工作id") | ||||||
|  | 	private Long jobId; | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * 申请id | ||||||
|  | 	 */ | ||||||
|  | 	@TableField(exist = false) | ||||||
|  | 	private Long applyId; | ||||||
|  | } | ||||||
| @@ -8,6 +8,7 @@ import com.fasterxml.jackson.annotation.JsonFormat; | |||||||
| import com.fasterxml.jackson.annotation.JsonIgnore; | import com.fasterxml.jackson.annotation.JsonIgnore; | ||||||
| import com.ruoyi.common.annotation.Excel; | import com.ruoyi.common.annotation.Excel; | ||||||
| import com.ruoyi.common.core.domain.BaseEntity; | import com.ruoyi.common.core.domain.BaseEntity; | ||||||
|  | import com.ruoyi.common.core.domain.entity.Company; | ||||||
| import io.swagger.annotations.ApiModel; | import io.swagger.annotations.ApiModel; | ||||||
| import io.swagger.annotations.ApiModelProperty; | import io.swagger.annotations.ApiModelProperty; | ||||||
| import lombok.Data; | import lombok.Data; | ||||||
| @@ -108,7 +109,7 @@ public class Job extends BaseEntity | |||||||
|     @ApiModelProperty("是否收藏 0为否 1为是") |     @ApiModelProperty("是否收藏 0为否 1为是") | ||||||
|     private Integer isCollection; |     private Integer isCollection; | ||||||
|  |  | ||||||
|     @ApiModelProperty("工作地点") |     @ApiModelProperty("岗位描述") | ||||||
|     private String description; |     private String description; | ||||||
|  |  | ||||||
|     @ApiModelProperty("是否发布 0未发布 1发布") |     @ApiModelProperty("是否发布 0未发布 1发布") | ||||||
| @@ -162,7 +163,14 @@ public class Job extends BaseEntity | |||||||
|     @ApiModelProperty("岗位类型 0疆内 1疆外") |     @ApiModelProperty("岗位类型 0疆内 1疆外") | ||||||
|     private String jobType; |     private String jobType; | ||||||
|  |  | ||||||
|  |     @ApiModelProperty("类型 0常规岗位 1就业见习岗位 2实习实训岗位 3社区实践岗位 4零工 对应字段字典position_type") | ||||||
|  |     private String type; | ||||||
|  |  | ||||||
|     @TableField(exist = false) |     @TableField(exist = false) | ||||||
|     @ApiModelProperty("岗位联系人列表") |     @ApiModelProperty("岗位联系人列表") | ||||||
|     private List<JobContact> jobContactList; |     private List<JobContact> jobContactList; | ||||||
|  |  | ||||||
|  |     @TableField(exist = false) | ||||||
|  |     @ApiModelProperty("附件列表") | ||||||
|  |     private List<File> filesList; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -38,4 +38,6 @@ public class JobApply extends BaseEntity | |||||||
|     @ApiModelProperty("匹配度") |     @ApiModelProperty("匹配度") | ||||||
|     private Long matchingDegree; |     private Long matchingDegree; | ||||||
|  |  | ||||||
|  |     @ApiModelProperty("是否录用 0录用 2或null未录用") | ||||||
|  |     private String hire; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -5,6 +5,7 @@ import java.util.Date; | |||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| import com.fasterxml.jackson.annotation.JsonFormat; | import com.fasterxml.jackson.annotation.JsonFormat; | ||||||
|  | import com.ruoyi.common.core.domain.entity.Company; | ||||||
| import lombok.Data; | import lombok.Data; | ||||||
| import com.ruoyi.common.annotation.Excel; | import com.ruoyi.common.annotation.Excel; | ||||||
| import io.swagger.annotations.ApiModel; | import io.swagger.annotations.ApiModel; | ||||||
|   | |||||||
| @@ -0,0 +1,45 @@ | |||||||
|  | package com.ruoyi.cms.domain; | ||||||
|  |  | ||||||
|  | import com.alibaba.excel.annotation.ExcelProperty; | ||||||
|  | import com.baomidou.mybatisplus.annotation.IdType; | ||||||
|  | import com.baomidou.mybatisplus.annotation.TableField; | ||||||
|  | import com.baomidou.mybatisplus.annotation.TableId; | ||||||
|  | import com.baomidou.mybatisplus.annotation.TableName; | ||||||
|  |  | ||||||
|  | import com.ruoyi.common.core.domain.BaseEntity; | ||||||
|  | import io.swagger.annotations.ApiModelProperty; | ||||||
|  | import lombok.Data; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 敏感词库 | ||||||
|  |  *  | ||||||
|  |  * @author  | ||||||
|  |  * @email  | ||||||
|  |  * @date 2025-10-10 10:42:16 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | @TableName("sensitive_word_data") | ||||||
|  | public class SensitiveWordData extends BaseEntity { | ||||||
|  | 	@TableField(exist = false) | ||||||
|  | 	private static final long serialVersionUID = 1L; | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * 主键id | ||||||
|  | 	 */ | ||||||
|  | 	@TableId(value = "id",type = IdType.AUTO) | ||||||
|  | 	@ApiModelProperty("id") | ||||||
|  | 	private Long id; | ||||||
|  | 	/** | ||||||
|  | 	 * 敏感词 | ||||||
|  | 	 */ | ||||||
|  | 	@ExcelProperty(value = "敏感词", index = 0) | ||||||
|  | 	@ApiModelProperty("敏感词") | ||||||
|  | 	private String sensitiveWord; | ||||||
|  | 	/** | ||||||
|  | 	 * 类型 | ||||||
|  | 	 */ | ||||||
|  | 	@ExcelProperty(value = "类型", index = 1) | ||||||
|  | 	@ApiModelProperty("类型") | ||||||
|  | 	private String type; | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -29,7 +29,7 @@ public class ESJobSearch extends Job | |||||||
|  |  | ||||||
|     private String radius; |     private String radius; | ||||||
|  |  | ||||||
|     @ApiModelProperty("排序方式 0:推荐 1:最热 2:最新发布") |     @ApiModelProperty("排序方式 0:推荐 1:最热 2:最新发布 3:最大薪资") | ||||||
|     private Integer order; |     private Integer order; | ||||||
|  |  | ||||||
|     //商圈id |     //商圈id | ||||||
|   | |||||||
| @@ -1,7 +1,8 @@ | |||||||
| package com.ruoyi.cms.domain.vo; | package com.ruoyi.cms.domain.vo; | ||||||
|  |  | ||||||
| import com.fasterxml.jackson.annotation.JsonFormat; | import com.fasterxml.jackson.annotation.JsonFormat; | ||||||
| import com.ruoyi.cms.domain.AppUser; | import com.ruoyi.common.annotation.Excel; | ||||||
|  | import com.ruoyi.common.core.domain.entity.AppUser; | ||||||
| import lombok.Data; | import lombok.Data; | ||||||
|  |  | ||||||
| import java.util.Date; | import java.util.Date; | ||||||
| @@ -11,4 +12,10 @@ public class CandidateVO extends AppUser { | |||||||
|     @JsonFormat(pattern = "yyyy-MM-dd") |     @JsonFormat(pattern = "yyyy-MM-dd") | ||||||
|     private Date applyDate; |     private Date applyDate; | ||||||
|     private Integer matchingDegree; |     private Integer matchingDegree; | ||||||
|  |     private String applyId; | ||||||
|  |  | ||||||
|  |     @Excel(name = "公司名称", sort = 0) | ||||||
|  |     private String companyName; | ||||||
|  |     @Excel(name = "岗位名称", sort = 1) | ||||||
|  |     private String jobName; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,12 @@ | |||||||
|  | package com.ruoyi.cms.domain.vo; | ||||||
|  |  | ||||||
|  | import com.ruoyi.common.core.domain.entity.CompanyContact; | ||||||
|  | import lombok.Data; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | @Data | ||||||
|  | public class CompanyContactVo { | ||||||
|  |  | ||||||
|  |     private List<CompanyContact> companyContactList; | ||||||
|  | } | ||||||
| @@ -0,0 +1,20 @@ | |||||||
|  | package com.ruoyi.cms.mapper; | ||||||
|  |  | ||||||
|  | import com.baomidou.mybatisplus.core.mapper.BaseMapper; | ||||||
|  | import com.ruoyi.common.core.domain.entity.AppSkill; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 用户技能信息 | ||||||
|  |  * | ||||||
|  |  * @author  | ||||||
|  |  * @email  | ||||||
|  |  * @date 2025-10-21 12:22:09 | ||||||
|  |  */ | ||||||
|  | public interface AppSkillMapper extends BaseMapper<AppSkill> { | ||||||
|  |  | ||||||
|  |     List<AppSkill> getList(AppSkill appSkill); | ||||||
|  |  | ||||||
|  |     int batchInsert(List<AppSkill> list); | ||||||
|  | } | ||||||
| @@ -2,7 +2,10 @@ package com.ruoyi.cms.mapper; | |||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.core.mapper.BaseMapper; | import com.baomidou.mybatisplus.core.mapper.BaseMapper; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import com.ruoyi.cms.domain.AppUser; | import java.util.Map; | ||||||
|  |  | ||||||
|  | import com.ruoyi.common.core.domain.entity.AppUser; | ||||||
|  | import com.ruoyi.common.core.domain.entity.SysUser; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * APP用户Mapper接口 |  * APP用户Mapper接口 | ||||||
| @@ -20,4 +23,10 @@ public interface AppUserMapper extends BaseMapper<AppUser> | |||||||
|     public List<AppUser> selectAppUserList(AppUser appUser); |     public List<AppUser> selectAppUserList(AppUser appUser); | ||||||
|  |  | ||||||
|     List<AppUser> selectByJobId(Long jobId); |     List<AppUser> selectByJobId(Long jobId); | ||||||
|  |  | ||||||
|  |     AppUser selectByOpenid(String openid); | ||||||
|  |  | ||||||
|  |     int insertSysUserRole(Map<String,Object> map); | ||||||
|  |  | ||||||
|  |     int insertSysUser(SysUser sysUser); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -3,7 +3,7 @@ package com.ruoyi.cms.mapper; | |||||||
| import com.baomidou.mybatisplus.core.mapper.BaseMapper; | import com.baomidou.mybatisplus.core.mapper.BaseMapper; | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| import com.ruoyi.cms.domain.Company; | import com.ruoyi.common.core.domain.entity.Company; | ||||||
| import com.ruoyi.cms.domain.CompanyCollection; | import com.ruoyi.cms.domain.CompanyCollection; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| package com.ruoyi.cms.mapper; | package com.ruoyi.cms.mapper; | ||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.core.mapper.BaseMapper; | import com.baomidou.mybatisplus.core.mapper.BaseMapper; | ||||||
| import com.ruoyi.cms.domain.CompanyContact; | import com.ruoyi.common.core.domain.entity.CompanyContact; | ||||||
|  |  | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| @@ -15,4 +15,8 @@ import java.util.List; | |||||||
| public interface CompanyContactMapper extends BaseMapper<CompanyContact> { | public interface CompanyContactMapper extends BaseMapper<CompanyContact> { | ||||||
|  |  | ||||||
|     List<CompanyContact> getSelectList(CompanyContact companyContact); |     List<CompanyContact> getSelectList(CompanyContact companyContact); | ||||||
|  |  | ||||||
|  |     int batchInsert(List<CompanyContact> list); | ||||||
|  |  | ||||||
|  |     int batchUpdate(List<CompanyContact> list); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ package com.ruoyi.cms.mapper; | |||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.core.mapper.BaseMapper; | import com.baomidou.mybatisplus.core.mapper.BaseMapper; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import com.ruoyi.cms.domain.Company; | import com.ruoyi.common.core.domain.entity.Company; | ||||||
| import org.apache.ibatis.annotations.Param; | import org.apache.ibatis.annotations.Param; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -25,4 +25,6 @@ public interface CompanyMapper extends BaseMapper<Company> | |||||||
|     void updateJobCountOfCompany(); |     void updateJobCountOfCompany(); | ||||||
|  |  | ||||||
|     List<Company> label(@Param("companyNature") String companyNature, @Param("targ")String targ,@Param("companyName")String companyName); |     List<Company> label(@Param("companyNature") String companyNature, @Param("targ")String targ,@Param("companyName")String companyName); | ||||||
|  |  | ||||||
|  |     List<Company> selectLikeCompanyList(Company company); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,19 @@ | |||||||
|  | package com.ruoyi.cms.mapper; | ||||||
|  |  | ||||||
|  | import com.baomidou.mybatisplus.core.mapper.BaseMapper; | ||||||
|  | import com.ruoyi.cms.domain.EmployeeConfirm; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 新入职员工确认信息 | ||||||
|  |  * | ||||||
|  |  * @author  | ||||||
|  |  * @email  | ||||||
|  |  * @date 2025-10-10 10:42:16 | ||||||
|  |  */ | ||||||
|  | public interface EmployeeConfirmMapper extends BaseMapper<EmployeeConfirm> { | ||||||
|  |  | ||||||
|  |     List<EmployeeConfirm> getEmployeeConfirmList(EmployeeConfirm employeeConfirm); | ||||||
|  | } | ||||||
| @@ -1,11 +1,14 @@ | |||||||
| package com.ruoyi.cms.mapper; | package com.ruoyi.cms.mapper; | ||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.core.mapper.BaseMapper; | import com.baomidou.mybatisplus.core.mapper.BaseMapper; | ||||||
|  |  | ||||||
|  | import java.util.HashMap; | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| import com.ruoyi.cms.domain.Job; | import com.ruoyi.cms.domain.Job; | ||||||
| import com.ruoyi.cms.domain.JobApply; | import com.ruoyi.cms.domain.JobApply; | ||||||
| import com.ruoyi.cms.domain.vo.CandidateVO; | import com.ruoyi.cms.domain.vo.CandidateVO; | ||||||
|  | import com.ruoyi.common.core.domain.entity.AppUser; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * 岗位申请Mapper接口 |  * 岗位申请Mapper接口 | ||||||
| @@ -26,4 +29,10 @@ public interface JobApplyMapper extends BaseMapper<JobApply> | |||||||
|     List<Job> applyJob(Long userId); |     List<Job> applyJob(Long userId); | ||||||
|  |  | ||||||
|     List<CandidateVO> candidates(Long jobId); |     List<CandidateVO> candidates(Long jobId); | ||||||
|  |  | ||||||
|  |     HashMap<String,Integer> trendChart(JobApply jobApply); | ||||||
|  |  | ||||||
|  |     List<CandidateVO> selectAppUserList(Job job); | ||||||
|  |  | ||||||
|  |     List<CandidateVO> selectApplyJobUserList(AppUser appUser); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -15,4 +15,6 @@ import java.util.List; | |||||||
| public interface JobContactMapper extends BaseMapper<JobContact> { | public interface JobContactMapper extends BaseMapper<JobContact> { | ||||||
|  |  | ||||||
|     List<JobContact> getSelectList(JobContact jobContact); |     List<JobContact> getSelectList(JobContact jobContact); | ||||||
|  |  | ||||||
|  |     int batchInsert(List<JobContact> list); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -4,13 +4,12 @@ import com.baomidou.mybatisplus.core.mapper.BaseMapper; | |||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Map; | import java.util.Map; | ||||||
|  |  | ||||||
| import com.ruoyi.cms.domain.Company; | import com.ruoyi.common.core.domain.entity.AppUser; | ||||||
|  | import com.ruoyi.common.core.domain.entity.Company; | ||||||
| import com.ruoyi.cms.domain.Job; | import com.ruoyi.cms.domain.Job; | ||||||
| import com.ruoyi.cms.domain.RowWork; | import com.ruoyi.cms.domain.RowWork; | ||||||
| import com.ruoyi.cms.domain.VectorJob; | import com.ruoyi.cms.domain.VectorJob; | ||||||
| import com.ruoyi.cms.domain.query.ESJobSearch; | import com.ruoyi.cms.domain.query.ESJobSearch; | ||||||
| import org.springframework.beans.factory.annotation.Value; |  | ||||||
| import org.springframework.data.repository.query.Param; |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * 岗位Mapper接口 |  * 岗位Mapper接口 | ||||||
| @@ -50,4 +49,6 @@ public interface JobMapper extends BaseMapper<Job> | |||||||
|     void insertBatchRowWorkTmp(List<RowWork> batchList); |     void insertBatchRowWorkTmp(List<RowWork> batchList); | ||||||
|  |  | ||||||
|     VectorJob selectVectorJob(Long jobId); |     VectorJob selectVectorJob(Long jobId); | ||||||
|  |  | ||||||
|  |     List<AppUser> selectApplyJobUserList(Long jobId); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,21 @@ | |||||||
|  | package com.ruoyi.cms.mapper; | ||||||
|  |  | ||||||
|  | import com.baomidou.mybatisplus.core.mapper.BaseMapper; | ||||||
|  | import com.ruoyi.cms.domain.SensitiveWordData; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 敏感词库 | ||||||
|  |  * | ||||||
|  |  * @author  | ||||||
|  |  * @email  | ||||||
|  |  * @date 2025-10-10 10:42:16 | ||||||
|  |  */ | ||||||
|  | public interface SensitiveWordDataMapper extends BaseMapper<SensitiveWordData> { | ||||||
|  |  | ||||||
|  |     List<SensitiveWordData> selectSensitiveworddataList(SensitiveWordData sensitiveWordData); | ||||||
|  |  | ||||||
|  |     int batchInsert(List<SensitiveWordData> list); | ||||||
|  | } | ||||||
| @@ -0,0 +1,20 @@ | |||||||
|  | package com.ruoyi.cms.mapper; | ||||||
|  |  | ||||||
|  | import com.baomidou.mybatisplus.core.mapper.BaseMapper; | ||||||
|  | import com.ruoyi.common.core.domain.entity.UserWorkExperiences; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 用户工作经历表 | ||||||
|  |  * | ||||||
|  |  * @author  | ||||||
|  |  * @email  | ||||||
|  |  * @date 2025-10-10 16:26:26 | ||||||
|  |  */ | ||||||
|  | public interface UserWorkExperiencesMapper extends BaseMapper<UserWorkExperiences> { | ||||||
|  |  | ||||||
|  |     List<UserWorkExperiences> getWorkExperiencesList(UserWorkExperiences userWorkExperiences); | ||||||
|  |  | ||||||
|  |     int batchInsert(List<UserWorkExperiences> list); | ||||||
|  | } | ||||||
| @@ -0,0 +1,26 @@ | |||||||
|  | package com.ruoyi.cms.service; | ||||||
|  |  | ||||||
|  | import com.ruoyi.common.core.domain.entity.AppSkill; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 用户技能信息 | ||||||
|  |  * | ||||||
|  |  * @author  | ||||||
|  |  * @email  | ||||||
|  |  * @date 2025-10-21 12:22:09 | ||||||
|  |  */ | ||||||
|  | public interface AppSkillService{ | ||||||
|  |  | ||||||
|  |     List<AppSkill> getList(AppSkill appSkill); | ||||||
|  |  | ||||||
|  |     int insertAppskill(AppSkill appSkill); | ||||||
|  |  | ||||||
|  |     int updateAppskillById(AppSkill appSkill); | ||||||
|  |  | ||||||
|  |     int removeAppskillIds(Long[] ids); | ||||||
|  |  | ||||||
|  |     AppSkill getAppskillById(Long id); | ||||||
|  | } | ||||||
|  |  | ||||||
| @@ -1,6 +1,6 @@ | |||||||
| package com.ruoyi.cms.service; | package com.ruoyi.cms.service; | ||||||
|  |  | ||||||
| import com.ruoyi.cms.domain.CompanyContact; | import com.ruoyi.common.core.domain.entity.CompanyContact; | ||||||
|  |  | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| @@ -14,5 +14,7 @@ import java.util.List; | |||||||
| public interface CompanyContactService { | public interface CompanyContactService { | ||||||
|  |  | ||||||
|     List<CompanyContact> getSelectList(CompanyContact companyContact); |     List<CompanyContact> getSelectList(CompanyContact companyContact); | ||||||
|  |  | ||||||
|  |     int insertUpadteCompanyContact(List<CompanyContact> list); | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -0,0 +1,24 @@ | |||||||
|  | package com.ruoyi.cms.service; | ||||||
|  |  | ||||||
|  | import com.ruoyi.cms.domain.EmployeeConfirm; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 新入职员工确认信息 | ||||||
|  |  * | ||||||
|  |  * @author  | ||||||
|  |  * @email  | ||||||
|  |  * @date 2025-10-10 10:42:16 | ||||||
|  |  */ | ||||||
|  | public interface EmployeeConfirmService { | ||||||
|  |  | ||||||
|  |     List<EmployeeConfirm> getEmployeeConfirmList(EmployeeConfirm employeeConfirm); | ||||||
|  |  | ||||||
|  |     int insertEmployeeConfirm(EmployeeConfirm employeeConfirm); | ||||||
|  |  | ||||||
|  |     int updateEmployeeConfirm(EmployeeConfirm employeeConfirm); | ||||||
|  |  | ||||||
|  |     int deleteEmployeeConfirmIds(Long[] ids); | ||||||
|  | } | ||||||
|  |  | ||||||
| @@ -1,7 +1,8 @@ | |||||||
| package com.ruoyi.cms.service; | package com.ruoyi.cms.service; | ||||||
|  |  | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import com.ruoyi.cms.domain.AppUser; | import com.ruoyi.common.core.domain.entity.AppUser; | ||||||
|  | import com.ruoyi.common.core.domain.model.RegisterBody; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * APP用户Service接口 |  * APP用户Service接口 | ||||||
| @@ -51,4 +52,9 @@ public interface IAppUserService | |||||||
|      */ |      */ | ||||||
|     public int deleteAppUserByUserIds(Long[] userIds); |     public int deleteAppUserByUserIds(Long[] userIds); | ||||||
|  |  | ||||||
|  |     public AppUser getPhone(String phone); | ||||||
|  |  | ||||||
|  |     AppUser selectByOpenid(String openid); | ||||||
|  |  | ||||||
|  |     public AppUser registerAppUser(RegisterBody registerBody); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ package com.ruoyi.cms.service; | |||||||
|  |  | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| import com.ruoyi.cms.domain.Company; | import com.ruoyi.common.core.domain.entity.Company; | ||||||
| import com.ruoyi.cms.domain.CompanyCollection; | import com.ruoyi.cms.domain.CompanyCollection; | ||||||
| import com.ruoyi.cms.domain.Job; | import com.ruoyi.cms.domain.Job; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,11 +1,9 @@ | |||||||
| package com.ruoyi.cms.service; | package com.ruoyi.cms.service; | ||||||
|  |  | ||||||
| import java.util.HashMap; |  | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import com.ruoyi.cms.domain.Company; | import com.ruoyi.common.core.domain.entity.Company; | ||||||
| import com.ruoyi.cms.domain.CompanyCard; | import com.ruoyi.cms.domain.CompanyCard; | ||||||
| import com.ruoyi.cms.domain.query.LabelQuery; | import com.ruoyi.cms.domain.query.LabelQuery; | ||||||
| import com.ruoyi.common.core.page.PageDomain; |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * 公司Service接口 |  * 公司Service接口 | ||||||
| @@ -77,4 +75,8 @@ public interface ICompanyService | |||||||
|     List<Company> approvalList(Company company); |     List<Company> approvalList(Company company); | ||||||
|  |  | ||||||
|     Company approval(Company company); |     Company approval(Company company); | ||||||
|  |  | ||||||
|  |     Company queryCodeCompany(String code); | ||||||
|  |  | ||||||
|  |     List<Company> selectLikeCompanyList(Company company); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -67,4 +67,6 @@ public interface IESJobSearchService | |||||||
|     void updateJob(Long jobId); |     void updateJob(Long jobId); | ||||||
|  |  | ||||||
|     void deleteJob(Long jobId); |     void deleteJob(Long jobId); | ||||||
|  |  | ||||||
|  |     List<ESJobDocument> selectByIds(Long[] jobIds); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,7 +1,6 @@ | |||||||
| package com.ruoyi.cms.service; | package com.ruoyi.cms.service; | ||||||
|  |  | ||||||
|  |  | ||||||
| import com.ruoyi.cms.domain.Company; |  | ||||||
| import com.ruoyi.cms.domain.FairCollection; | import com.ruoyi.cms.domain.FairCollection; | ||||||
| import com.ruoyi.cms.domain.JobFair; | import com.ruoyi.cms.domain.JobFair; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -5,6 +5,8 @@ import java.util.List; | |||||||
|  |  | ||||||
| import com.ruoyi.cms.domain.Job; | import com.ruoyi.cms.domain.Job; | ||||||
| import com.ruoyi.cms.domain.JobApply; | import com.ruoyi.cms.domain.JobApply; | ||||||
|  | import com.ruoyi.cms.domain.vo.CandidateVO; | ||||||
|  | import com.ruoyi.common.core.domain.entity.AppUser; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * 岗位申请Service接口 |  * 岗位申请Service接口 | ||||||
| @@ -57,4 +59,10 @@ public interface IJobApplyService | |||||||
|     List<Job> applyJob(); |     List<Job> applyJob(); | ||||||
|  |  | ||||||
|     HashMap<String, Integer> statistics(); |     HashMap<String, Integer> statistics(); | ||||||
|  |  | ||||||
|  |     HashMap<String,Integer> trendChart(JobApply jobApply); | ||||||
|  |  | ||||||
|  |     List<CandidateVO> selectAppUserList(Job job); | ||||||
|  |  | ||||||
|  |     List<CandidateVO> selectApplyJobUserList(AppUser appUser); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -7,6 +7,7 @@ import com.ruoyi.cms.domain.Job; | |||||||
| import com.ruoyi.cms.domain.query.ESJobSearch; | import com.ruoyi.cms.domain.query.ESJobSearch; | ||||||
| import com.ruoyi.cms.domain.vo.CandidateVO; | import com.ruoyi.cms.domain.vo.CandidateVO; | ||||||
| import com.ruoyi.cms.util.AppWechatEntity; | import com.ruoyi.cms.util.AppWechatEntity; | ||||||
|  | import com.ruoyi.common.core.domain.entity.AppUser; | ||||||
| import org.dromara.easyes.core.biz.EsPageInfo; | import org.dromara.easyes.core.biz.EsPageInfo; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -89,4 +90,6 @@ public interface IJobService | |||||||
|     List<ESJobDocument> littleVideoRandom(String uuid, Integer count,String jobTitle); |     List<ESJobDocument> littleVideoRandom(String uuid, Integer count,String jobTitle); | ||||||
|  |  | ||||||
|     void publishJob(Job job); |     void publishJob(Job job); | ||||||
|  |  | ||||||
|  |     List<AppUser> selectApplyJobUserList(Long jobId); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,28 @@ | |||||||
|  | package com.ruoyi.cms.service; | ||||||
|  |  | ||||||
|  | import com.ruoyi.cms.domain.SensitiveWordData; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 敏感词库 | ||||||
|  |  * | ||||||
|  |  * @author  | ||||||
|  |  * @email  | ||||||
|  |  * @date 2025-10-10 10:42:16 | ||||||
|  |  */ | ||||||
|  | public interface SensitiveWordDataService { | ||||||
|  |  | ||||||
|  |     List<SensitiveWordData> selectSensitiveworddataList(SensitiveWordData sensitiveworddata); | ||||||
|  |  | ||||||
|  |     SensitiveWordData selectById(Long id); | ||||||
|  |  | ||||||
|  |     int insertSensitiveworddata(SensitiveWordData sensitiveWordData); | ||||||
|  |  | ||||||
|  |     int updateSensitiveworddata(SensitiveWordData sensitiveWordData); | ||||||
|  |  | ||||||
|  |     int deleteSensitiveworddataIds(Long[] ids); | ||||||
|  |  | ||||||
|  |     int batchInsert(List<SensitiveWordData> list); | ||||||
|  | } | ||||||
|  |  | ||||||
| @@ -0,0 +1,26 @@ | |||||||
|  | package com.ruoyi.cms.service; | ||||||
|  |  | ||||||
|  | import com.ruoyi.common.core.domain.entity.UserWorkExperiences; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 用户工作经历表 | ||||||
|  |  * | ||||||
|  |  * @author  | ||||||
|  |  * @email  | ||||||
|  |  * @date 2025-10-10 16:26:26 | ||||||
|  |  */ | ||||||
|  | public interface UserWorkExperiencesService { | ||||||
|  |  | ||||||
|  |     List<UserWorkExperiences> getWorkExperiencesList(UserWorkExperiences userWorkExperiences); | ||||||
|  |  | ||||||
|  |     int insertWorkExperiences(UserWorkExperiences userWorkExperiences); | ||||||
|  |  | ||||||
|  |     int updateWorkExperiencesById(UserWorkExperiences userWorkExperiences); | ||||||
|  |  | ||||||
|  |     int deleteWorkExperiencesIds(Long[] ids); | ||||||
|  |  | ||||||
|  |     UserWorkExperiences getWorkExperiencesById(Long id); | ||||||
|  | } | ||||||
|  |  | ||||||
| @@ -6,11 +6,11 @@ import com.ruoyi.cms.domain.*; | |||||||
| import com.ruoyi.cms.mapper.*; | import com.ruoyi.cms.mapper.*; | ||||||
| import com.ruoyi.cms.service.IAppNoticeService; | import com.ruoyi.cms.service.IAppNoticeService; | ||||||
| import com.ruoyi.cms.util.StringUtil; | import com.ruoyi.cms.util.StringUtil; | ||||||
| import com.ruoyi.common.utils.SecurityUtils; | import com.ruoyi.common.core.domain.entity.AppUser; | ||||||
|  | import com.ruoyi.common.utils.SiteSecurityUtils; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
|  |  | ||||||
| import java.text.SimpleDateFormat; |  | ||||||
| import java.util.Date; | import java.util.Date; | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  |  | ||||||
| @@ -154,14 +154,14 @@ public class AppNoticeServiceImpl implements IAppNoticeService | |||||||
|     @Override |     @Override | ||||||
|     public List<Notice> listNotRead(Integer isRead) { |     public List<Notice> listNotRead(Integer isRead) { | ||||||
|  |  | ||||||
|         Long userId = SecurityUtils.getUserId(); |         Long userId = SiteSecurityUtils.getUserId(); | ||||||
|         List<Notice> sysNoticeList = noticeInfoMapper.selectList(Wrappers.<Notice>lambdaQuery().eq(Notice::getUserId, userId).eq(Notice::getRemark,"notice_bar").orderByDesc(Notice::getCreateTime)); |         List<Notice> sysNoticeList = noticeInfoMapper.selectList(Wrappers.<Notice>lambdaQuery().eq(Notice::getUserId, userId).eq(Notice::getRemark,"notice_bar").orderByDesc(Notice::getCreateTime)); | ||||||
|         return sysNoticeList; |         return sysNoticeList; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public List<Job> recommend(String jobTitle) { |     public List<Job> recommend(String jobTitle) { | ||||||
|         return appNoticeMapper.recommend(jobTitle,SecurityUtils.getUserId()); |         return appNoticeMapper.recommend(jobTitle,SiteSecurityUtils.getUserId()); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
| @@ -172,7 +172,7 @@ public class AppNoticeServiceImpl implements IAppNoticeService | |||||||
|             notice.setIsRead(1); |             notice.setIsRead(1); | ||||||
|             noticeInfoMapper.updateById(notice); |             noticeInfoMapper.updateById(notice); | ||||||
|             }); |             }); | ||||||
|         List<Notice> notices1 = noticeInfoMapper.selectList(Wrappers.<Notice>lambdaQuery().eq(Notice::getUserId, SecurityUtils.getUserId()).eq(Notice::getRemark, "notice_bar").eq(Notice::getTitle, "系统通知").orderByDesc(Notice::getCreateTime).last("limit 1")); |         List<Notice> notices1 = noticeInfoMapper.selectList(Wrappers.<Notice>lambdaQuery().eq(Notice::getUserId, SiteSecurityUtils.getUserId()).eq(Notice::getRemark, "notice_bar").eq(Notice::getTitle, "系统通知").orderByDesc(Notice::getCreateTime).last("limit 1")); | ||||||
|         Notice notice = notices1.get(0); |         Notice notice = notices1.get(0); | ||||||
|         notice.setNotReadCount(notice.getNotReadCount() - longs.size()); |         notice.setNotReadCount(notice.getNotReadCount() - longs.size()); | ||||||
|         if(notice.getNotReadCount()==0){ |         if(notice.getNotReadCount()==0){ | ||||||
| @@ -194,7 +194,7 @@ public class AppNoticeServiceImpl implements IAppNoticeService | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public List<Notice> sysNoticeList() { |     public List<Notice> sysNoticeList() { | ||||||
|         Long userId = SecurityUtils.getUserId(); |         Long userId = SiteSecurityUtils.getUserId(); | ||||||
|         List<Notice> sysNoticeList = noticeInfoMapper.selectList(Wrappers.<Notice>lambdaQuery().eq(Notice::getUserId, userId).isNotNull(Notice::getNoticeType).notIn(Notice::getNoticeType,"").orderByDesc(Notice::getCreateTime)); |         List<Notice> sysNoticeList = noticeInfoMapper.selectList(Wrappers.<Notice>lambdaQuery().eq(Notice::getUserId, userId).isNotNull(Notice::getNoticeType).notIn(Notice::getNoticeType,"").orderByDesc(Notice::getCreateTime)); | ||||||
|         return sysNoticeList; |         return sysNoticeList; | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ import com.ruoyi.cms.domain.Job; | |||||||
| import com.ruoyi.cms.domain.query.MineJobQuery; | import com.ruoyi.cms.domain.query.MineJobQuery; | ||||||
| import com.ruoyi.cms.mapper.AppReviewJobMapper; | import com.ruoyi.cms.mapper.AppReviewJobMapper; | ||||||
| import com.ruoyi.cms.service.IAppReviewJobService; | import com.ruoyi.cms.service.IAppReviewJobService; | ||||||
| import com.ruoyi.common.utils.SecurityUtils; | import com.ruoyi.common.utils.SiteSecurityUtils; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
|  |  | ||||||
| @@ -91,13 +91,13 @@ public class AppReviewJobServiceImpl extends ServiceImpl<AppReviewJobMapper, App | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public List<Job> review(MineJobQuery jobQuery) { |     public List<Job> review(MineJobQuery jobQuery) { | ||||||
|         List<Job> jobs = appReviewJobMapper.review(SecurityUtils.getUserId(),jobQuery); |         List<Job> jobs = appReviewJobMapper.review(SiteSecurityUtils.getUserId(),jobQuery); | ||||||
|         return jobs; |         return jobs; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public List<String> reviewArray() { |     public List<String> reviewArray() { | ||||||
|         List<AppReviewJob> appReviewJobs = appReviewJobMapper.reviewArray(SecurityUtils.getUserId()); |         List<AppReviewJob> appReviewJobs = appReviewJobMapper.reviewArray(SiteSecurityUtils.getUserId()); | ||||||
|         return appReviewJobs.stream().map(x -> formatter.format(x.getReviewDate())).collect(Collectors.toList()); |         return appReviewJobs.stream().map(x -> formatter.format(x.getReviewDate())).collect(Collectors.toList()); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -0,0 +1,43 @@ | |||||||
|  | package com.ruoyi.cms.service.impl; | ||||||
|  |  | ||||||
|  | import com.ruoyi.cms.mapper.AppSkillMapper; | ||||||
|  | import com.ruoyi.cms.service.AppSkillService; | ||||||
|  | import com.ruoyi.common.core.domain.entity.AppSkill; | ||||||
|  | import org.springframework.beans.factory.annotation.Autowired; | ||||||
|  | import org.springframework.stereotype.Service; | ||||||
|  |  | ||||||
|  | import java.util.Arrays; | ||||||
|  | import java.util.List; | ||||||
|  | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @Service | ||||||
|  | public class AppSkillServiceImpl extends ServiceImpl<AppSkillMapper, AppSkill> implements AppSkillService { | ||||||
|  |  | ||||||
|  |     @Autowired | ||||||
|  |     AppSkillMapper appSkillMapper; | ||||||
|  |  | ||||||
|  |     public List<AppSkill> getList(AppSkill appSkill){ | ||||||
|  |         return appSkillMapper.getList(appSkill); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public int insertAppskill(AppSkill appSkill) { | ||||||
|  |         return appSkillMapper.insert(appSkill); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public int updateAppskillById(AppSkill appSkill) { | ||||||
|  |         return appSkillMapper.updateById(appSkill); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public int removeAppskillIds(Long[] ids) { | ||||||
|  |         return appSkillMapper.deleteBatchIds(Arrays.asList(ids)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public AppSkill getAppskillById(Long id) { | ||||||
|  |         return appSkillMapper.selectById(id); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -1,18 +1,23 @@ | |||||||
| package com.ruoyi.cms.service.impl; | package com.ruoyi.cms.service.impl; | ||||||
|  |  | ||||||
|  | import java.util.HashMap; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
|  | import java.util.Map; | ||||||
| import java.util.stream.Collectors; | import java.util.stream.Collectors; | ||||||
|  |  | ||||||
| import com.ruoyi.cms.mapper.JobTitleMapper; | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||||
|  | import com.baomidou.mybatisplus.core.toolkit.Wrappers; | ||||||
|  | import com.ruoyi.cms.mapper.*; | ||||||
| import com.ruoyi.cms.util.StringUtil; | import com.ruoyi.cms.util.StringUtil; | ||||||
| import com.ruoyi.common.core.domain.entity.JobTitle; | import com.ruoyi.common.core.domain.entity.*; | ||||||
|  | import com.ruoyi.common.core.domain.model.RegisterBody; | ||||||
|  | import com.ruoyi.common.utils.SecurityUtils; | ||||||
|  | import com.ruoyi.common.utils.SiteSecurityUtils; | ||||||
| import com.ruoyi.common.utils.StringUtils; | import com.ruoyi.common.utils.StringUtils; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| import com.ruoyi.cms.mapper.AppUserMapper; |  | ||||||
| import com.ruoyi.cms.domain.AppUser; |  | ||||||
| import com.ruoyi.cms.service.IAppUserService; | import com.ruoyi.cms.service.IAppUserService; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -28,6 +33,14 @@ public class AppUserServiceImpl extends ServiceImpl<AppUserMapper,AppUser> imple | |||||||
|     private AppUserMapper appUserMapper; |     private AppUserMapper appUserMapper; | ||||||
|     @Autowired |     @Autowired | ||||||
|     private JobTitleMapper jobTitleMapper; |     private JobTitleMapper jobTitleMapper; | ||||||
|  |     @Autowired | ||||||
|  |     private CompanyContactMapper companyContactMapper; | ||||||
|  |     @Autowired | ||||||
|  |     private UserWorkExperiencesMapper userWorkExperiencesMapper; | ||||||
|  |     @Autowired | ||||||
|  |     private AppSkillMapper appSkillMapper; | ||||||
|  |     @Autowired | ||||||
|  |     private CompanyMapper companyMapper; | ||||||
|     /** |     /** | ||||||
|      * 查询APP用户 |      * 查询APP用户 | ||||||
|      * |      * | ||||||
| @@ -44,6 +57,22 @@ public class AppUserServiceImpl extends ServiceImpl<AppUserMapper,AppUser> imple | |||||||
|             List<JobTitle> jobs = jobTitleMapper.selectBatchIds(collect); |             List<JobTitle> jobs = jobTitleMapper.selectBatchIds(collect); | ||||||
|             appUser.setJobTitle(jobs.stream().map(JobTitle::getJobName).collect(Collectors.toList())); |             appUser.setJobTitle(jobs.stream().map(JobTitle::getJobName).collect(Collectors.toList())); | ||||||
|         } |         } | ||||||
|  |         //查询企业信息 | ||||||
|  |         if("0".equals(appUser.getIsCompanyUser())){ | ||||||
|  |             Company company=companyMapper.selectOne(Wrappers.<Company>lambdaQuery().eq(Company::getCode, appUser.getIdCard()).orderByDesc(Company::getUpdateTime).last("LIMIT 1")); | ||||||
|  |             appUser.setCompany(company); | ||||||
|  |             if(company!=null){ | ||||||
|  |                 CompanyContact contact=new CompanyContact(); | ||||||
|  |                 contact.setCompanyId(company.getCompanyId()); | ||||||
|  |                 List<CompanyContact> companyContactList=companyContactMapper.getSelectList(contact); | ||||||
|  |                 company.setCompanyContactList(companyContactList); | ||||||
|  |             } | ||||||
|  |         }else if("1".equals(appUser.getIsCompanyUser())){ | ||||||
|  |             UserWorkExperiences workExperiences=new UserWorkExperiences(); | ||||||
|  |             workExperiences.setUserId(appUser.getUserId()); | ||||||
|  |             List<UserWorkExperiences> experiences =userWorkExperiencesMapper.getWorkExperiencesList(workExperiences); | ||||||
|  |             appUser.setExperiencesList(experiences); | ||||||
|  |         } | ||||||
|         return appUser; |         return appUser; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -102,4 +131,83 @@ public class AppUserServiceImpl extends ServiceImpl<AppUserMapper,AppUser> imple | |||||||
|         return appUserMapper.deleteBatchIds(Arrays.asList(userIds)); |         return appUserMapper.deleteBatchIds(Arrays.asList(userIds)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public AppUser getPhone(String phone) { | ||||||
|  |         return appUserMapper.selectOne(new LambdaQueryWrapper<AppUser>() | ||||||
|  |                 .eq(AppUser::getPhone, phone)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public AppUser selectByOpenid(String openid) { | ||||||
|  |         return appUserMapper.selectByOpenid(openid); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public AppUser registerAppUser(RegisterBody registerBody) { | ||||||
|  |         AppUser appUser=registerBody.getAppUser(); | ||||||
|  |         System.out.println("userId================"+SiteSecurityUtils.getUserId()); | ||||||
|  |         if(SiteSecurityUtils.isLogin()){ | ||||||
|  |             AppUser appUserResult=appUserMapper.selectById(SiteSecurityUtils.getUserId()); | ||||||
|  |             if(appUser==null){ | ||||||
|  |                 appUser=appUserResult; | ||||||
|  |             }else{ | ||||||
|  |                 appUser.setPhone(appUserResult.getPhone()); | ||||||
|  |                 appUser.setUserId(appUserResult.getUserId()); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         //角色集合 | ||||||
|  |         Map mapUserRole=new HashMap<>(); | ||||||
|  |         switch (appUser.getIsCompanyUser()){ | ||||||
|  |             case "0"://企业 | ||||||
|  |                 if(registerBody.getCompany()!=null){ | ||||||
|  |                     Company company=registerBody.getCompany(); | ||||||
|  |                     Long companyId=company.getCompanyId(); | ||||||
|  |                     if(companyId==null){ | ||||||
|  |                         companyMapper.insert(registerBody.getCompany()); | ||||||
|  |                         registerBody.getCompany().getCompanyContactList().forEach(it->{ | ||||||
|  |                             it.setCompanyId(registerBody.getCompany().getCompanyId()); | ||||||
|  |                         }); | ||||||
|  |                     } | ||||||
|  |                     if(registerBody.getCompany().getCompanyContactList()!=null){ | ||||||
|  |                         companyContactMapper.batchInsert(registerBody.getCompany().getCompanyContactList()); | ||||||
|  |                     } | ||||||
|  |                     //保存app_user信息 | ||||||
|  |                     appUser.setIdCard(company.getCode()); | ||||||
|  |                     appUser.setName(company.getName()); | ||||||
|  |                 } | ||||||
|  |                 mapUserRole.put("roleId",100); | ||||||
|  |                 break; | ||||||
|  |             default://求职者 | ||||||
|  |                 if(registerBody.getExperiencesList()!=null){ | ||||||
|  |                     registerBody.getExperiencesList().forEach(it->{ | ||||||
|  |                         it.setUserId(SiteSecurityUtils.getUserId()); | ||||||
|  |                     }); | ||||||
|  |                     userWorkExperiencesMapper.batchInsert(registerBody.getExperiencesList()); | ||||||
|  |                 } | ||||||
|  |                 if(registerBody.getAppSkillsList()!=null){ | ||||||
|  |                     registerBody.getAppSkillsList().forEach(it->{ | ||||||
|  |                         it.setUserId(SiteSecurityUtils.getUserId()); | ||||||
|  |                     }); | ||||||
|  |                     appSkillMapper.batchInsert(registerBody.getAppSkillsList()); | ||||||
|  |                 } | ||||||
|  |                 mapUserRole.put("roleId",1); | ||||||
|  |         } | ||||||
|  |         //保存sys_user | ||||||
|  |         SysUser sysUser=new SysUser(); | ||||||
|  |         sysUser.setUserName(appUser.getPhone()); | ||||||
|  |         sysUser.setNickName(StringUtils.isEmpty(appUser.getName())?appUser.getPhone():appUser.getName()); | ||||||
|  |         sysUser.setPassword(SecurityUtils.encryptPassword("123456")); | ||||||
|  |         sysUser.setPhonenumber(appUser.getPhone()); | ||||||
|  |         sysUser.setSex(appUser.getSex()); | ||||||
|  |         sysUser.setStatus("0"); | ||||||
|  |         sysUser.setLoginIp(appUser.getLoginIp()); | ||||||
|  |         sysUser.setLoginDate(appUser.getLoginDate()); | ||||||
|  |         sysUser.setIdCard(appUser.getIdCard()); | ||||||
|  |         appUserMapper.insertSysUser(sysUser); | ||||||
|  |         //保存sys_user_role | ||||||
|  |         mapUserRole.put("userId",appUser.getUserId()); | ||||||
|  |         appUserMapper.insertSysUserRole(mapUserRole); | ||||||
|  |         appUserMapper.updateById(appUser); | ||||||
|  |         return appUser; | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ import com.ruoyi.cms.domain.CompanyCardCollection; | |||||||
| import com.ruoyi.cms.domain.vo.CompanyCardVO; | import com.ruoyi.cms.domain.vo.CompanyCardVO; | ||||||
| import com.ruoyi.cms.mapper.CompanyCardCollectionMapper; | import com.ruoyi.cms.mapper.CompanyCardCollectionMapper; | ||||||
| import com.ruoyi.common.utils.DateUtils; | import com.ruoyi.common.utils.DateUtils; | ||||||
| import com.ruoyi.common.utils.SecurityUtils; | import com.ruoyi.common.utils.SiteSecurityUtils; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| @@ -100,9 +100,9 @@ public class CompanyCardServiceImpl extends ServiceImpl<CompanyCardMapper,Compan | |||||||
|         CompanyCard companyCard = new CompanyCard(); |         CompanyCard companyCard = new CompanyCard(); | ||||||
|         companyCard.setStatus(1); |         companyCard.setStatus(1); | ||||||
|         List<CompanyCardVO> companyCards = companyCardMapper.selectCompanyCardListVO(companyCard); |         List<CompanyCardVO> companyCards = companyCardMapper.selectCompanyCardListVO(companyCard); | ||||||
|         if(SecurityUtils.isLogin()){ |         if(SiteSecurityUtils.isLogin()){ | ||||||
|             CompanyCardCollection companyCardCollection = new CompanyCardCollection(); |             CompanyCardCollection companyCardCollection = new CompanyCardCollection(); | ||||||
|             companyCardCollection.setUserId(SecurityUtils.getUserId()); |             companyCardCollection.setUserId(SiteSecurityUtils.getUserId()); | ||||||
|             List<CompanyCardCollection> companyCardCollections = companyCardCollectionMapper.selectCompanyCardCollectionList(companyCardCollection); |             List<CompanyCardCollection> companyCardCollections = companyCardCollectionMapper.selectCompanyCardCollectionList(companyCardCollection); | ||||||
|             for (CompanyCardVO item:companyCards){ |             for (CompanyCardVO item:companyCards){ | ||||||
|                 for(CompanyCardCollection collection:companyCardCollections){ |                 for(CompanyCardCollection collection:companyCardCollections){ | ||||||
| @@ -119,7 +119,7 @@ public class CompanyCardServiceImpl extends ServiceImpl<CompanyCardMapper,Compan | |||||||
|     public void cardCollection(Long companyCardId) { |     public void cardCollection(Long companyCardId) { | ||||||
|         CompanyCardCollection companyCardCollection = new CompanyCardCollection(); |         CompanyCardCollection companyCardCollection = new CompanyCardCollection(); | ||||||
|         companyCardCollection.setCompanyCardId(companyCardId); |         companyCardCollection.setCompanyCardId(companyCardId); | ||||||
|         companyCardCollection.setUserId(SecurityUtils.getUserId()); |         companyCardCollection.setUserId(SiteSecurityUtils.getUserId()); | ||||||
|         companyCardCollectionService.save(companyCardCollection); |         companyCardCollectionService.save(companyCardCollection); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -127,8 +127,8 @@ public class CompanyCardServiceImpl extends ServiceImpl<CompanyCardMapper,Compan | |||||||
|     public void cardCancel(Long companyCardId) { |     public void cardCancel(Long companyCardId) { | ||||||
|         CompanyCardCollection companyCardCollection = new CompanyCardCollection(); |         CompanyCardCollection companyCardCollection = new CompanyCardCollection(); | ||||||
|         companyCardCollection.setCompanyCardId(companyCardId); |         companyCardCollection.setCompanyCardId(companyCardId); | ||||||
|         companyCardCollection.setUserId(SecurityUtils.getUserId()); |         companyCardCollection.setUserId(SiteSecurityUtils.getUserId()); | ||||||
|         List<CompanyCardCollection> companyCardCollections = companyCardCollectionMapper.selectList(Wrappers.<CompanyCardCollection>lambdaQuery().eq(CompanyCardCollection::getCompanyCardId, companyCardId).eq(CompanyCardCollection::getUserId, SecurityUtils.getUserId())); |         List<CompanyCardCollection> companyCardCollections = companyCardCollectionMapper.selectList(Wrappers.<CompanyCardCollection>lambdaQuery().eq(CompanyCardCollection::getCompanyCardId, companyCardId).eq(CompanyCardCollection::getUserId, SiteSecurityUtils.getUserId())); | ||||||
|         companyCardCollectionMapper.deleteBatchIds(companyCardCollections.stream().map(CompanyCardCollection::getCompanyCardCollectionId).collect(Collectors.toList())); |         companyCardCollectionMapper.deleteBatchIds(companyCardCollections.stream().map(CompanyCardCollection::getCompanyCardCollectionId).collect(Collectors.toList())); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -5,10 +5,10 @@ import java.util.Arrays; | |||||||
| import java.util.stream.Collectors; | import java.util.stream.Collectors; | ||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.core.toolkit.Wrappers; | import com.baomidou.mybatisplus.core.toolkit.Wrappers; | ||||||
| import com.ruoyi.cms.domain.Company; | import com.ruoyi.common.core.domain.entity.Company; | ||||||
| import com.ruoyi.cms.domain.Job; | import com.ruoyi.cms.domain.Job; | ||||||
| import com.ruoyi.cms.mapper.JobMapper; | import com.ruoyi.cms.mapper.JobMapper; | ||||||
| import com.ruoyi.common.utils.SecurityUtils; | import com.ruoyi.common.utils.SiteSecurityUtils; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| @@ -93,7 +93,7 @@ public class CompanyCollectionServiceImpl extends ServiceImpl<CompanyCollectionM | |||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public int companyCancel(Long companyId) { |     public int companyCancel(Long companyId) { | ||||||
|         List<CompanyCollection> companyCollections = companyCollectionMapper.selectList(Wrappers.<CompanyCollection>lambdaQuery().eq(CompanyCollection::getCompanyId, companyId).eq(CompanyCollection::getUserId, SecurityUtils.getUserId())); |         List<CompanyCollection> companyCollections = companyCollectionMapper.selectList(Wrappers.<CompanyCollection>lambdaQuery().eq(CompanyCollection::getCompanyId, companyId).eq(CompanyCollection::getUserId, SiteSecurityUtils.getUserId())); | ||||||
|         if(companyCollections.size()>0){ |         if(companyCollections.size()>0){ | ||||||
|             companyCollectionMapper.deleteBatchIds(companyCollections.stream().map(CompanyCollection::getId).collect(Collectors.toList())); |             companyCollectionMapper.deleteBatchIds(companyCollections.stream().map(CompanyCollection::getId).collect(Collectors.toList())); | ||||||
|         } |         } | ||||||
| @@ -104,7 +104,7 @@ public class CompanyCollectionServiceImpl extends ServiceImpl<CompanyCollectionM | |||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public int companyCollection(Long companyId) { |     public int companyCollection(Long companyId) { | ||||||
|         Long userId = SecurityUtils.getUserId(); |         Long userId = SiteSecurityUtils.getUserId(); | ||||||
|         List<CompanyCollection> companyCollections = companyCollectionMapper.selectList(Wrappers.<CompanyCollection>lambdaQuery().eq(CompanyCollection::getCompanyId, companyId).eq(CompanyCollection::getUserId, userId)); |         List<CompanyCollection> companyCollections = companyCollectionMapper.selectList(Wrappers.<CompanyCollection>lambdaQuery().eq(CompanyCollection::getCompanyId, companyId).eq(CompanyCollection::getUserId, userId)); | ||||||
|         if(companyCollections.size()>0){ |         if(companyCollections.size()>0){ | ||||||
|             companyCollectionMapper.deleteBatchIds(companyCollections.stream().map(CompanyCollection::getId).collect(Collectors.toList())); |             companyCollectionMapper.deleteBatchIds(companyCollections.stream().map(CompanyCollection::getId).collect(Collectors.toList())); | ||||||
| @@ -118,7 +118,7 @@ public class CompanyCollectionServiceImpl extends ServiceImpl<CompanyCollectionM | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public List<Company> collectionCompany() { |     public List<Company> collectionCompany() { | ||||||
|         List<Company> companies = companyCollectionMapper.collectionJob(SecurityUtils.getUserId()); |         List<Company> companies = companyCollectionMapper.collectionJob(SiteSecurityUtils.getUserId()); | ||||||
|         return companies; |         return companies; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,13 +1,17 @@ | |||||||
| package com.ruoyi.cms.service.impl; | package com.ruoyi.cms.service.impl; | ||||||
|  |  | ||||||
| import com.ruoyi.cms.domain.CompanyContact; | import com.ruoyi.common.core.domain.entity.CompanyContact; | ||||||
| import com.ruoyi.cms.mapper.CompanyContactMapper; | import com.ruoyi.cms.mapper.CompanyContactMapper; | ||||||
| import com.ruoyi.cms.service.CompanyContactService; | import com.ruoyi.cms.service.CompanyContactService; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| import java.util.List; |  | ||||||
| import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; |  | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  | import java.util.Map; | ||||||
|  | import java.util.stream.Collectors; | ||||||
|  |  | ||||||
|  | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | ||||||
|  | import org.springframework.transaction.annotation.Transactional; | ||||||
|  |  | ||||||
|  |  | ||||||
| @Service | @Service | ||||||
| @@ -19,4 +23,20 @@ public class CompanyContactServiceImpl extends ServiceImpl<CompanyContactMapper, | |||||||
|     public List<CompanyContact> getSelectList(CompanyContact companyContact){ |     public List<CompanyContact> getSelectList(CompanyContact companyContact){ | ||||||
|         return companyContactMapper.getSelectList(companyContact); |         return companyContactMapper.getSelectList(companyContact); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     @Transactional | ||||||
|  |     public int insertUpadteCompanyContact(List<CompanyContact> list) { | ||||||
|  |         Map<Boolean, List<CompanyContact>> partitioned = list.stream() | ||||||
|  |                 .collect(Collectors.partitioningBy(it -> it.getId() != null)); | ||||||
|  |         List<CompanyContact> add=partitioned.get(false); | ||||||
|  |         List<CompanyContact> udp=partitioned.get(true); | ||||||
|  |         if(add.size()>0){ | ||||||
|  |             companyContactMapper.batchInsert(add); | ||||||
|  |         } | ||||||
|  |         if(udp.size()>0){ | ||||||
|  |             companyContactMapper.batchUpdate(udp); | ||||||
|  |         } | ||||||
|  |         return 0; | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -10,8 +10,14 @@ import com.ruoyi.cms.domain.*; | |||||||
| import com.ruoyi.cms.domain.query.LabelQuery; | import com.ruoyi.cms.domain.query.LabelQuery; | ||||||
| import com.ruoyi.cms.mapper.*; | import com.ruoyi.cms.mapper.*; | ||||||
| import com.ruoyi.common.constant.Constants; | import com.ruoyi.common.constant.Constants; | ||||||
|  | import com.ruoyi.common.core.domain.entity.Company; | ||||||
|  | import com.ruoyi.common.core.domain.entity.CompanyContact; | ||||||
|  | import com.ruoyi.common.core.domain.model.LoginSiteUser; | ||||||
|  | import com.ruoyi.common.core.domain.model.LoginUser; | ||||||
| import com.ruoyi.common.exception.ServiceException; | import com.ruoyi.common.exception.ServiceException; | ||||||
| import com.ruoyi.common.utils.SecurityUtils; | import com.ruoyi.common.utils.SecurityUtils; | ||||||
|  | import com.ruoyi.common.utils.SiteSecurityUtils; | ||||||
|  | import com.ruoyi.common.utils.bean.BeanUtils; | ||||||
| import org.apache.poi.ss.usermodel.Cell; | import org.apache.poi.ss.usermodel.Cell; | ||||||
| import org.apache.poi.ss.usermodel.Row; | import org.apache.poi.ss.usermodel.Row; | ||||||
| import org.apache.poi.ss.usermodel.Sheet; | import org.apache.poi.ss.usermodel.Sheet; | ||||||
| @@ -29,7 +35,7 @@ import com.ruoyi.cms.service.ICompanyService; | |||||||
|  * @date 2024-09-04 |  * @date 2024-09-04 | ||||||
|  */ |  */ | ||||||
| @Service | @Service | ||||||
| public class CompanyServiceImpl extends ServiceImpl<CompanyMapper,Company> implements ICompanyService | public class CompanyServiceImpl extends ServiceImpl<CompanyMapper, Company> implements ICompanyService | ||||||
| { | { | ||||||
|     @Autowired |     @Autowired | ||||||
|     private CompanyMapper companyMapper; |     private CompanyMapper companyMapper; | ||||||
| @@ -53,11 +59,23 @@ public class CompanyServiceImpl extends ServiceImpl<CompanyMapper,Company> imple | |||||||
|     public Company selectCompanyByCompanyId(Long companyId) |     public Company selectCompanyByCompanyId(Long companyId) | ||||||
|     { |     { | ||||||
|         Company company = companyMapper.selectById(companyId); |         Company company = companyMapper.selectById(companyId); | ||||||
|         if(SecurityUtils.isLogin()){ |         Long userId=null; | ||||||
|             Long l = companyCollectionMapper.selectCount(Wrappers.<CompanyCollection>lambdaQuery().eq(CompanyCollection::getCompanyId, companyId).eq(CompanyCollection::getUserId, SecurityUtils.getUserId())); |         try { | ||||||
|             company.setIsCollection(l>0?1:0); |             LoginUser loginUser = SecurityUtils.getLoginUser(); | ||||||
|         }else { |             userId = loginUser.getUserId(); | ||||||
|             company.setIsCollection(0); |         }catch (Exception ignored){ | ||||||
|  |             LoginSiteUser siteUser = SiteSecurityUtils.getLoginSiteUser(); | ||||||
|  |             userId = siteUser.getUserId(); | ||||||
|  |         } | ||||||
|  |         //收藏 | ||||||
|  |         Long l = companyCollectionMapper.selectCount(Wrappers.<CompanyCollection>lambdaQuery().eq(CompanyCollection::getCompanyId, companyId).eq(CompanyCollection::getUserId, userId)); | ||||||
|  |         company.setIsCollection(l>0?1:0); | ||||||
|  |         //联系人 | ||||||
|  |         CompanyContact contact=new CompanyContact(); | ||||||
|  |         contact.setCompanyId(company.getCompanyId()); | ||||||
|  |         List<CompanyContact> contacts=companyContactMapper.getSelectList(contact); | ||||||
|  |         if(contacts!=null){ | ||||||
|  |             company.setCompanyContactList(contacts); | ||||||
|         } |         } | ||||||
|         return company; |         return company; | ||||||
|     } |     } | ||||||
| @@ -91,6 +109,7 @@ public class CompanyServiceImpl extends ServiceImpl<CompanyMapper,Company> imple | |||||||
|         if(insert>0){ |         if(insert>0){ | ||||||
|             company.getCompanyContactList().forEach(x->{ |             company.getCompanyContactList().forEach(x->{ | ||||||
|                 CompanyContact companyContact=new CompanyContact(); |                 CompanyContact companyContact=new CompanyContact(); | ||||||
|  |                 BeanUtils.copyProperties(x,companyContact); | ||||||
|                 companyContact.setCompanyId(company.getCompanyId()); |                 companyContact.setCompanyId(company.getCompanyId()); | ||||||
|                 companyContactMapper.insert(companyContact); |                 companyContactMapper.insert(companyContact); | ||||||
|             }); |             }); | ||||||
| @@ -241,7 +260,7 @@ public class CompanyServiceImpl extends ServiceImpl<CompanyMapper,Company> imple | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void register(Company company) { |     public void register(Company company) { | ||||||
|         Long userId = SecurityUtils.getUserId(); |         Long userId = SiteSecurityUtils.getUserId(); | ||||||
|         company.setUserId(userId); |         company.setUserId(userId); | ||||||
|         if(companyMapper.selectCount(Wrappers.<Company>lambdaQuery().eq(Company::getName, company.getName()).in(Company::getStatus,Arrays.asList(0,1)))>0){ |         if(companyMapper.selectCount(Wrappers.<Company>lambdaQuery().eq(Company::getName, company.getName()).in(Company::getStatus,Arrays.asList(0,1)))>0){ | ||||||
|             throw new ServiceException(company.getName()+"已经存在"); |             throw new ServiceException(company.getName()+"已经存在"); | ||||||
| @@ -251,7 +270,7 @@ public class CompanyServiceImpl extends ServiceImpl<CompanyMapper,Company> imple | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public Company registerStatus() { |     public Company registerStatus() { | ||||||
|         Long userId = SecurityUtils.getUserId(); |         Long userId = SiteSecurityUtils.getUserId(); | ||||||
|         Company company = companyMapper.selectOne(Wrappers.<Company>lambdaQuery().eq(Company::getUserId, userId).orderByDesc(Company::getUpdateTime)); |         Company company = companyMapper.selectOne(Wrappers.<Company>lambdaQuery().eq(Company::getUserId, userId).orderByDesc(Company::getUpdateTime)); | ||||||
|         return company; |         return company; | ||||||
|     } |     } | ||||||
| @@ -267,12 +286,29 @@ public class CompanyServiceImpl extends ServiceImpl<CompanyMapper,Company> imple | |||||||
|         if(company1==null){ |         if(company1==null){ | ||||||
|             throw new ServiceException("企业不存在"); |             throw new ServiceException("企业不存在"); | ||||||
|         } |         } | ||||||
|         if(company1.getStatus()!=0){ |         if(company1.getStatus()!=null){ | ||||||
|             throw new ServiceException("企业已审核"); |             if(company1.getStatus()!=0){ | ||||||
|  |                 throw new ServiceException("企业已审核"); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|         companyMapper.updateById(company); |         companyMapper.updateById(company); | ||||||
|         //创建账号 |         //创建账号 | ||||||
|         return company1; |         return company1; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public Company queryCodeCompany(String code) { | ||||||
|  |         Company companyResult = companyMapper.selectOne(Wrappers.<Company>lambdaQuery().eq(Company::getCode, code).orderByDesc(Company::getUpdateTime).last("LIMIT 1")); | ||||||
|  |         if(companyResult!=null){ | ||||||
|  |             CompanyContact contact=new CompanyContact(); | ||||||
|  |             contact.setCompanyId(companyResult.getCompanyId()); | ||||||
|  |             List<CompanyContact> contacts=companyContactMapper.getSelectList(contact); | ||||||
|  |         } | ||||||
|  |         return companyResult; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public List<Company> selectLikeCompanyList(Company company) { | ||||||
|  |         return companyMapper.selectLikeCompanyList(company); | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,18 +1,19 @@ | |||||||
| package com.ruoyi.cms.service.impl; | package com.ruoyi.cms.service.impl; | ||||||
|  |  | ||||||
| import com.ruoyi.cms.domain.AppUser; | import com.ruoyi.cms.service.ICompanyService; | ||||||
|  | import com.ruoyi.common.core.domain.entity.AppUser; | ||||||
| import com.ruoyi.cms.domain.ESJobDocument; | import com.ruoyi.cms.domain.ESJobDocument; | ||||||
| import com.ruoyi.cms.domain.Job; | import com.ruoyi.cms.domain.Job; | ||||||
| import com.ruoyi.cms.domain.query.ESJobSearch; | import com.ruoyi.cms.domain.query.ESJobSearch; | ||||||
| import com.ruoyi.cms.mapper.es.EsJobDocumentMapper; | import com.ruoyi.cms.mapper.es.EsJobDocumentMapper; | ||||||
| import com.ruoyi.cms.mapper.JobMapper; | import com.ruoyi.cms.mapper.JobMapper; | ||||||
| import com.ruoyi.cms.service.IESJobSearchService; | import com.ruoyi.cms.service.IESJobSearchService; | ||||||
| import com.ruoyi.cms.util.Base64Util; |  | ||||||
| import com.ruoyi.cms.util.ListUtil; | import com.ruoyi.cms.util.ListUtil; | ||||||
| import com.ruoyi.cms.util.StringUtil; | import com.ruoyi.cms.util.StringUtil; | ||||||
|  | import com.ruoyi.common.core.domain.entity.Company; | ||||||
|  | import com.ruoyi.common.core.domain.model.LoginSiteUser; | ||||||
| import com.ruoyi.common.core.text.Convert; | import com.ruoyi.common.core.text.Convert; | ||||||
| import com.ruoyi.common.utils.SecurityUtils; | import com.ruoyi.common.utils.SiteSecurityUtils; | ||||||
| import com.ruoyi.common.utils.StringUtils; |  | ||||||
| import com.ruoyi.common.utils.bean.BeanUtils; | import com.ruoyi.common.utils.bean.BeanUtils; | ||||||
| import org.dromara.easyes.core.biz.EsPageInfo; | import org.dromara.easyes.core.biz.EsPageInfo; | ||||||
| import org.dromara.easyes.core.conditions.select.LambdaEsQueryWrapper; | import org.dromara.easyes.core.conditions.select.LambdaEsQueryWrapper; | ||||||
| @@ -44,6 +45,8 @@ public class ESJobSearchImpl implements IESJobSearchService | |||||||
|  |  | ||||||
|     @Autowired |     @Autowired | ||||||
|     private AppUserServiceImpl appUserService; |     private AppUserServiceImpl appUserService; | ||||||
|  |     @Autowired | ||||||
|  |     private ICompanyService iCompanyService; | ||||||
|  |  | ||||||
|     @Autowired |     @Autowired | ||||||
|     private BussinessDictDataServiceImpl bussinessDictDataServicel; |     private BussinessDictDataServiceImpl bussinessDictDataServicel; | ||||||
| @@ -140,8 +143,8 @@ public class ESJobSearchImpl implements IESJobSearchService | |||||||
|         ESJobSearch newSearch = new ESJobSearch(); |         ESJobSearch newSearch = new ESJobSearch(); | ||||||
|         BeanUtils.copyProperties(esJobSearch,newSearch); |         BeanUtils.copyProperties(esJobSearch,newSearch); | ||||||
|         //查询 |         //查询 | ||||||
|         if(SecurityUtils.isLogin()){ |         if(SiteSecurityUtils.isLogin()){ | ||||||
|             AppUser appUser = appUserService.selectAppUserByUserId(SecurityUtils.getUserId()); |             AppUser appUser = appUserService.selectAppUserByUserId(SiteSecurityUtils.getUserId()); | ||||||
|             if(!ListUtil.isEmptyOrNull(appUser.getJobTitle())){ |             if(!ListUtil.isEmptyOrNull(appUser.getJobTitle())){ | ||||||
|                 List<String> jobTitle = appUser.getJobTitle(); |                 List<String> jobTitle = appUser.getJobTitle(); | ||||||
|                 newSearch.setJobTitle(String.join(",", jobTitle)); |                 newSearch.setJobTitle(String.join(",", jobTitle)); | ||||||
| @@ -174,6 +177,21 @@ public class ESJobSearchImpl implements IESJobSearchService | |||||||
|             if(!StringUtil.isEmptyOrNull(appUser.getSalaryMin())){ |             if(!StringUtil.isEmptyOrNull(appUser.getSalaryMin())){ | ||||||
|                 newSearch.setMinSalary(Long.valueOf(appUser.getSalaryMin())); |                 newSearch.setMinSalary(Long.valueOf(appUser.getSalaryMin())); | ||||||
|             } |             } | ||||||
|  |             if(!StringUtil.isEmptyOrNull(esJobSearch.getJobType())){ | ||||||
|  |                 newSearch.setJobType(esJobSearch.getJobType()); | ||||||
|  |             } | ||||||
|  |             if(!StringUtil.isEmptyOrNull(esJobSearch.getType())){ | ||||||
|  |                 newSearch.setType(esJobSearch.getType()); | ||||||
|  |             } | ||||||
|  |             if(!StringUtil.isEmptyOrNull(esJobSearch.getDescription())){ | ||||||
|  |                 newSearch.setDescription(esJobSearch.getDescription()); | ||||||
|  |             } | ||||||
|  |             if(!StringUtil.isEmptyOrNull(esJobSearch.getCompanyNature())){ | ||||||
|  |                 newSearch.setCompanyNature(esJobSearch.getCompanyNature()); | ||||||
|  |             } | ||||||
|  |             if(!StringUtil.isEmptyOrNull(esJobSearch.getCode())){ | ||||||
|  |                 newSearch.setCode(esJobSearch.getCode()); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         LambdaEsQueryWrapper<ESJobDocument> wrapper = getWrapper(newSearch,jobIds); |         LambdaEsQueryWrapper<ESJobDocument> wrapper = getWrapper(newSearch,jobIds); | ||||||
| @@ -395,6 +413,21 @@ public class ESJobSearchImpl implements IESJobSearchService | |||||||
|             List<Integer> integers = StringUtil.convertStringToIntegerList(esJobSearch.getArea()); |             List<Integer> integers = StringUtil.convertStringToIntegerList(esJobSearch.getArea()); | ||||||
|             wrapper.and(x->x.in(ESJobDocument::getJobLocationAreaCode,integers)); |             wrapper.and(x->x.in(ESJobDocument::getJobLocationAreaCode,integers)); | ||||||
|         } |         } | ||||||
|  |         if(!StringUtil.isEmptyOrNull(esJobSearch.getJobType())){ | ||||||
|  |             wrapper.and(x->x.eq(ESJobDocument::getJobType,esJobSearch.getJobType())); | ||||||
|  |         } | ||||||
|  |         if(!StringUtil.isEmptyOrNull(esJobSearch.getType())){ | ||||||
|  |             wrapper.and(x->x.eq(ESJobDocument::getType,esJobSearch.getType())); | ||||||
|  |         } | ||||||
|  |         if(!StringUtil.isEmptyOrNull(esJobSearch.getDescription())){ | ||||||
|  |             wrapper.and(x->x.like(ESJobDocument::getDescription,esJobSearch.getDescription())); | ||||||
|  |         } | ||||||
|  |         if(!StringUtil.isEmptyOrNull(esJobSearch.getCompanyNature())){ | ||||||
|  |             wrapper.and(x->x.eq(ESJobDocument::getCompanyNature,esJobSearch.getCompanyNature())); | ||||||
|  |         } | ||||||
|  |         if(!StringUtil.isEmptyOrNull(esJobSearch.getCode())){ | ||||||
|  |             wrapper.and(x->x.eq(ESJobDocument::getCode,esJobSearch.getCode())); | ||||||
|  |         } | ||||||
|         if(Objects.nonNull(esJobSearch.getOrder())){ |         if(Objects.nonNull(esJobSearch.getOrder())){ | ||||||
|             if(esJobSearch.getOrder()==1){ |             if(esJobSearch.getOrder()==1){ | ||||||
|                 wrapper.orderByDesc(ESJobDocument::getIsHot); |                 wrapper.orderByDesc(ESJobDocument::getIsHot); | ||||||
| @@ -402,8 +435,18 @@ public class ESJobSearchImpl implements IESJobSearchService | |||||||
|             if(esJobSearch.getOrder()==2){ |             if(esJobSearch.getOrder()==2){ | ||||||
|                 wrapper.orderByDesc(ESJobDocument::getPostingDate); |                 wrapper.orderByDesc(ESJobDocument::getPostingDate); | ||||||
|             } |             } | ||||||
|  |             if(esJobSearch.getOrder()==3){ | ||||||
|  |                 wrapper.orderByDesc(ESJobDocument::getMaxSalary); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|         if(!ListUtil.isListEmptyOrNull(jobIds)){ |         //企业用户排除es去除jobIds | ||||||
|  |         boolean needExclude = true; | ||||||
|  |         if (SiteSecurityUtils.isLogin()) { | ||||||
|  |             LoginSiteUser siteUser = SiteSecurityUtils.getLoginSiteUser(); | ||||||
|  |             AppUser appUser = siteUser.getUser(); | ||||||
|  |             needExclude = !StringUtil.IS_COMPANY_USER.equals(appUser.getIsCompanyUser()); | ||||||
|  |         } | ||||||
|  |         if(needExclude && !ListUtil.isListEmptyOrNull(jobIds)){ | ||||||
|             wrapper.not().in(ESJobDocument::getJobId, jobIds); |             wrapper.not().in(ESJobDocument::getJobId, jobIds); | ||||||
|         } |         } | ||||||
|         return wrapper; |         return wrapper; | ||||||
| @@ -415,8 +458,8 @@ public class ESJobSearchImpl implements IESJobSearchService | |||||||
|         Integer pageNum = jobQuery.getCurrent(); |         Integer pageNum = jobQuery.getCurrent(); | ||||||
|         Integer pageSize = jobQuery.getPageSize(); |         Integer pageSize = jobQuery.getPageSize(); | ||||||
|         LambdaEsQueryWrapper<ESJobDocument> wrapper = new LambdaEsQueryWrapper<>(); |         LambdaEsQueryWrapper<ESJobDocument> wrapper = new LambdaEsQueryWrapper<>(); | ||||||
| //        if(SecurityUtils.isLogin()){ | //        if(SiteSecurityUtils.isLogin()){ | ||||||
| //            AppUser appUser = appUserService.selectAppUserByUserId(SecurityUtils.getUserId()); | //            AppUser appUser = appUserService.selectAppUserByUserId(SiteSecurityUtils.getUserId()); | ||||||
| //            if(!ListUtil.isEmptyOrNull(appUser.getJobTitle())){ | //            if(!ListUtil.isEmptyOrNull(appUser.getJobTitle())){ | ||||||
| //                List<String> jobTitle = appUser.getJobTitle(); | //                List<String> jobTitle = appUser.getJobTitle(); | ||||||
| //                jobQuery.setJobTitle(String.join(",", jobTitle)); | //                jobQuery.setJobTitle(String.join(",", jobTitle)); | ||||||
| @@ -509,6 +552,12 @@ public class ESJobSearchImpl implements IESJobSearchService | |||||||
|     public void updateJob(Long jobId) { |     public void updateJob(Long jobId) { | ||||||
|         ESJobDocument esJobDocument = new ESJobDocument(); |         ESJobDocument esJobDocument = new ESJobDocument(); | ||||||
|         Job job = jobMapper.selectById(jobId); |         Job job = jobMapper.selectById(jobId); | ||||||
|  |         if(job!=null){ | ||||||
|  |             if(job.getCompanyId()!=null){ | ||||||
|  |                 Company company=iCompanyService.selectCompanyByCompanyId(job.getCompanyId()); | ||||||
|  |                 job.setCode(company.getCode()); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|         BeanUtils.copyBeanProp(esJobDocument, job); |         BeanUtils.copyBeanProp(esJobDocument, job); | ||||||
|         esJobDocument.setAppJobUrl("https://ks.zhaopinzao8dian.com/app#/packageA/pages/post/post?jobId="+ Base64.getEncoder().encodeToString(String.valueOf(job.getJobId()).getBytes())); |         esJobDocument.setAppJobUrl("https://ks.zhaopinzao8dian.com/app#/packageA/pages/post/post?jobId="+ Base64.getEncoder().encodeToString(String.valueOf(job.getJobId()).getBytes())); | ||||||
| @@ -540,4 +589,10 @@ public class ESJobSearchImpl implements IESJobSearchService | |||||||
|         esJobDocumentMapper.delete(lambdaEsQueryWrapper); |         esJobDocumentMapper.delete(lambdaEsQueryWrapper); | ||||||
|         esJobDocumentMapper.insert(esJobDocument); |         esJobDocumentMapper.insert(esJobDocument); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public List<ESJobDocument> selectByIds(Long[] jobIds) { | ||||||
|  |         LambdaEsQueryWrapper<ESJobDocument> wrapper = new LambdaEsQueryWrapper<>(); | ||||||
|  |         wrapper.in(ESJobDocument::getJobId,jobIds); | ||||||
|  |         return esJobDocumentMapper.selectList(wrapper); | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,49 @@ | |||||||
|  | package com.ruoyi.cms.service.impl; | ||||||
|  |  | ||||||
|  | import com.ruoyi.cms.domain.EmployeeConfirm; | ||||||
|  | import com.ruoyi.cms.domain.JobApply; | ||||||
|  | import com.ruoyi.cms.mapper.EmployeeConfirmMapper; | ||||||
|  | import com.ruoyi.cms.mapper.JobApplyMapper; | ||||||
|  | import com.ruoyi.cms.service.EmployeeConfirmService; | ||||||
|  | import org.springframework.beans.factory.annotation.Autowired; | ||||||
|  | import org.springframework.stereotype.Service; | ||||||
|  |  | ||||||
|  | import java.util.Arrays; | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @Service | ||||||
|  | public class EmployeeConfirmServiceImpl implements EmployeeConfirmService { | ||||||
|  |  | ||||||
|  |     @Autowired | ||||||
|  |     EmployeeConfirmMapper employeeConfirmMapper; | ||||||
|  |     @Autowired | ||||||
|  |     private JobApplyMapper jobApplyMapper; | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public List<EmployeeConfirm> getEmployeeConfirmList(EmployeeConfirm employeeConfirm) { | ||||||
|  |         return employeeConfirmMapper.getEmployeeConfirmList(employeeConfirm); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public int insertEmployeeConfirm(EmployeeConfirm employeeConfirm) { | ||||||
|  |         int t=employeeConfirmMapper.insert(employeeConfirm); | ||||||
|  |         if(t>0){ | ||||||
|  |             JobApply apply=new JobApply(); | ||||||
|  |             apply.setId(employeeConfirm.getApplyId()); | ||||||
|  |             apply.setHire("0"); | ||||||
|  |             jobApplyMapper.updateById(apply); | ||||||
|  |         } | ||||||
|  |         return t; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public int updateEmployeeConfirm(EmployeeConfirm employeeConfirm) { | ||||||
|  |         return employeeConfirmMapper.updateById(employeeConfirm); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public int deleteEmployeeConfirmIds(Long[] ids) { | ||||||
|  |         return employeeConfirmMapper.deleteBatchIds(Arrays.asList(ids)); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -2,13 +2,12 @@ package com.ruoyi.cms.service.impl; | |||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.core.toolkit.Wrappers; | import com.baomidou.mybatisplus.core.toolkit.Wrappers; | ||||||
| import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | ||||||
| import com.ruoyi.cms.domain.Company; |  | ||||||
| import com.ruoyi.cms.domain.FairCollection; | import com.ruoyi.cms.domain.FairCollection; | ||||||
| import com.ruoyi.cms.domain.JobFair; | import com.ruoyi.cms.domain.JobFair; | ||||||
| import com.ruoyi.cms.mapper.FairCollectionMapper; | import com.ruoyi.cms.mapper.FairCollectionMapper; | ||||||
| import com.ruoyi.cms.mapper.JobFairMapper; | import com.ruoyi.cms.mapper.JobFairMapper; | ||||||
| import com.ruoyi.cms.service.IFairCollectionService; | import com.ruoyi.cms.service.IFairCollectionService; | ||||||
| import com.ruoyi.common.utils.SecurityUtils; | import com.ruoyi.common.utils.SiteSecurityUtils; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| import org.springframework.transaction.annotation.Transactional; | import org.springframework.transaction.annotation.Transactional; | ||||||
| @@ -50,7 +49,7 @@ public class FairCollectionServiceImpl extends ServiceImpl<FairCollectionMapper, | |||||||
|     @Override |     @Override | ||||||
|     public List<FairCollection> selectFairCollectionList(FairCollection fairCollection) |     public List<FairCollection> selectFairCollectionList(FairCollection fairCollection) | ||||||
|     { |     { | ||||||
|         List<FairCollection> fairCollections = fairCollectionMapper.selectList(Wrappers.<FairCollection>lambdaQuery().eq(FairCollection::getUserId, SecurityUtils.getUserId())); |         List<FairCollection> fairCollections = fairCollectionMapper.selectList(Wrappers.<FairCollection>lambdaQuery().eq(FairCollection::getUserId, SiteSecurityUtils.getUserId())); | ||||||
|         return fairCollections; |         return fairCollections; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -95,7 +94,7 @@ public class FairCollectionServiceImpl extends ServiceImpl<FairCollectionMapper, | |||||||
|     @Override |     @Override | ||||||
|     @Transactional |     @Transactional | ||||||
|     public int fairCollection(Long fairId) { |     public int fairCollection(Long fairId) { | ||||||
|         Long userId = SecurityUtils.getUserId(); |         Long userId = SiteSecurityUtils.getUserId(); | ||||||
|         List<FairCollection> fairCollections = fairCollectionMapper.selectList(Wrappers.<FairCollection>lambdaQuery().eq(FairCollection::getFairId, fairId).eq(FairCollection::getUserId, userId)); |         List<FairCollection> fairCollections = fairCollectionMapper.selectList(Wrappers.<FairCollection>lambdaQuery().eq(FairCollection::getFairId, fairId).eq(FairCollection::getUserId, userId)); | ||||||
|         if(fairCollections.size()>0){ |         if(fairCollections.size()>0){ | ||||||
|             fairCollectionMapper.deleteBatchIds(fairCollections.stream().map(FairCollection::getId).collect(Collectors.toList())); |             fairCollectionMapper.deleteBatchIds(fairCollections.stream().map(FairCollection::getId).collect(Collectors.toList())); | ||||||
| @@ -111,7 +110,7 @@ public class FairCollectionServiceImpl extends ServiceImpl<FairCollectionMapper, | |||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public int cancel(Long fairId) { |     public int cancel(Long fairId) { | ||||||
|         Long userId = SecurityUtils.getUserId(); |         Long userId = SiteSecurityUtils.getUserId(); | ||||||
|         List<FairCollection> fairCollections = fairCollectionMapper.selectList(Wrappers.<FairCollection>lambdaQuery().eq(FairCollection::getFairId, fairId).eq(FairCollection::getUserId, userId)); |         List<FairCollection> fairCollections = fairCollectionMapper.selectList(Wrappers.<FairCollection>lambdaQuery().eq(FairCollection::getFairId, fairId).eq(FairCollection::getUserId, userId)); | ||||||
|         if(fairCollections.size()>0){ |         if(fairCollections.size()>0){ | ||||||
|             fairCollectionMapper.deleteBatchIds(fairCollections.stream().map(FairCollection::getId).collect(Collectors.toList())); |             fairCollectionMapper.deleteBatchIds(fairCollections.stream().map(FairCollection::getId).collect(Collectors.toList())); | ||||||
| @@ -123,6 +122,6 @@ public class FairCollectionServiceImpl extends ServiceImpl<FairCollectionMapper, | |||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public List<JobFair> appCollectionFair(Integer type) { |     public List<JobFair> appCollectionFair(Integer type) { | ||||||
|         return jobFairMapper.selectAppList(SecurityUtils.getUserId(),type); |         return jobFairMapper.selectAppList(SiteSecurityUtils.getUserId(),type); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -12,7 +12,7 @@ import com.ruoyi.cms.mapper.FileMapper; | |||||||
| import com.ruoyi.cms.service.IFileService; | import com.ruoyi.cms.service.IFileService; | ||||||
| import com.ruoyi.common.core.domain.AjaxResult; | import com.ruoyi.common.core.domain.AjaxResult; | ||||||
| import com.ruoyi.common.utils.DateUtils; | import com.ruoyi.common.utils.DateUtils; | ||||||
| import com.ruoyi.common.utils.SecurityUtils; | import com.ruoyi.common.utils.SiteSecurityUtils; | ||||||
| import com.ruoyi.common.utils.uuid.IdUtils; | import com.ruoyi.common.utils.uuid.IdUtils; | ||||||
| import com.ruoyi.common.utils.uuid.UUID; | import com.ruoyi.common.utils.uuid.UUID; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
|   | |||||||
| @@ -6,9 +6,11 @@ import com.ruoyi.cms.domain.FairCollection; | |||||||
| import com.ruoyi.cms.domain.Job; | import com.ruoyi.cms.domain.Job; | ||||||
| import com.ruoyi.cms.domain.JobApply; | import com.ruoyi.cms.domain.JobApply; | ||||||
| import com.ruoyi.cms.domain.query.MineJobQuery; | import com.ruoyi.cms.domain.query.MineJobQuery; | ||||||
|  | import com.ruoyi.cms.domain.vo.CandidateVO; | ||||||
| import com.ruoyi.cms.mapper.*; | import com.ruoyi.cms.mapper.*; | ||||||
| import com.ruoyi.cms.service.IJobApplyService; | import com.ruoyi.cms.service.IJobApplyService; | ||||||
| import com.ruoyi.common.utils.SecurityUtils; | import com.ruoyi.common.core.domain.entity.AppUser; | ||||||
|  | import com.ruoyi.common.utils.SiteSecurityUtils; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
|  |  | ||||||
| @@ -98,17 +100,17 @@ public class JobApplyServiceImpl extends ServiceImpl<JobApplyMapper,JobApply> im | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public List<Job> applyJob() { |     public List<Job> applyJob() { | ||||||
|         List<Job> jobs = jobApplyMapper.applyJob(SecurityUtils.getUserId()); |         List<Job> jobs = jobApplyMapper.applyJob(SiteSecurityUtils.getUserId()); | ||||||
|         return jobs; |         return jobs; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public HashMap<String, Integer> statistics() { |     public HashMap<String, Integer> statistics() { | ||||||
|         Integer applyCount = jobApplyMapper.applyJob(SecurityUtils.getUserId()).size(); |         Integer applyCount = jobApplyMapper.applyJob(SiteSecurityUtils.getUserId()).size(); | ||||||
|         Integer collectionJobCount = jobCollectionMapper.collectionJob(SecurityUtils.getUserId()).size(); |         Integer collectionJobCount = jobCollectionMapper.collectionJob(SiteSecurityUtils.getUserId()).size(); | ||||||
|         Integer collectionCompanyCount = companyCollectionMapper.collectionJob(SecurityUtils.getUserId()).size(); |         Integer collectionCompanyCount = companyCollectionMapper.collectionJob(SiteSecurityUtils.getUserId()).size(); | ||||||
|         Integer jobReviewCount = appReviewJobMapper.review(SecurityUtils.getUserId(),new MineJobQuery()).size(); |         Integer jobReviewCount = appReviewJobMapper.review(SiteSecurityUtils.getUserId(),new MineJobQuery()).size(); | ||||||
|         Integer fairCollecitonCount = fairCollectionMapper.selectList(Wrappers.<FairCollection>lambdaQuery().eq(FairCollection::getUserId, SecurityUtils.getUserId())).size(); |         Integer fairCollecitonCount = fairCollectionMapper.selectList(Wrappers.<FairCollection>lambdaQuery().eq(FairCollection::getUserId, SiteSecurityUtils.getUserId())).size(); | ||||||
|         HashMap<String, Integer> map = new HashMap<>(); |         HashMap<String, Integer> map = new HashMap<>(); | ||||||
|         map.put("applyCount", applyCount); |         map.put("applyCount", applyCount); | ||||||
|         map.put("collectionCount", collectionJobCount+collectionCompanyCount); |         map.put("collectionCount", collectionJobCount+collectionCompanyCount); | ||||||
| @@ -116,4 +118,19 @@ public class JobApplyServiceImpl extends ServiceImpl<JobApplyMapper,JobApply> im | |||||||
|         map.put("fairCollecitonCount", fairCollecitonCount); |         map.put("fairCollecitonCount", fairCollecitonCount); | ||||||
|         return map; |         return map; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public HashMap<String, Integer> trendChart(JobApply jobApply) { | ||||||
|  |         return jobApplyMapper.trendChart(jobApply); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public List<CandidateVO> selectAppUserList(Job job) { | ||||||
|  |         return jobApplyMapper.selectAppUserList(job); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public List<CandidateVO> selectApplyJobUserList(AppUser appUser) { | ||||||
|  |         return jobApplyMapper.selectApplyJobUserList(appUser); | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -14,7 +14,8 @@ import com.ruoyi.cms.mapper.AppUserMapper; | |||||||
| import com.ruoyi.cms.mapper.JobApplyMapper; | import com.ruoyi.cms.mapper.JobApplyMapper; | ||||||
| import com.ruoyi.cms.mapper.JobMapper; | import com.ruoyi.cms.mapper.JobMapper; | ||||||
| import com.ruoyi.cms.service.IBussinessDictTypeService; | import com.ruoyi.cms.service.IBussinessDictTypeService; | ||||||
| import com.ruoyi.common.utils.SecurityUtils; | import com.ruoyi.common.core.domain.entity.AppUser; | ||||||
|  | import com.ruoyi.common.utils.SiteSecurityUtils; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| @@ -106,7 +107,7 @@ public class JobCollectionServiceImpl extends ServiceImpl<JobCollectionMapper,Jo | |||||||
|     @Override |     @Override | ||||||
|     @Transactional |     @Transactional | ||||||
|     public int jobCollection(Long jobId) { |     public int jobCollection(Long jobId) { | ||||||
|         Long userId = SecurityUtils.getUserId(); |         Long userId = SiteSecurityUtils.getUserId(); | ||||||
|         List<JobCollection> jobCollections = jobCollectionMapper.selectList(Wrappers.<JobCollection>lambdaQuery().eq(JobCollection::getJobId, jobId).eq(JobCollection::getUserId, userId)); |         List<JobCollection> jobCollections = jobCollectionMapper.selectList(Wrappers.<JobCollection>lambdaQuery().eq(JobCollection::getJobId, jobId).eq(JobCollection::getUserId, userId)); | ||||||
|         if(jobCollections.size()>0){ |         if(jobCollections.size()>0){ | ||||||
|             jobCollectionMapper.deleteBatchIds(jobCollections.stream().map(JobCollection::getId).collect(Collectors.toList())); |             jobCollectionMapper.deleteBatchIds(jobCollections.stream().map(JobCollection::getId).collect(Collectors.toList())); | ||||||
| @@ -122,7 +123,7 @@ public class JobCollectionServiceImpl extends ServiceImpl<JobCollectionMapper,Jo | |||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public int cancel(Long jobId) { |     public int cancel(Long jobId) { | ||||||
|         Long userId = SecurityUtils.getUserId(); |         Long userId = SiteSecurityUtils.getUserId(); | ||||||
|         List<JobCollection> jobCollections = jobCollectionMapper.selectList(Wrappers.<JobCollection>lambdaQuery().eq(JobCollection::getJobId, jobId).eq(JobCollection::getUserId, userId)); |         List<JobCollection> jobCollections = jobCollectionMapper.selectList(Wrappers.<JobCollection>lambdaQuery().eq(JobCollection::getJobId, jobId).eq(JobCollection::getUserId, userId)); | ||||||
|         if(jobCollections.size()>0){ |         if(jobCollections.size()>0){ | ||||||
|             jobCollectionMapper.deleteBatchIds(jobCollections.stream().map(JobCollection::getId).collect(Collectors.toList())); |             jobCollectionMapper.deleteBatchIds(jobCollections.stream().map(JobCollection::getId).collect(Collectors.toList())); | ||||||
| @@ -132,7 +133,7 @@ public class JobCollectionServiceImpl extends ServiceImpl<JobCollectionMapper,Jo | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public int apply(Long jobId) { |     public int apply(Long jobId) { | ||||||
|         Long userId = SecurityUtils.getUserId(); |         Long userId = SiteSecurityUtils.getUserId(); | ||||||
|         JobApply jobApply = new JobApply(); |         JobApply jobApply = new JobApply(); | ||||||
|         jobApply.setJobId(jobId); |         jobApply.setJobId(jobId); | ||||||
|         jobApply.setUserId(userId); |         jobApply.setUserId(userId); | ||||||
| @@ -149,7 +150,7 @@ public class JobCollectionServiceImpl extends ServiceImpl<JobCollectionMapper,Jo | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public List<Job> collectionJob() { |     public List<Job> collectionJob() { | ||||||
|         List<Job> jobs = jobCollectionMapper.collectionJob(SecurityUtils.getUserId()); |         List<Job> jobs = jobCollectionMapper.collectionJob(SiteSecurityUtils.getUserId()); | ||||||
|         return jobs; |         return jobs; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -9,8 +9,9 @@ import com.ruoyi.cms.mapper.CompanyMapper; | |||||||
| import com.ruoyi.cms.mapper.FairCollectionMapper; | import com.ruoyi.cms.mapper.FairCollectionMapper; | ||||||
| import com.ruoyi.cms.mapper.FairCompanyMapper; | import com.ruoyi.cms.mapper.FairCompanyMapper; | ||||||
| import com.ruoyi.common.constant.Constants; | import com.ruoyi.common.constant.Constants; | ||||||
|  | import com.ruoyi.common.core.domain.entity.Company; | ||||||
| import com.ruoyi.common.exception.ServiceException; | import com.ruoyi.common.exception.ServiceException; | ||||||
| import com.ruoyi.common.utils.SecurityUtils; | import com.ruoyi.common.utils.SiteSecurityUtils; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| @@ -148,8 +149,8 @@ public class JobFairServiceImpl extends ServiceImpl<JobFairMapper,JobFair> imple | |||||||
|             List<Company> companyList = companyMapper.selectBatchIds(companyIds); |             List<Company> companyList = companyMapper.selectBatchIds(companyIds); | ||||||
|             jobFair.setCompanyList(companyList); |             jobFair.setCompanyList(companyList); | ||||||
|         } |         } | ||||||
|         if(SecurityUtils.isLogin()){ |         if(SiteSecurityUtils.isLogin()){ | ||||||
|             Long count = fairCollectionMapper.selectCount(Wrappers.<FairCollection>lambdaQuery().eq(FairCollection::getFairId, fairId).eq(FairCollection::getUserId, SecurityUtils.getUserId())); |             Long count = fairCollectionMapper.selectCount(Wrappers.<FairCollection>lambdaQuery().eq(FairCollection::getFairId, fairId).eq(FairCollection::getUserId, SiteSecurityUtils.getUserId())); | ||||||
|             jobFair.setIsCollection(count>0?1:null); |             jobFair.setIsCollection(count>0?1:null); | ||||||
|         } |         } | ||||||
|         return jobFair; |         return jobFair; | ||||||
| @@ -159,10 +160,10 @@ public class JobFairServiceImpl extends ServiceImpl<JobFairMapper,JobFair> imple | |||||||
|     public List<JobFair> appList(JobFair jobFair) { |     public List<JobFair> appList(JobFair jobFair) { | ||||||
|         List<JobFair> fairCompanies = jobFairMapper.appList(jobFair); |         List<JobFair> fairCompanies = jobFairMapper.appList(jobFair); | ||||||
|         if(fairCompanies.isEmpty()){return new ArrayList<>();} |         if(fairCompanies.isEmpty()){return new ArrayList<>();} | ||||||
|         if(SecurityUtils.isLogin()){ |         if(SiteSecurityUtils.isLogin()){ | ||||||
|             //收藏 |             //收藏 | ||||||
|             Set<Long> collectionIds = fairCollectionMapper.selectList(Wrappers.<FairCollection>lambdaQuery() |             Set<Long> collectionIds = fairCollectionMapper.selectList(Wrappers.<FairCollection>lambdaQuery() | ||||||
|                             .eq(FairCollection::getUserId, SecurityUtils.getUserId()) |                             .eq(FairCollection::getUserId, SiteSecurityUtils.getUserId()) | ||||||
|                             .in(FairCollection::getFairId, fairCompanies.stream().map(JobFair::getJobFairId).collect(Collectors.toList()))) |                             .in(FairCollection::getFairId, fairCompanies.stream().map(JobFair::getJobFairId).collect(Collectors.toList()))) | ||||||
|                     .stream().map(FairCollection::getFairId).collect(Collectors.toSet()); |                     .stream().map(FairCollection::getFairId).collect(Collectors.toSet()); | ||||||
|             for (JobFair j : fairCompanies) { |             for (JobFair j : fairCompanies) { | ||||||
|   | |||||||
| @@ -2,16 +2,15 @@ package com.ruoyi.cms.service.impl; | |||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.core.toolkit.Wrappers; | import com.baomidou.mybatisplus.core.toolkit.Wrappers; | ||||||
| import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | ||||||
| import com.ruoyi.cms.domain.AppUser; | import com.ruoyi.common.core.domain.entity.AppUser; | ||||||
| import com.ruoyi.cms.domain.Job; | import com.ruoyi.cms.domain.Job; | ||||||
| import com.ruoyi.cms.domain.JobApply; | import com.ruoyi.cms.domain.JobApply; | ||||||
| import com.ruoyi.cms.domain.JobCollection; | import com.ruoyi.cms.domain.JobCollection; | ||||||
| import com.ruoyi.cms.mapper.AppUserMapper; | import com.ruoyi.cms.mapper.AppUserMapper; | ||||||
| import com.ruoyi.cms.mapper.JobApplyMapper; | import com.ruoyi.cms.mapper.JobApplyMapper; | ||||||
| import com.ruoyi.cms.mapper.JobCollectionMapper; | import com.ruoyi.cms.mapper.JobCollectionMapper; | ||||||
| import com.ruoyi.cms.service.IJobCollectionService; |  | ||||||
| import com.ruoyi.cms.service.IJobRecommentService; | import com.ruoyi.cms.service.IJobRecommentService; | ||||||
| import com.ruoyi.common.utils.SecurityUtils; | import com.ruoyi.common.utils.SiteSecurityUtils; | ||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| import org.springframework.transaction.annotation.Transactional; | import org.springframework.transaction.annotation.Transactional; | ||||||
| @@ -100,7 +99,7 @@ public class JobRecommentServiceImpl extends ServiceImpl<JobCollectionMapper,Job | |||||||
|     @Override |     @Override | ||||||
|     @Transactional |     @Transactional | ||||||
|     public int jobCollection(Long jobId) { |     public int jobCollection(Long jobId) { | ||||||
|         Long userId = SecurityUtils.getUserId(); |         Long userId = SiteSecurityUtils.getUserId(); | ||||||
|         List<JobCollection> jobCollections = jobCollectionMapper.selectList(Wrappers.<JobCollection>lambdaQuery().eq(JobCollection::getJobId, jobId).eq(JobCollection::getUserId, userId)); |         List<JobCollection> jobCollections = jobCollectionMapper.selectList(Wrappers.<JobCollection>lambdaQuery().eq(JobCollection::getJobId, jobId).eq(JobCollection::getUserId, userId)); | ||||||
|         if(jobCollections.size()>0){ |         if(jobCollections.size()>0){ | ||||||
|             jobCollectionMapper.deleteBatchIds(jobCollections.stream().map(JobCollection::getId).collect(Collectors.toList())); |             jobCollectionMapper.deleteBatchIds(jobCollections.stream().map(JobCollection::getId).collect(Collectors.toList())); | ||||||
| @@ -116,7 +115,7 @@ public class JobRecommentServiceImpl extends ServiceImpl<JobCollectionMapper,Job | |||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public int cancel(Long jobId) { |     public int cancel(Long jobId) { | ||||||
|         Long userId = SecurityUtils.getUserId(); |         Long userId = SiteSecurityUtils.getUserId(); | ||||||
|         List<JobCollection> jobCollections = jobCollectionMapper.selectList(Wrappers.<JobCollection>lambdaQuery().eq(JobCollection::getJobId, jobId).eq(JobCollection::getUserId, userId)); |         List<JobCollection> jobCollections = jobCollectionMapper.selectList(Wrappers.<JobCollection>lambdaQuery().eq(JobCollection::getJobId, jobId).eq(JobCollection::getUserId, userId)); | ||||||
|         if(jobCollections.size()>0){ |         if(jobCollections.size()>0){ | ||||||
|             jobCollectionMapper.deleteBatchIds(jobCollections.stream().map(JobCollection::getId).collect(Collectors.toList())); |             jobCollectionMapper.deleteBatchIds(jobCollections.stream().map(JobCollection::getId).collect(Collectors.toList())); | ||||||
| @@ -126,7 +125,7 @@ public class JobRecommentServiceImpl extends ServiceImpl<JobCollectionMapper,Job | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public int apply(Long jobId) { |     public int apply(Long jobId) { | ||||||
|         Long userId = SecurityUtils.getUserId(); |         Long userId = SiteSecurityUtils.getUserId(); | ||||||
|         JobApply jobApply = new JobApply(); |         JobApply jobApply = new JobApply(); | ||||||
|         jobApply.setJobId(jobId); |         jobApply.setJobId(jobId); | ||||||
|         jobApply.setUserId(userId); |         jobApply.setUserId(userId); | ||||||
| @@ -143,13 +142,13 @@ public class JobRecommentServiceImpl extends ServiceImpl<JobCollectionMapper,Job | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public List<Job> collectionJob() { |     public List<Job> collectionJob() { | ||||||
|         List<Job> jobs = jobCollectionMapper.collectionJob(SecurityUtils.getUserId()); |         List<Job> jobs = jobCollectionMapper.collectionJob(SiteSecurityUtils.getUserId()); | ||||||
|         return jobs; |         return jobs; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public String competitiveness(Long jobId) { |     public String competitiveness(Long jobId) { | ||||||
|         AppUser appUser = appUserMapper.selectById(SecurityUtils.getUserId()); |         AppUser appUser = appUserMapper.selectById(SiteSecurityUtils.getUserId()); | ||||||
|         String education = appUser.getEducation(); |         String education = appUser.getEducation(); | ||||||
|         return "90.5"; |         return "90.5"; | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -9,6 +9,7 @@ import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | |||||||
| import com.fasterxml.jackson.core.type.TypeReference; | import com.fasterxml.jackson.core.type.TypeReference; | ||||||
| import com.fasterxml.jackson.databind.ObjectMapper; | import com.fasterxml.jackson.databind.ObjectMapper; | ||||||
| import com.ruoyi.cms.domain.*; | import com.ruoyi.cms.domain.*; | ||||||
|  | import com.ruoyi.cms.domain.File; | ||||||
| import com.ruoyi.cms.domain.query.ESJobSearch; | import com.ruoyi.cms.domain.query.ESJobSearch; | ||||||
| import com.ruoyi.cms.domain.vo.CandidateVO; | import com.ruoyi.cms.domain.vo.CandidateVO; | ||||||
| import com.ruoyi.cms.mapper.*; | import com.ruoyi.cms.mapper.*; | ||||||
| @@ -16,10 +17,13 @@ import com.ruoyi.cms.service.*; | |||||||
| import com.ruoyi.cms.util.*; | import com.ruoyi.cms.util.*; | ||||||
| import com.ruoyi.common.constant.Constants; | import com.ruoyi.common.constant.Constants; | ||||||
| import com.ruoyi.common.core.domain.TreeSelect; | import com.ruoyi.common.core.domain.TreeSelect; | ||||||
|  | import com.ruoyi.common.core.domain.entity.AppUser; | ||||||
|  | import com.ruoyi.common.core.domain.entity.Company; | ||||||
| import com.ruoyi.common.core.domain.entity.JobTitle; | import com.ruoyi.common.core.domain.entity.JobTitle; | ||||||
| import com.ruoyi.common.core.redis.RedisCache; | import com.ruoyi.common.core.redis.RedisCache; | ||||||
| import com.ruoyi.common.exception.ServiceException; | import com.ruoyi.common.exception.ServiceException; | ||||||
| import com.ruoyi.common.utils.SecurityUtils; | import com.ruoyi.common.utils.SiteSecurityUtils; | ||||||
|  | import com.ruoyi.common.utils.bean.BeanUtils; | ||||||
| import com.ruoyi.common.utils.spring.SpringUtils; | import com.ruoyi.common.utils.spring.SpringUtils; | ||||||
| import org.dromara.easyes.core.biz.EsPageInfo; | import org.dromara.easyes.core.biz.EsPageInfo; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| @@ -73,6 +77,8 @@ public class JobServiceImpl extends ServiceImpl<JobMapper,Job> implements IJobSe | |||||||
|     private RedisCache redisCache; |     private RedisCache redisCache; | ||||||
|     @Autowired |     @Autowired | ||||||
|     private JobContactMapper jobContactMapper; |     private JobContactMapper jobContactMapper; | ||||||
|  |     @Autowired | ||||||
|  |     private FileMapper fileMapper; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 更新工作地址的经纬度信息 |      * 更新工作地址的经纬度信息 | ||||||
| @@ -197,6 +203,21 @@ public class JobServiceImpl extends ServiceImpl<JobMapper,Job> implements IJobSe | |||||||
|             Company company = companyMapper.selectById(job.getCompanyId()); |             Company company = companyMapper.selectById(job.getCompanyId()); | ||||||
|             job.setCompany(company); |             job.setCompany(company); | ||||||
|         } |         } | ||||||
|  |         //查询联系人 | ||||||
|  |         JobContact contact=new JobContact(); | ||||||
|  |         contact.setJobId(job.getJobId()); | ||||||
|  |         List<JobContact> contacts=jobContactMapper.getSelectList(contact); | ||||||
|  |         if(contacts!=null){ | ||||||
|  |             job.setJobContactList(contacts); | ||||||
|  |         } | ||||||
|  |         //查询附件 | ||||||
|  |         File file=new File(); | ||||||
|  |         file.setBussinessId(jobId); | ||||||
|  |         List<File> filesList=fileMapper.selectFileList(file); | ||||||
|  |         if(filesList!=null){ | ||||||
|  |             job.setFilesList(filesList); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         return job; |         return job; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -245,6 +266,7 @@ public class JobServiceImpl extends ServiceImpl<JobMapper,Job> implements IJobSe | |||||||
|         if(insert>0){ |         if(insert>0){ | ||||||
|             job.getJobContactList().forEach(x->{ |             job.getJobContactList().forEach(x->{ | ||||||
|                 JobContact jobContact=new JobContact(); |                 JobContact jobContact=new JobContact(); | ||||||
|  |                 BeanUtils.copyProperties(x,jobContact); | ||||||
|                 jobContact.setJobId(job.getJobId()); |                 jobContact.setJobId(job.getJobId()); | ||||||
|                 jobContactMapper.insert(jobContact); |                 jobContactMapper.insert(jobContact); | ||||||
|             }); |             }); | ||||||
| @@ -369,22 +391,22 @@ public class JobServiceImpl extends ServiceImpl<JobMapper,Job> implements IJobSe | |||||||
|                 Company company = companyMapper.selectById(job.getCompanyId()); |                 Company company = companyMapper.selectById(job.getCompanyId()); | ||||||
|                 job.setCompany(company); |                 job.setCompany(company); | ||||||
|             } |             } | ||||||
|             if(SecurityUtils.isLogin()){ |             if(SiteSecurityUtils.isLogin()){ | ||||||
|                 //查询申请信息 |                 //查询申请信息 | ||||||
|                 Long applyCount = jobApplyMapper.selectCount(Wrappers.<JobApply>lambdaQuery().eq(JobApply::getJobId, jobId).eq(JobApply::getUserId, SecurityUtils.getUserId())); |                 Long applyCount = jobApplyMapper.selectCount(Wrappers.<JobApply>lambdaQuery().eq(JobApply::getJobId, jobId).eq(JobApply::getUserId, SiteSecurityUtils.getUserId())); | ||||||
|                 job.setIsApply(applyCount>0?1:0); |                 job.setIsApply(applyCount>0?1:0); | ||||||
|                 //查询收藏信息 |                 //查询收藏信息 | ||||||
|                 Long collectionCount = jobCollectionMapper.selectCount(Wrappers.<JobCollection>lambdaQuery().eq(JobCollection::getJobId, jobId).eq(JobCollection::getUserId, SecurityUtils.getUserId())); |                 Long collectionCount = jobCollectionMapper.selectCount(Wrappers.<JobCollection>lambdaQuery().eq(JobCollection::getJobId, jobId).eq(JobCollection::getUserId, SiteSecurityUtils.getUserId())); | ||||||
|                 job.setIsCollection(collectionCount>0?1:0); |                 job.setIsCollection(collectionCount>0?1:0); | ||||||
|                 //todo asyn |                 //todo asyn | ||||||
|                 //保存浏览记录 |                 //保存浏览记录 | ||||||
|                 List<AppReviewJob> appReviewJobs = appReviewJobMapper.selectList(Wrappers.<AppReviewJob>lambdaQuery().eq(AppReviewJob::getUserId, SecurityUtils.getUserId()).eq(AppReviewJob::getJobId, jobId)); |                 List<AppReviewJob> appReviewJobs = appReviewJobMapper.selectList(Wrappers.<AppReviewJob>lambdaQuery().eq(AppReviewJob::getUserId, SiteSecurityUtils.getUserId()).eq(AppReviewJob::getJobId, jobId)); | ||||||
|                 //之前相同岗位的记录删除 保存最新的浏览记录 |                 //之前相同岗位的记录删除 保存最新的浏览记录 | ||||||
|                 if(!appReviewJobs.isEmpty()){ |                 if(!appReviewJobs.isEmpty()){ | ||||||
|                     appReviewJobMapper.deleteBatchIds(appReviewJobs.stream().map(AppReviewJob::getId).collect(Collectors.toList())); |                     appReviewJobMapper.deleteBatchIds(appReviewJobs.stream().map(AppReviewJob::getId).collect(Collectors.toList())); | ||||||
|                 } |                 } | ||||||
|                 AppReviewJob appReviewJob = new AppReviewJob(); |                 AppReviewJob appReviewJob = new AppReviewJob(); | ||||||
|                 appReviewJob.setUserId(SecurityUtils.getUserId()); |                 appReviewJob.setUserId(SiteSecurityUtils.getUserId()); | ||||||
|                 LocalDateTime now = LocalDateTime.now(); |                 LocalDateTime now = LocalDateTime.now(); | ||||||
|                 String formattedDate = now.format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")); |                 String formattedDate = now.format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")); | ||||||
|                 appReviewJob.setReviewDate(formattedDate); |                 appReviewJob.setReviewDate(formattedDate); | ||||||
| @@ -685,6 +707,7 @@ public class JobServiceImpl extends ServiceImpl<JobMapper,Job> implements IJobSe | |||||||
|             logger.error("导入数据过程中发生异常: {}", e.getMessage(), e); |             logger.error("导入数据过程中发生异常: {}", e.getMessage(), e); | ||||||
|             throw new RuntimeException(e); |             throw new RuntimeException(e); | ||||||
|         } |         } | ||||||
|  |         iesJobSearchService.resetTextCache(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private Long getCompanyId(List<Company> allCompany, String aab004) { |     private Long getCompanyId(List<Company> allCompany, String aab004) { | ||||||
| @@ -748,10 +771,10 @@ public class JobServiceImpl extends ServiceImpl<JobMapper,Job> implements IJobSe | |||||||
|  |  | ||||||
|     private List<ESJobDocument> userCollection(List<ESJobDocument> jobs){ |     private List<ESJobDocument> userCollection(List<ESJobDocument> jobs){ | ||||||
|         if(jobs.isEmpty()){return new ArrayList<>();} |         if(jobs.isEmpty()){return new ArrayList<>();} | ||||||
|         if(SecurityUtils.isLogin()){ |         if(SiteSecurityUtils.isLogin()){ | ||||||
|             //收藏 |             //收藏 | ||||||
|             Set<Long> collectionIds = jobCollectionMapper.selectList(Wrappers.<JobCollection>lambdaQuery() |             Set<Long> collectionIds = jobCollectionMapper.selectList(Wrappers.<JobCollection>lambdaQuery() | ||||||
|                             .eq(JobCollection::getUserId, SecurityUtils.getUserId()) |                             .eq(JobCollection::getUserId, SiteSecurityUtils.getUserId()) | ||||||
|                             .in(JobCollection::getJobId, jobs.stream().map(ESJobDocument::getJobId).collect(Collectors.toList()))) |                             .in(JobCollection::getJobId, jobs.stream().map(ESJobDocument::getJobId).collect(Collectors.toList()))) | ||||||
|                     .stream().map(JobCollection::getJobId).collect(Collectors.toSet()); |                     .stream().map(JobCollection::getJobId).collect(Collectors.toSet()); | ||||||
|             for (ESJobDocument j : jobs) { |             for (ESJobDocument j : jobs) { | ||||||
| @@ -766,12 +789,24 @@ public class JobServiceImpl extends ServiceImpl<JobMapper,Job> implements IJobSe | |||||||
|     @Override |     @Override | ||||||
|     public void publishJob(Job job) { |     public void publishJob(Job job) { | ||||||
|         job.setIsPublish(0); |         job.setIsPublish(0); | ||||||
|         Long userId = SecurityUtils.getUserId(); | //        Long userId = SiteSecurityUtils.getUserId(); | ||||||
|         Company company = companyMapper.selectOne(Wrappers.<Company>lambdaQuery().eq(Company::getUserId, userId).eq(Company::getStatus, 1)); | //        Company company = companyMapper.selectOne(Wrappers.<Company>lambdaQuery().eq(Company::getUserId, userId).eq(Company::getStatus, 1)); | ||||||
|         if(Objects.isNull(company)){ | //        if(Objects.isNull(company)){ | ||||||
|             throw new ServiceException("请先完成招聘企业登记"); | //            throw new ServiceException("请先完成招聘企业登记"); | ||||||
|         } | //        } | ||||||
|         job.setCompanyId(company.getCompanyId()); | //        job.setCompanyId(company.getCompanyId()); | ||||||
|         jobMapper.insert(job); |         jobMapper.insert(job); | ||||||
|  |         if(job.getJobContactList()!=null){ | ||||||
|  |             job.getJobContactList().forEach(it->{ | ||||||
|  |                 it.setJobId(job.getJobId()); | ||||||
|  |             }); | ||||||
|  |             jobContactMapper.batchInsert(job.getJobContactList()); | ||||||
|  |         } | ||||||
|  |         iesJobSearchService.updateJob(job.getJobId()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public List<AppUser> selectApplyJobUserList(Long jobId) { | ||||||
|  |         return jobMapper.selectApplyJobUserList(jobId); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,48 @@ | |||||||
|  | package com.ruoyi.cms.service.impl; | ||||||
|  |  | ||||||
|  | import com.ruoyi.cms.domain.SensitiveWordData; | ||||||
|  | import com.ruoyi.cms.mapper.SensitiveWordDataMapper; | ||||||
|  | import com.ruoyi.cms.service.SensitiveWordDataService; | ||||||
|  | import org.springframework.beans.factory.annotation.Autowired; | ||||||
|  | import org.springframework.stereotype.Service; | ||||||
|  |  | ||||||
|  | import java.util.Arrays; | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @Service | ||||||
|  | public class SensitiveWordDataServiceImpl implements SensitiveWordDataService { | ||||||
|  |  | ||||||
|  |     @Autowired | ||||||
|  |     SensitiveWordDataMapper sensitiveWordDataMapper; | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public List<SensitiveWordData> selectSensitiveworddataList(SensitiveWordData sensitiveworddata) { | ||||||
|  |         return sensitiveWordDataMapper.selectSensitiveworddataList(sensitiveworddata); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public SensitiveWordData selectById(Long id) { | ||||||
|  |         return sensitiveWordDataMapper.selectById(id); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public int insertSensitiveworddata(SensitiveWordData sensitiveWordData) { | ||||||
|  |         return sensitiveWordDataMapper.insert(sensitiveWordData); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public int updateSensitiveworddata(SensitiveWordData sensitiveWordData) { | ||||||
|  |         return sensitiveWordDataMapper.updateById(sensitiveWordData); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public int deleteSensitiveworddataIds(Long[] ids) { | ||||||
|  |         return sensitiveWordDataMapper.deleteBatchIds(Arrays.asList(ids)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public int batchInsert(List<SensitiveWordData> list) { | ||||||
|  |         return sensitiveWordDataMapper.batchInsert(list); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -0,0 +1,42 @@ | |||||||
|  | package com.ruoyi.cms.service.impl; | ||||||
|  |  | ||||||
|  | import com.ruoyi.common.core.domain.entity.UserWorkExperiences; | ||||||
|  | import com.ruoyi.cms.mapper.UserWorkExperiencesMapper; | ||||||
|  | import com.ruoyi.cms.service.UserWorkExperiencesService; | ||||||
|  | import org.springframework.beans.factory.annotation.Autowired; | ||||||
|  | import org.springframework.stereotype.Service; | ||||||
|  |  | ||||||
|  | import java.util.Arrays; | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @Service | ||||||
|  | public class UserWorkExperiencesServiceImpl implements UserWorkExperiencesService { | ||||||
|  |  | ||||||
|  |     @Autowired | ||||||
|  |     UserWorkExperiencesMapper userWorkExperiencesMapper; | ||||||
|  |  | ||||||
|  |     public List<UserWorkExperiences> getWorkExperiencesList(UserWorkExperiences userWorkExperiences){ | ||||||
|  |         return userWorkExperiencesMapper.getWorkExperiencesList(userWorkExperiences); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public int insertWorkExperiences(UserWorkExperiences userWorkExperiences) { | ||||||
|  |         return userWorkExperiencesMapper.insert(userWorkExperiences); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public int updateWorkExperiencesById(UserWorkExperiences userWorkExperiences) { | ||||||
|  |         return userWorkExperiencesMapper.updateById(userWorkExperiences); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public int deleteWorkExperiencesIds(Long[] ids) { | ||||||
|  |         return userWorkExperiencesMapper.deleteBatchIds(Arrays.asList(ids)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public UserWorkExperiences getWorkExperiencesById(Long id) { | ||||||
|  |         return userWorkExperiencesMapper.selectById(id); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -0,0 +1,198 @@ | |||||||
|  | package com.ruoyi.cms.util; | ||||||
|  |  | ||||||
|  | import com.alibaba.excel.EasyExcel; | ||||||
|  | import com.alibaba.excel.context.AnalysisContext; | ||||||
|  | import com.alibaba.excel.event.AnalysisEventListener; | ||||||
|  | import com.alibaba.excel.write.builder.ExcelWriterSheetBuilder; | ||||||
|  | import com.alibaba.excel.write.metadata.style.WriteCellStyle; | ||||||
|  | import com.alibaba.excel.write.metadata.style.WriteFont; | ||||||
|  | import com.alibaba.excel.write.style.HorizontalCellStyleStrategy; | ||||||
|  | import org.apache.poi.ss.usermodel.HorizontalAlignment; | ||||||
|  | import org.apache.poi.ss.usermodel.VerticalAlignment; | ||||||
|  |  | ||||||
|  | import javax.servlet.http.HttpServletResponse; | ||||||
|  | import java.io.*; | ||||||
|  | import java.net.URLEncoder; | ||||||
|  | import java.util.List; | ||||||
|  | import java.util.Map; | ||||||
|  | import java.util.Objects; | ||||||
|  | import java.util.function.Consumer; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * EasyExcel 工具类(基于 alibaba easyexcel 3.x+) | ||||||
|  |  */ | ||||||
|  | public class EasyExcelUtils { | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 读取 Excel 文件(一次性读取所有数据) | ||||||
|  |      * | ||||||
|  |      * @param file      上传的 Excel 文件 | ||||||
|  |      * @param head      实体类字节码(需使用 @ExcelProperty 注解映射表头) | ||||||
|  |      * @param <T>       实体类泛型 | ||||||
|  |      * @return 解析后的数据集 | ||||||
|  |      */ | ||||||
|  |     public static <T> List<T> readExcel(File file, Class<T> head) { | ||||||
|  |         return EasyExcel.read(file) | ||||||
|  |                 .head(head) | ||||||
|  |                 .sheet() | ||||||
|  |                 .doReadSync(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 读取 Excel 输入流(一次性读取所有数据) | ||||||
|  |      * | ||||||
|  |      * @param inputStream Excel 输入流(如 MultipartFile 的 getInputStream()) | ||||||
|  |      * @param head        实体类字节码 | ||||||
|  |      * @param <T>         实体类泛型 | ||||||
|  |      * @return 解析后的数据集 | ||||||
|  |      */ | ||||||
|  |     public static <T> List<T> readExcel(InputStream inputStream, Class<T> head) { | ||||||
|  |         return EasyExcel.read(inputStream) | ||||||
|  |                 .head(head) | ||||||
|  |                 .sheet() | ||||||
|  |                 .doReadSync(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 分批读取 Excel(适用于大数据量,避免内存溢出) | ||||||
|  |      * | ||||||
|  |      * @param inputStream Excel 输入流 | ||||||
|  |      * @param head        实体类字节码 | ||||||
|  |      * @param batchSize   每批处理的数据量 | ||||||
|  |      * @param consumer    数据处理函数(如批量保存到数据库) | ||||||
|  |      * @param <T>         实体类泛型 | ||||||
|  |      */ | ||||||
|  |     public static <T> void readExcelByBatch(InputStream inputStream, Class<T> head, int batchSize, Consumer<List<T>> consumer) { | ||||||
|  |         EasyExcel.read(inputStream) | ||||||
|  |                 .head(head) | ||||||
|  |                 .sheet() | ||||||
|  |                 .registerReadListener(new AnalysisEventListener<T>() { | ||||||
|  |                     private List<T> batchList; // 临时存储批数据 | ||||||
|  |  | ||||||
|  |                     @Override | ||||||
|  |                     public void invoke(T data, AnalysisContext context) { | ||||||
|  |                         if (batchList == null) { | ||||||
|  |                             batchList = new java.util.ArrayList<>(batchSize); | ||||||
|  |                         } | ||||||
|  |                         batchList.add(data); | ||||||
|  |                         // 达到批处理量时执行消费逻辑 | ||||||
|  |                         if (batchList.size() >= batchSize) { | ||||||
|  |                             consumer.accept(batchList); | ||||||
|  |                             batchList.clear(); // 清空集合,释放内存 | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |  | ||||||
|  |                     @Override | ||||||
|  |                     public void doAfterAllAnalysed(AnalysisContext context) { | ||||||
|  |                         // 处理剩余不足一批的数据 | ||||||
|  |                         if (batchList != null && !batchList.isEmpty()) { | ||||||
|  |                             consumer.accept(batchList); | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 }) | ||||||
|  |                 .doRead(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 生成 Excel 并写入到输出流(通用样式) | ||||||
|  |      * | ||||||
|  |      * @param outputStream 输出流(如 HttpServletResponse 的 getOutputStream()) | ||||||
|  |      * @param data         数据集 | ||||||
|  |      * @param head         实体类字节码 | ||||||
|  |      * @param sheetName    工作表名称 | ||||||
|  |      * @param <T>          实体类泛型 | ||||||
|  |      */ | ||||||
|  |     public static <T> void writeExcel(OutputStream outputStream, List<T> data, Class<T> head, String sheetName) { | ||||||
|  |         // 构建通用样式策略(表头居中加粗,内容居中) | ||||||
|  |         HorizontalCellStyleStrategy styleStrategy = getDefaultStyleStrategy(); | ||||||
|  |  | ||||||
|  |         ExcelWriterSheetBuilder writerBuilder = EasyExcel.write(outputStream, head) | ||||||
|  |                 .sheet(sheetName) | ||||||
|  |                 .registerWriteHandler(styleStrategy); | ||||||
|  |  | ||||||
|  |         writerBuilder.doWrite(data); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 生成 Excel 并通过 HttpServletResponse 下载(前端直接触发下载) | ||||||
|  |      * | ||||||
|  |      * @param response  HttpServletResponse | ||||||
|  |      * @param data      数据集 | ||||||
|  |      * @param head      实体类字节码 | ||||||
|  |      * @param sheetName 工作表名称 | ||||||
|  |      * @param fileName  下载的文件名(不带后缀) | ||||||
|  |      * @param <T>       实体类泛型 | ||||||
|  |      * @throws IOException IO异常 | ||||||
|  |      */ | ||||||
|  |     public static <T> void downloadExcel(HttpServletResponse response, List<T> data, Class<T> head, | ||||||
|  |                                          String sheetName, String fileName) throws IOException { | ||||||
|  |         // 设置响应头,触发前端下载 | ||||||
|  |         response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"); | ||||||
|  |         response.setCharacterEncoding("UTF-8"); | ||||||
|  |         // 文件名编码,避免中文乱码 | ||||||
|  |         String encodedFileName = URLEncoder.encode(fileName, "UTF-8").replaceAll("\\+", "%20"); | ||||||
|  |         response.setHeader("Content-disposition", "attachment;filename*=UTF-8''" + encodedFileName + ".xlsx"); | ||||||
|  |  | ||||||
|  |         // 写入数据到响应流 | ||||||
|  |         writeExcel(response.getOutputStream(), data, head, sheetName); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 填充 Excel 模板(适用于带固定格式的模板文件) | ||||||
|  |      * | ||||||
|  |      * @param templateInputStream 模板文件输入流 | ||||||
|  |      * @param outputStream        输出流(如响应流或文件流) | ||||||
|  |      * @param dataMap             填充数据(key为模板中的占位符,value为填充值) | ||||||
|  |      * @param sheetName           工作表名称 | ||||||
|  |      */ | ||||||
|  |     public static void fillTemplate(InputStream templateInputStream, OutputStream outputStream, | ||||||
|  |                                     Map<String, Object> dataMap, String sheetName) { | ||||||
|  |         EasyExcel.write(outputStream) | ||||||
|  |                 .withTemplate(templateInputStream) | ||||||
|  |                 .sheet(sheetName) | ||||||
|  |                 .doFill(dataMap); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取默认单元格样式策略(表头加粗居中,内容居中) | ||||||
|  |      */ | ||||||
|  |     private static HorizontalCellStyleStrategy getDefaultStyleStrategy() { | ||||||
|  |         // 表头样式 | ||||||
|  |         WriteCellStyle headStyle = new WriteCellStyle(); | ||||||
|  |         WriteFont headFont = new WriteFont(); | ||||||
|  |         headFont.setBold(true); // 加粗 | ||||||
|  |         headFont.setFontHeightInPoints((short) 11); | ||||||
|  |         headStyle.setWriteFont(headFont); | ||||||
|  |         headStyle.setHorizontalAlignment(HorizontalAlignment.CENTER); // 水平居中 | ||||||
|  |         headStyle.setVerticalAlignment(VerticalAlignment.CENTER); // 垂直居中 | ||||||
|  |  | ||||||
|  |         // 内容样式 | ||||||
|  |         WriteCellStyle contentStyle = new WriteCellStyle(); | ||||||
|  |         WriteFont contentFont = new WriteFont(); | ||||||
|  |         contentFont.setFontHeightInPoints((short) 11); | ||||||
|  |         contentStyle.setWriteFont(contentFont); | ||||||
|  |         contentStyle.setHorizontalAlignment(HorizontalAlignment.CENTER); | ||||||
|  |         contentStyle.setVerticalAlignment(VerticalAlignment.CENTER); | ||||||
|  |  | ||||||
|  |         // 返回样式策略 | ||||||
|  |         return new HorizontalCellStyleStrategy(headStyle, contentStyle); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 关闭流(工具类内部使用) | ||||||
|  |      */ | ||||||
|  |     private static void closeStream(Closeable... closeables) { | ||||||
|  |         if (closeables != null) { | ||||||
|  |             for (Closeable closeable : closeables) { | ||||||
|  |                 if (Objects.nonNull(closeable)) { | ||||||
|  |                     try { | ||||||
|  |                         closeable.close(); | ||||||
|  |                     } catch (IOException e) { | ||||||
|  |                         // 日志记录(建议替换为实际项目的日志框架) | ||||||
|  |                         e.printStackTrace(); | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -1,7 +1,5 @@ | |||||||
| package com.ruoyi.cms.util; | package com.ruoyi.cms.util; | ||||||
|  |  | ||||||
| import org.apache.poi.ss.formula.functions.T; |  | ||||||
|  |  | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Objects; | import java.util.Objects; | ||||||
|  |  | ||||||
| @@ -15,4 +13,8 @@ public class ListUtil { | |||||||
|         return s.isEmpty(); |         return s.isEmpty(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public static boolean isListObjectEmptyOrNull(List<?> list) { | ||||||
|  |         // 先判断 null,再判断空集合(短路逻辑避免 NPE) | ||||||
|  |         return list == null || list.isEmpty(); | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,64 @@ | |||||||
|  | package com.ruoyi.cms.util; | ||||||
|  |  | ||||||
|  | import com.ruoyi.common.core.domain.entity.AppUser; | ||||||
|  | import com.ruoyi.common.core.domain.entity.SysUser; | ||||||
|  | import com.ruoyi.common.core.domain.model.LoginSiteUser; | ||||||
|  | import com.ruoyi.common.core.domain.model.LoginUser; | ||||||
|  | import com.ruoyi.common.utils.SecurityUtils; | ||||||
|  | import com.ruoyi.common.utils.SiteSecurityUtils; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 判断是否企业用户 | ||||||
|  |  */ | ||||||
|  | public class RoleUtils { | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 验证用户角色是否是企业用户 | ||||||
|  |      * @return | ||||||
|  |      */ | ||||||
|  |     public static boolean isCompanyAdmin() { | ||||||
|  |         // 先判断用户是否登录 | ||||||
|  |         if (!SecurityUtils.isLogin()) { | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  |         // 获取当前登录用户的角色列表,判断是否包含企业管理员角色ID | ||||||
|  |         LoginUser loginUser = SecurityUtils.getLoginUser(); | ||||||
|  |         return loginUser.getUser().getRoles().stream() | ||||||
|  |                 .anyMatch(role -> StringUtil.COMPANY_ADMIN_ROLE_KEY.equals(role.getRoleId())); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取身份证或统一信用代码 | ||||||
|  |      * @return | ||||||
|  |      */ | ||||||
|  |     public static String getCurrentUseridCard() { | ||||||
|  |         LoginUser loginUser = SecurityUtils.getLoginUser(); // 已包含登录校验 | ||||||
|  |         SysUser sysUser = loginUser.getUser(); | ||||||
|  |         if (sysUser == null) { | ||||||
|  |             throw new IllegalArgumentException("用户信息为空,无法获取身份证号"); | ||||||
|  |         } | ||||||
|  |         return sysUser.getIdCard(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取App用户身份证或统一信用代码 | ||||||
|  |      * @return | ||||||
|  |      */ | ||||||
|  |     public static String getAppCurrentUseridCard(){ | ||||||
|  |         if (!SiteSecurityUtils.isLogin()) { | ||||||
|  |             return null; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         LoginSiteUser loginSiteUser = SiteSecurityUtils.getLoginUser(); | ||||||
|  |         AppUser appUser = loginSiteUser.getUser(); | ||||||
|  |         if (appUser == null) { | ||||||
|  |             throw new IllegalArgumentException("用户信息为空,无法获取身份证号"); // 用户信息为空仍抛异常,避免空指针 | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if ("0".equals(appUser.getIsCompanyUser())) { | ||||||
|  |             return appUser.getIdCard(); | ||||||
|  |         } else { | ||||||
|  |             return null; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -9,6 +9,14 @@ import java.util.Objects; | |||||||
| import java.util.stream.Collectors; | import java.util.stream.Collectors; | ||||||
|  |  | ||||||
| public class StringUtil { | public class StringUtil { | ||||||
|  |  | ||||||
|  |     public static final Long COMPANY_ADMIN_ROLE_KEY = 100L; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 企业用户 | ||||||
|  |      */ | ||||||
|  |     public static final String IS_COMPANY_USER = "0"; | ||||||
|  |  | ||||||
|     public static Boolean isEmptyOrNull(String s){ |     public static Boolean isEmptyOrNull(String s){ | ||||||
|         if(Objects.isNull(s)){return true;} |         if(Objects.isNull(s)){return true;} | ||||||
|         return s.isEmpty(); |         return s.isEmpty(); | ||||||
|   | |||||||
| @@ -11,10 +11,14 @@ import lombok.extern.slf4j.Slf4j; | |||||||
| import org.apache.commons.io.FileUtils; | import org.apache.commons.io.FileUtils; | ||||||
| import org.springframework.stereotype.Component; | import org.springframework.stereotype.Component; | ||||||
|  |  | ||||||
|  | import javax.crypto.Cipher; | ||||||
|  | import javax.crypto.spec.IvParameterSpec; | ||||||
|  | import javax.crypto.spec.SecretKeySpec; | ||||||
| import java.io.File; | import java.io.File; | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
| import java.nio.charset.StandardCharsets; | import java.nio.charset.StandardCharsets; | ||||||
| import java.security.MessageDigest; | import java.security.MessageDigest; | ||||||
|  | import java.util.Base64; | ||||||
| import java.util.Formatter; | import java.util.Formatter; | ||||||
| import java.util.HashMap; | import java.util.HashMap; | ||||||
| import java.util.Map; | import java.util.Map; | ||||||
| @@ -24,8 +28,8 @@ public class WechatUtil { | |||||||
|     /** |     /** | ||||||
|      * 生成signature |      * 生成signature | ||||||
|      **/ |      **/ | ||||||
|     private static String appid = "wx7cab1155e849fe18"; |     private static String appid = "wx9d1cbc11c8c40ba7"; | ||||||
|     private static String secret = "0263f34d422d24588d6c2df8f09500ab"; |     private static String secret = "38e87cf6251945446e8ac091a0ba9ab2"; | ||||||
|     public AppWechatEntity sign(String url) { |     public AppWechatEntity sign(String url) { | ||||||
|         Map<String, String> ret = new HashMap(); |         Map<String, String> ret = new HashMap(); | ||||||
|         String nonceStr = create_nonce_str(); |         String nonceStr = create_nonce_str(); | ||||||
| @@ -168,6 +172,7 @@ public class WechatUtil { | |||||||
|     private String getAccessTokenData(String url) { |     private String getAccessTokenData(String url) { | ||||||
|         String str = ""; |         String str = ""; | ||||||
|         String result = HttpUtil.get(url, CharsetUtil.CHARSET_UTF_8); |         String result = HttpUtil.get(url, CharsetUtil.CHARSET_UTF_8); | ||||||
|  |         System.out.println("result=============="+result); | ||||||
|         if (StringUtils.isEmpty(result)) |         if (StringUtils.isEmpty(result)) | ||||||
|             return str; |             return str; | ||||||
|         str = parseData("access_token", "expires_in", result); |         str = parseData("access_token", "expires_in", result); | ||||||
| @@ -200,6 +205,20 @@ public class WechatUtil { | |||||||
|         return tokenConent; |         return tokenConent; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 获取appid和session_key | ||||||
|  |      * @param url | ||||||
|  |      * @return | ||||||
|  |      */ | ||||||
|  |     private String getAccessData(String url) { | ||||||
|  |         String str = ""; | ||||||
|  |         String result = HttpUtil.get(url, CharsetUtil.CHARSET_UTF_8); | ||||||
|  |         System.out.println("result=============="+result); | ||||||
|  |         if (StringUtils.isEmpty(result)) | ||||||
|  |             return str; | ||||||
|  |         return result; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     private String byteToHex(final byte[] hash) { |     private String byteToHex(final byte[] hash) { | ||||||
|         Formatter formatter = new Formatter(); |         Formatter formatter = new Formatter(); | ||||||
|         for (byte b : hash) { |         for (byte b : hash) { | ||||||
| @@ -210,6 +229,69 @@ public class WechatUtil { | |||||||
|         return result; |         return result; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 通过code获取微信用户的openid和session_key | ||||||
|  |      * | ||||||
|  |      * @param code      登录凭证code | ||||||
|  |      * @return 包含openid、session_key、unionid的JSON对象 | ||||||
|  |      */ | ||||||
|  |     public JSONObject code2Session(String code) { | ||||||
|  |         try { | ||||||
|  |             System.out.println("appid==============="+appid); | ||||||
|  |             System.out.println("secret================"+secret); | ||||||
|  |             String response = getAccessData("https://api.weixin.qq.com/sns/jscode2session?appid="+appid+"&secret="+secret+"&js_code="+code+"&grant_type=authorization_code"); | ||||||
|  |             JSONObject result = JSONObject.parseObject(response); | ||||||
|  |             // 微信返回错误码处理 | ||||||
|  |             if (result.containsKey("errcode") && result.getInteger("errcode") != 0) { | ||||||
|  |                 throw new RuntimeException("微信授权失败:" + result.getString("errmsg")); | ||||||
|  |             } | ||||||
|  |             return result; | ||||||
|  |         } catch (Exception e) { | ||||||
|  |             throw new RuntimeException("调用微信接口失败:" + e.getMessage()); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 解密微信用户手机号(用户通过 getPhoneNumber 组件授权后返回的加密数据) | ||||||
|  |      * @param encryptedData 微信返回的加密手机号数据 | ||||||
|  |      * @param sessionKey 从 code2Session 接口获取的会话密钥 | ||||||
|  |      * @param iv 微信返回的加密向量(与 encryptedData 配套) | ||||||
|  |      * @return 解密后的 JSON 对象(包含 phoneNumber、purePhoneNumber 等字段) | ||||||
|  |      * @throws RuntimeException 解密失败时抛出 | ||||||
|  |      */ | ||||||
|  |     public JSONObject decryptPhoneNumber(String encryptedData, String sessionKey, String iv) { | ||||||
|  |         try { | ||||||
|  |             // 1. Base64 解码(encryptedData、sessionKey、iv 均为 Base64 编码) | ||||||
|  |             byte[] encryptedDataBytes = Base64.getDecoder().decode(encryptedData); | ||||||
|  |             byte[] sessionKeyBytes = Base64.getDecoder().decode(sessionKey); | ||||||
|  |             byte[] ivBytes = Base64.getDecoder().decode(iv); | ||||||
|  |  | ||||||
|  |             // 2. 验证session_key长度(AES-128要求密钥长度为16字节) | ||||||
|  |             if (sessionKeyBytes.length != 16) { | ||||||
|  |                 throw new RuntimeException("session_key长度错误,应为16字节"); | ||||||
|  |             } | ||||||
|  |             // 验证iv长度(CBC模式下iv长度必须与块大小一致,AES为16字节) | ||||||
|  |             if (ivBytes.length != 16) { | ||||||
|  |                 throw new RuntimeException("iv长度错误,应为16字节"); | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             // 2. 初始化 AES-128-CBC 解密器(使用PKCS5Padding替换PKCS7Padding,两者在AES中效果一致) | ||||||
|  |             Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding"); | ||||||
|  |             SecretKeySpec keySpec = new SecretKeySpec(sessionKeyBytes, "AES"); | ||||||
|  |             IvParameterSpec ivSpec = new IvParameterSpec(ivBytes); | ||||||
|  |             cipher.init(Cipher.DECRYPT_MODE, keySpec, ivSpec); | ||||||
|  |  | ||||||
|  |             // 3. 执行解密并转换为字符串 | ||||||
|  |             byte[] decryptedBytes = cipher.doFinal(encryptedDataBytes); | ||||||
|  |             String decryptedStr = new String(decryptedBytes, StandardCharsets.UTF_8); | ||||||
|  |  | ||||||
|  |             // 4. 解析为 JSON 并返回(包含手机号等信息) | ||||||
|  |             return JSONObject.parseObject(decryptedStr); | ||||||
|  |         } catch (Exception e) { | ||||||
|  |             throw new RuntimeException("解密用户手机号失败:" + e.getMessage(), e); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     private String create_nonce_str() { |     private String create_nonce_str() { | ||||||
|         return IdUtil.simpleUUID(); |         return IdUtil.simpleUUID(); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -0,0 +1,105 @@ | |||||||
|  | package com.ruoyi.cms.util.sensitiveWord; | ||||||
|  |  | ||||||
|  | import com.ruoyi.cms.domain.SensitiveWordData; | ||||||
|  | import com.ruoyi.cms.mapper.SensitiveWordDataMapper; | ||||||
|  | import com.ruoyi.common.core.redis.RedisCache; | ||||||
|  | import org.springframework.beans.factory.annotation.Autowired; | ||||||
|  | import org.springframework.cache.annotation.CacheEvict; | ||||||
|  | import org.springframework.cache.annotation.Cacheable; | ||||||
|  | import org.springframework.stereotype.Component; | ||||||
|  | import javax.annotation.PostConstruct; | ||||||
|  | import java.util.Collections; | ||||||
|  | import java.util.List; | ||||||
|  | import java.util.concurrent.TimeUnit; | ||||||
|  | import java.util.stream.Collectors; | ||||||
|  |  | ||||||
|  | @Component | ||||||
|  | public class SensitiveWordChecker { | ||||||
|  |  | ||||||
|  |     @Autowired | ||||||
|  |     private SensitiveWordDataMapper sensitiveWordDataMapper; | ||||||
|  |  | ||||||
|  |     @Autowired | ||||||
|  |     private SensitiveWordTrie trie; // 注入前缀树 | ||||||
|  |     // 缓存键常量 | ||||||
|  |     private static final String SENSITIVE_WORD_CACHE_KEY = "sensitive:words"; | ||||||
|  |     @Autowired | ||||||
|  |     private RedisCache redisCache; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 项目启动时初始化敏感词库到前缀树 | ||||||
|  |      */ | ||||||
|  |     @PostConstruct | ||||||
|  |     public void init() { | ||||||
|  |         List<String> sensitiveWords = getSensitiveWordsFromCache(); | ||||||
|  |         if (sensitiveWords.isEmpty()) { | ||||||
|  |             // 缓存未命中,从数据库加载 | ||||||
|  |             sensitiveWords = loadSensitiveWordsFromDbAndCache(); | ||||||
|  |         } | ||||||
|  |         // 初始化前缀树 | ||||||
|  |         trie.batchAddWords(sensitiveWords); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 检测文本中的敏感词 | ||||||
|  |      * @param text 待检测文本(如job.getDescription()) | ||||||
|  |      * @return 敏感词列表(空列表表示无敏感词) | ||||||
|  |      */ | ||||||
|  |     public List<String> checkSensitiveWords(String text) { | ||||||
|  |         return trie.findAllSensitiveWords(text); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 从缓存获取敏感词列表 | ||||||
|  |      */ | ||||||
|  |     @Cacheable(value = SENSITIVE_WORD_CACHE_KEY) | ||||||
|  |     public List<String> getSensitiveWordsFromCache() { | ||||||
|  |         // 从Redis获取 | ||||||
|  |         Object cachedWords = redisCache.getCacheObject(SENSITIVE_WORD_CACHE_KEY); | ||||||
|  |         if (cachedWords instanceof List<?>) { | ||||||
|  |             return ((List<?>) cachedWords).stream() | ||||||
|  |                     .filter(obj -> obj instanceof String) | ||||||
|  |                     .map(obj -> (String) obj) | ||||||
|  |                     .collect(Collectors.toList()); | ||||||
|  |         } | ||||||
|  |         return Collections.emptyList(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 从数据库加载敏感词并更新缓存 | ||||||
|  |      */ | ||||||
|  |     public List<String> loadSensitiveWordsFromDbAndCache() { | ||||||
|  |         List<SensitiveWordData> wordList = sensitiveWordDataMapper.selectSensitiveworddataList(new SensitiveWordData()); | ||||||
|  |         List<String> sensitiveWords = wordList.stream() | ||||||
|  |                 .map(SensitiveWordData::getSensitiveWord) | ||||||
|  |                 .collect(Collectors.toList()); | ||||||
|  |         // 缓存有效期设置为24小时,可根据实际需求调整 | ||||||
|  |         redisCache.setCacheObject(SENSITIVE_WORD_CACHE_KEY, sensitiveWords, 24, TimeUnit.HOURS); | ||||||
|  |         return sensitiveWords; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 敏感词更新时清除缓存(需在敏感词管理服务中调用) | ||||||
|  |      */ | ||||||
|  |     @CacheEvict(value = SENSITIVE_WORD_CACHE_KEY, allEntries = true) | ||||||
|  |     public void clearSensitiveWordCache() { | ||||||
|  |         // 清除缓存后可重新加载 | ||||||
|  |         loadSensitiveWordsFromDbAndCache(); | ||||||
|  |         // 重新初始化前缀树 | ||||||
|  |         trie.clear(); | ||||||
|  |         init(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 新增/修改敏感词后更新缓存和前缀树 | ||||||
|  |      */ | ||||||
|  |     public void updateCacheAfterModify() { | ||||||
|  |         // 1. 清除旧缓存 | ||||||
|  |         redisCache.deleteObject(SENSITIVE_WORD_CACHE_KEY); | ||||||
|  |         // 2. 从数据库重新加载最新数据并更新缓存 | ||||||
|  |         List<String> latestWords = loadSensitiveWordsFromDbAndCache(); | ||||||
|  |         // 3. 重建前缀树 | ||||||
|  |         trie.clear(); | ||||||
|  |         trie.batchAddWords(latestWords); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -0,0 +1,97 @@ | |||||||
|  | package com.ruoyi.cms.util.sensitiveWord; | ||||||
|  |  | ||||||
|  | import org.springframework.stereotype.Component; | ||||||
|  |  | ||||||
|  | import java.util.*; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 前缀树(Trie树)节点 | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 前缀树(Trie树)工具类 | ||||||
|  |  */ | ||||||
|  | @Component | ||||||
|  | public class SensitiveWordTrie { | ||||||
|  |     // 根节点(无实际字符) | ||||||
|  |     private final TrieNode root = new TrieNode(); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 向前缀树中添加敏感词 | ||||||
|  |      */ | ||||||
|  |     public void addWord(String word) { | ||||||
|  |         if (word == null || word.isEmpty()) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         TrieNode current = root; | ||||||
|  |         for (char c : word.toCharArray()) { | ||||||
|  |             // 若子节点中不存在该字符,则创建新节点 | ||||||
|  |             current.getChildren().putIfAbsent(c, new TrieNode()); | ||||||
|  |             // 移动到子节点 | ||||||
|  |             current = current.getChildren().get(c); | ||||||
|  |         } | ||||||
|  |         // 标记当前节点为敏感词结尾 | ||||||
|  |         current.setEnd(true); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 检测文本中所有敏感词(去重) | ||||||
|  |      * @param text 待检测文本 | ||||||
|  |      * @return 敏感词列表 | ||||||
|  |      */ | ||||||
|  |     public List<String> findAllSensitiveWords(String text) { | ||||||
|  |         if (text == null || text.isEmpty()) { | ||||||
|  |             return new ArrayList<>(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         Set<String> sensitiveWords = new HashSet<>(); | ||||||
|  |         TrieNode current = root; | ||||||
|  |         StringBuilder currentWord = new StringBuilder(); // 记录当前匹配的字符 | ||||||
|  |  | ||||||
|  |         for (int i = 0; i < text.length(); i++) { | ||||||
|  |             char c = text.charAt(i); | ||||||
|  |  | ||||||
|  |             // 若当前字符不在子节点中,重置匹配状态 | ||||||
|  |             if (!current.getChildren().containsKey(c)) { | ||||||
|  |                 current = root; // 回到根节点 | ||||||
|  |                 currentWord.setLength(0); // 清空当前匹配的字符 | ||||||
|  |                 continue; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             // 匹配到字符,移动到子节点 | ||||||
|  |             current = current.getChildren().get(c); | ||||||
|  |             currentWord.append(c); | ||||||
|  |  | ||||||
|  |             // 若当前节点是敏感词结尾,记录该敏感词 | ||||||
|  |             if (current.isEnd()) { | ||||||
|  |                 sensitiveWords.add(currentWord.toString()); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return new ArrayList<>(sensitiveWords); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 批量添加敏感词到前缀树 | ||||||
|  |      * @param words 敏感词列表 | ||||||
|  |      */ | ||||||
|  |     public void batchAddWords(List<String> words) { | ||||||
|  |         if (words == null || words.isEmpty()) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         // 批量处理比循环单次添加更高效,减少重复判断 | ||||||
|  |         for (String word : words) { | ||||||
|  |             addWord(word); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 清空前缀树所有节点 | ||||||
|  |      */ | ||||||
|  |     public void clear() { | ||||||
|  |         // 清空根节点的子节点映射,达到清空整个前缀树的效果 | ||||||
|  |         root.getChildren().clear(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -0,0 +1,23 @@ | |||||||
|  | package com.ruoyi.cms.util.sensitiveWord; | ||||||
|  |  | ||||||
|  | import java.util.HashMap; | ||||||
|  | import java.util.Map; | ||||||
|  |  | ||||||
|  | class TrieNode { | ||||||
|  |     // 子节点:key=字符,value=子节点 | ||||||
|  |     private final Map<Character, TrieNode> children = new HashMap<>(); | ||||||
|  |     // 标记当前节点是否为敏感词的结尾 | ||||||
|  |     private boolean isEnd = false; | ||||||
|  |  | ||||||
|  |     public Map<Character, TrieNode> getChildren() { | ||||||
|  |         return children; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public boolean isEnd() { | ||||||
|  |         return isEnd; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setEnd(boolean end) { | ||||||
|  |         isEnd = end; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -0,0 +1,45 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||||
|  |  | ||||||
|  | <mapper namespace="com.ruoyi.cms.mapper.AppSkillMapper"> | ||||||
|  |  | ||||||
|  | 	<!-- 可根据自己的需求,是否要使用 --> | ||||||
|  |     <resultMap type="AppSkill" id="AppSkillResult"> | ||||||
|  |         <result property="id" column="id"/> | ||||||
|  |         <result property="userId" column="user_id"/> | ||||||
|  |         <result property="name" column="name"/> | ||||||
|  |         <result property="levels" column="levels"/> | ||||||
|  |         <result property="delFlag" column="del_flag"/> | ||||||
|  |         <result property="createBy" column="create_by"/> | ||||||
|  |         <result property="createTime" column="create_time"/> | ||||||
|  |         <result property="updateBy" column="update_by"/> | ||||||
|  |         <result property="updateTime" column="update_time"/> | ||||||
|  |         <result property="remark" column="remark"/> | ||||||
|  |     </resultMap> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     <sql id="selectAppSkillVo"> | ||||||
|  |         select id, user_id, name, levels, del_flag, create_by, create_time, update_by, update_time, remark from app_skill | ||||||
|  |     </sql> | ||||||
|  |  | ||||||
|  |     <select id="getList" resultType="AppSkill" resultMap="AppSkillResult"> | ||||||
|  |         <include refid="selectAppSkillVo"/> | ||||||
|  |         <where>  del_flag = '0' | ||||||
|  |             <if test="name != null  and name != ''"> and name like concat('%', #{name}, '%')</if> | ||||||
|  |             <if test="levels != null  and levels != ''"> and levels = #{levels}</if> | ||||||
|  |         </where> | ||||||
|  |     </select> | ||||||
|  |  | ||||||
|  |     <insert id="batchInsert" parameterType="java.util.List"> | ||||||
|  |         INSERT INTO app_skill ( | ||||||
|  |         user_id, name, levels, create_by, create_time, del_flag | ||||||
|  |         ) VALUES | ||||||
|  |         <foreach collection="list" item="item" separator=","> | ||||||
|  |             ( | ||||||
|  |             #{item.userId}, #{item.name}, #{item.levels}, | ||||||
|  |             #{item.createBy}, #{item.createTime}, #{item.delFlag} | ||||||
|  |             ) | ||||||
|  |         </foreach> | ||||||
|  |     </insert> | ||||||
|  |  | ||||||
|  | </mapper> | ||||||
| @@ -29,11 +29,12 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | |||||||
|         <result property="jobTitleId"    column="job_title_id"    /> |         <result property="jobTitleId"    column="job_title_id"    /> | ||||||
|         <result property="isRecommend"    column="is_recommend"    /> |         <result property="isRecommend"    column="is_recommend"    /> | ||||||
|         <result property="idCard"    column="id_card"    /> |         <result property="idCard"    column="id_card"    /> | ||||||
|         <result property="hire"    column="hire"    /> |         <result property="workExperience"    column="work_experience"    /> | ||||||
|  |         <result property="isCompanyUser"    column="is_company_user"    /> | ||||||
|     </resultMap> |     </resultMap> | ||||||
|  |  | ||||||
|     <sql id="selectAppUserVo"> |     <sql id="selectAppUserVo"> | ||||||
|         select user_id, name, age, sex, birth_date, education, political_affiliation, phone, avatar, salary_min, salary_max, area, status, del_flag, login_ip, login_date, create_by, create_time, update_by, update_time, remark,job_title_id,is_recommend,id_card,hire from app_user |         select user_id, name, age, sex, birth_date, education, political_affiliation, phone, avatar, salary_min, salary_max, area, status, del_flag, login_ip, login_date, create_by, create_time, update_by, update_time, remark,job_title_id,is_recommend,id_card,work_experience,is_company_user from app_user | ||||||
|     </sql> |     </sql> | ||||||
|  |  | ||||||
|     <select id="selectAppUserList" parameterType="AppUser" resultMap="AppUserResult"> |     <select id="selectAppUserList" parameterType="AppUser" resultMap="AppUserResult"> | ||||||
| @@ -57,10 +58,51 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | |||||||
|             <if test="idCard != null  and idCard != ''"> and id_card like concat('%', CAST(#{idCard} AS VARCHAR), '%')</if> |             <if test="idCard != null  and idCard != ''"> and id_card like concat('%', CAST(#{idCard} AS VARCHAR), '%')</if> | ||||||
|         </where> |         </where> | ||||||
|     </select> |     </select> | ||||||
|     <select id="selectByJobId" resultType="com.ruoyi.cms.domain.AppUser" parameterType="java.lang.Long"> |     <select id="selectByJobId" resultType="com.ruoyi.common.core.domain.entity.AppUser" parameterType="java.lang.Long"> | ||||||
|         SELECT * FROM app_user WHERE user_id IN ( |         SELECT * FROM app_user WHERE user_id IN ( | ||||||
|             select DISTINCT au.USER_ID  from APP_USER au |             select DISTINCT au.USER_ID  from APP_USER au | ||||||
|                                                  INNER JOIN JOB_APPLY ja ON ja.USER_ID  = au.USER_ID |                                                  INNER JOIN JOB_APPLY ja ON ja.USER_ID  = au.USER_ID | ||||||
|             WHERE au.DEL_FLAG = '0' AND ja.DEL_FLAG = '0'  AND ja.JOB_Id = #{jobId}) |             WHERE au.DEL_FLAG = '0' AND ja.DEL_FLAG = '0'  AND ja.JOB_Id = #{jobId}) | ||||||
|     </select> |     </select> | ||||||
|  |  | ||||||
|  |     <select id="selectByOpenid" resultType="com.ruoyi.common.core.domain.entity.AppUser"> | ||||||
|  |         <include refid="selectAppUserVo"/> WHERE DEL_FLAG = '0' and openid=#{openid} LIMIT 1 | ||||||
|  |     </select> | ||||||
|  |  | ||||||
|  |     <insert id="insertSysUserRole" parameterType="java.util.Map"> | ||||||
|  |         insert into sys_user_role (user_id,role_id) values (#{userId},#{roleId}) | ||||||
|  |     </insert> | ||||||
|  |  | ||||||
|  |     <insert id="insertSysUser" parameterType="com.ruoyi.common.core.domain.entity.SysUser" useGeneratedKeys="true" keyProperty="userId"> | ||||||
|  |         insert into sys_user( | ||||||
|  |         <if test="userId != null and userId != 0">user_id,</if> | ||||||
|  |         <if test="deptId != null and deptId != 0">dept_id,</if> | ||||||
|  |         <if test="userName != null and userName != ''">user_name,</if> | ||||||
|  |         <if test="nickName != null and nickName != ''">nick_name,</if> | ||||||
|  |         <if test="email != null and email != ''">email,</if> | ||||||
|  |         <if test="avatar != null and avatar != ''">avatar,</if> | ||||||
|  |         <if test="phonenumber != null and phonenumber != ''">phonenumber,</if> | ||||||
|  |         <if test="sex != null and sex != ''">sex,</if> | ||||||
|  |         <if test="password != null and password != ''">password,</if> | ||||||
|  |         <if test="status != null and status != ''">status,</if> | ||||||
|  |         <if test="createBy != null and createBy != ''">create_by,</if> | ||||||
|  |         <if test="remark != null and remark != ''">remark,</if> | ||||||
|  |         create_time | ||||||
|  |         )values( | ||||||
|  |         <if test="userId != null and userId != ''">#{userId},</if> | ||||||
|  |         <if test="deptId != null and deptId != ''">#{deptId},</if> | ||||||
|  |         <if test="userName != null and userName != ''">#{userName},</if> | ||||||
|  |         <if test="nickName != null and nickName != ''">#{nickName},</if> | ||||||
|  |         <if test="email != null and email != ''">#{email},</if> | ||||||
|  |         <if test="avatar != null and avatar != ''">#{avatar},</if> | ||||||
|  |         <if test="phonenumber != null and phonenumber != ''">#{phonenumber},</if> | ||||||
|  |         <if test="sex != null and sex != ''">#{sex},</if> | ||||||
|  |         <if test="password != null and password != ''">#{password},</if> | ||||||
|  |         <if test="status != null and status != ''">#{status},</if> | ||||||
|  |         <if test="createBy != null and createBy != ''">#{createBy},</if> | ||||||
|  |         <if test="remark != null and remark != ''">#{remark},</if> | ||||||
|  |         sysdate() | ||||||
|  |         ) | ||||||
|  |     </insert> | ||||||
|  |  | ||||||
| </mapper> | </mapper> | ||||||
| @@ -27,7 +27,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | |||||||
|             <if test="userId != null "> and user_id = #{userId}</if> |             <if test="userId != null "> and user_id = #{userId}</if> | ||||||
|         </where> |         </where> | ||||||
|     </select> |     </select> | ||||||
|     <select id="collectionJob" resultType="com.ruoyi.cms.domain.Company"> |     <select id="collectionJob" resultType="com.ruoyi.common.core.domain.entity.Company"> | ||||||
|         select * |         select * | ||||||
|         from company |         from company | ||||||
|         where del_flag = '0' |         where del_flag = '0' | ||||||
|   | |||||||
| @@ -36,4 +36,57 @@ | |||||||
|         </where> |         </where> | ||||||
|     </select> |     </select> | ||||||
|  |  | ||||||
|  |     <insert id="batchInsert" parameterType="java.util.List"> | ||||||
|  |         INSERT INTO company_contact ( | ||||||
|  |         company_id, contact_person, contact_person_phone, | ||||||
|  |         create_by, create_time, del_flag,remark | ||||||
|  |         ) VALUES | ||||||
|  |         <foreach collection="list" item="item" separator=","> | ||||||
|  |             ( | ||||||
|  |             #{item.companyId}, #{item.contactPerson}, #{item.contactPersonPhone}, | ||||||
|  |             #{item.createBy}, #{item.createTime}, #{item.delFlag},#{item.remark} | ||||||
|  |             ) | ||||||
|  |         </foreach> | ||||||
|  |     </insert> | ||||||
|  |  | ||||||
|  |     <update id="batchUpdate" parameterType="java.util.List"> | ||||||
|  |         UPDATE company_contact | ||||||
|  |         SET | ||||||
|  |         contact_person = CASE | ||||||
|  |         <foreach collection="list" item="item" separator=""> | ||||||
|  |             WHEN id = #{item.id} THEN #{item.contactPerson} | ||||||
|  |         </foreach> | ||||||
|  |         ELSE contact_person | ||||||
|  |         END, | ||||||
|  |         contact_person_phone = CASE | ||||||
|  |         <foreach collection="list" item="item" separator=""> | ||||||
|  |             WHEN id = #{item.id} THEN #{item.contactPersonPhone} | ||||||
|  |         </foreach> | ||||||
|  |         ELSE contact_person_phone | ||||||
|  |         END, | ||||||
|  |         update_by = CASE | ||||||
|  |         <foreach collection="list" item="item" separator=""> | ||||||
|  |             WHEN id = #{item.id} THEN #{item.updateBy} | ||||||
|  |         </foreach> | ||||||
|  |         ELSE update_by | ||||||
|  |         END, | ||||||
|  |         update_time = CASE | ||||||
|  |         <foreach collection="list" item="item" separator=""> | ||||||
|  |             WHEN id = #{item.id} THEN NOW() | ||||||
|  |         </foreach> | ||||||
|  |         ELSE update_time | ||||||
|  |         END, | ||||||
|  |         remark = CASE | ||||||
|  |         <foreach collection="list" item="item" separator=""> | ||||||
|  |             WHEN id = #{item.id} THEN #{item.remark} | ||||||
|  |         </foreach> | ||||||
|  |         ELSE remark | ||||||
|  |         END | ||||||
|  |         WHERE | ||||||
|  |         id IN | ||||||
|  |         <foreach collection="list" item="item" open="(" separator="," close=")"> | ||||||
|  |             #{item.id} | ||||||
|  |         </foreach> | ||||||
|  |     </update> | ||||||
|  |  | ||||||
| </mapper> | </mapper> | ||||||
|   | |||||||
| @@ -31,10 +31,17 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | |||||||
|         <result property="notPassReason"    column="not_pass_reason"    /> |         <result property="notPassReason"    column="not_pass_reason"    /> | ||||||
|         <result property="registeredAddress"    column="registered_address"    /> |         <result property="registeredAddress"    column="registered_address"    /> | ||||||
|         <result property="isAbnormal"    column="is_abnormal"    /> |         <result property="isAbnormal"    column="is_abnormal"    /> | ||||||
|  |         <result property="enterpriseType"    column="enterprise_type"    /> | ||||||
|  |         <result property="isImpCompany"    column="is_imp_company"    /> | ||||||
|  |         <result property="impCompanyType"    column="imp_company_type"    /> | ||||||
|  |         <result property="legalPerson"    column="legal_person"    /> | ||||||
|  |         <result property="legalIdCard"    column="legal_id_card"    /> | ||||||
|  |         <result property="legalPhone"    column="legal_phone"    /> | ||||||
|  |  | ||||||
|     </resultMap> |     </resultMap> | ||||||
|  |  | ||||||
|     <sql id="selectCompanyVo"> |     <sql id="selectCompanyVo"> | ||||||
|         select company_id, name, location, industry, scale, del_flag, create_by, create_time, update_by, update_time, remark,code,description,nature,total_recruitment,registered_address,contact_person,contact_person_phone,is_abnormal from company |         select company_id, name, location, industry, scale, del_flag, create_by, create_time, update_by, update_time, remark,code,description,nature,total_recruitment,registered_address,contact_person,contact_person_phone,is_abnormal,not_pass_reason,status,case when status='2' then update_time else null end reject_time,is_imp_company,imp_company_type,enterprise_type,legal_person,legal_id_card,legal_phone from company | ||||||
|     </sql> |     </sql> | ||||||
|         <insert id="batchInsert" parameterType="java.util.List"> |         <insert id="batchInsert" parameterType="java.util.List"> | ||||||
|             INSERT INTO company ( |             INSERT INTO company ( | ||||||
| @@ -61,12 +68,13 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | |||||||
|     <select id="selectCompanyList" parameterType="Company" resultMap="CompanyResult"> |     <select id="selectCompanyList" parameterType="Company" resultMap="CompanyResult"> | ||||||
|         <include refid="selectCompanyVo"/> |         <include refid="selectCompanyVo"/> | ||||||
|         <where>  del_flag = '0' |         <where>  del_flag = '0' | ||||||
|             <if test="name != null  and name != ''"> and name like concat('%', #{name}, '%')</if> |             <if test="name != null  and name != ''"> and name like concat('%', cast(#{name, jdbcType=VARCHAR} as varchar), '%')</if> | ||||||
|             <if test="location != null  and location != ''"> and location = #{location}</if> |             <if test="location != null  and location != ''"> and location = #{location}</if> | ||||||
|             <if test="industry != null  and industry != ''"> and industry = #{industry}</if> |             <if test="industry != null  and industry != ''"> and industry = #{industry}</if> | ||||||
|             <if test="scale != null  and scale != ''"> and scale = #{scale}</if> |             <if test="scale != null  and scale != ''"> and scale = #{scale}</if> | ||||||
|             <if test="nature != null  and nature != ''"> and nature = #{nature}</if> |             <if test="nature != null  and nature != ''"> and nature = #{nature}</if> | ||||||
|             <if test="code != null  and code != ''"> and code = #{code}</if> |             <if test="code != null  and code != ''"> and code = #{code}</if> | ||||||
|  |             <if test="status != null  and status != ''"> and status = #{status}</if> | ||||||
|         </where> |         </where> | ||||||
|     </select> |     </select> | ||||||
|     <select id="label" resultMap="CompanyResult"> |     <select id="label" resultMap="CompanyResult"> | ||||||
| @@ -81,4 +89,18 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | |||||||
|                                                 </if>) |                                                 </if>) | ||||||
|         <if test="companyName != null  and companyName != ''"> and name like concat('%',#{companyName},'%')</if> |         <if test="companyName != null  and companyName != ''"> and name like concat('%',#{companyName},'%')</if> | ||||||
|     </select> |     </select> | ||||||
|  |  | ||||||
|  |     <select id="selectLikeCompanyList" parameterType="Company" resultMap="CompanyResult"> | ||||||
|  |         <include refid="selectCompanyVo"/> | ||||||
|  |         <where>  del_flag = '0' | ||||||
|  |             <if test="name != null  and name != ''"> and name like concat('%', cast(#{name, jdbcType=VARCHAR} as varchar), '%')</if> | ||||||
|  |             <if test="location != null  and location != ''"> and location = #{location}</if> | ||||||
|  |             <if test="industry != null  and industry != ''"> and industry = #{industry}</if> | ||||||
|  |             <if test="scale != null  and scale != ''"> and scale = #{scale}</if> | ||||||
|  |             <if test="nature != null  and nature != ''"> and nature = #{nature}</if> | ||||||
|  |             <if test="code != null  and code != ''"> and code = #{code}</if> | ||||||
|  |             <if test="status != null  and status != ''"> and status = #{status}</if> | ||||||
|  |         </where> | ||||||
|  |         LIMIT 50 | ||||||
|  |     </select> | ||||||
| </mapper> | </mapper> | ||||||
| @@ -0,0 +1,38 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||||
|  |  | ||||||
|  | <mapper namespace="com.ruoyi.cms.mapper.EmployeeConfirmMapper"> | ||||||
|  |  | ||||||
|  | 	<!-- 可根据自己的需求,是否要使用 --> | ||||||
|  |     <resultMap type="EmployeeConfirm" id="EmployeeConfirmResult"> | ||||||
|  |         <result property="id" column="id"/> | ||||||
|  |         <result property="companyId" column="company_id"/> | ||||||
|  |         <result property="contactPerson" column="contact_person"/> | ||||||
|  |         <result property="idCard" column="id_card"/> | ||||||
|  |         <result property="entryDate" column="entry_date"/> | ||||||
|  |         <result property="contactPersonPhone" column="contact_person_phone"/> | ||||||
|  |         <result property="contractTerm" column="contract_term"/> | ||||||
|  |         <result property="delFlag" column="del_flag"/> | ||||||
|  |         <result property="createBy" column="create_by"/> | ||||||
|  |         <result property="createTime" column="create_time"/> | ||||||
|  |         <result property="updateBy" column="update_by"/> | ||||||
|  |         <result property="updateTime" column="update_time"/> | ||||||
|  |         <result property="remark" column="remark"/> | ||||||
|  |     </resultMap> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     <sql id="selectsinosoftVo"> | ||||||
|  |         select id, company_id, contact_person, id_card, entry_date, contact_person_phone, contract_term, del_flag, create_by, create_time, update_by, update_time, remark from employee_confirm | ||||||
|  |     </sql> | ||||||
|  |  | ||||||
|  |     <select id="getEmployeeConfirmList" resultMap="EmployeeConfirmResult" parameterType="EmployeeConfirm"> | ||||||
|  |         <include refid="selectsinosoftVo"/> | ||||||
|  |         <where>  del_flag = '0' | ||||||
|  |             <if test="contactPerson != null  and contactPerson != ''"> and contact_person like concat('%', #{contactPerson}, '%')</if> | ||||||
|  |             <if test="idCard != null  and idCard != ''"> and id_card = #{idCard}</if> | ||||||
|  |             <if test="contactPersonPhone != null  and contactPersonPhone != ''"> and contact_person_phone = #{contactPersonPhone}</if> | ||||||
|  |             <if test="companyId != null  and companyId != ''"> and company_id = #{companyId}</if> | ||||||
|  |         </where> | ||||||
|  |     </select> | ||||||
|  |  | ||||||
|  | </mapper> | ||||||
| @@ -40,10 +40,80 @@ | |||||||
|         ORDER BY ja.create_time DESC |         ORDER BY ja.create_time DESC | ||||||
|     </select> |     </select> | ||||||
|     <select id="candidates" resultType="com.ruoyi.cms.domain.vo.CandidateVO"> |     <select id="candidates" resultType="com.ruoyi.cms.domain.vo.CandidateVO"> | ||||||
|         SELECT au.*,jc.create_time as apply_date,jc.matching_degree |         SELECT au.*,jc.create_time as apply_date,jc.matching_degree,jc.id as applyId | ||||||
|         from job_apply as jc |         from job_apply as jc | ||||||
|                  inner join app_user as au on jc.user_id = au.user_id |                  inner join app_user as au on jc.user_id = au.user_id | ||||||
|         where jc.job_id = #{jobId} and jc.del_flag = '0' and au.del_flag ='0' |         where jc.job_id = #{jobId} and jc.del_flag = '0' and au.del_flag ='0' | ||||||
|     </select> |     </select> | ||||||
|  |  | ||||||
|  |     <select id="trendChart" resultType="java.util.HashMap" parameterType="JobApply"> | ||||||
|  |         select a.job_title as name,count(b.job_id) sl from job a left join job_apply b | ||||||
|  |             on a.job_id=b.job_id where a.del_flag='0' and b.del_flag='0' | ||||||
|  |          <if test="jobId!=null and jobId!=''"> | ||||||
|  |              and a.job_id=#{jobId} | ||||||
|  |          </if> | ||||||
|  |           group by a.job_title | ||||||
|  |     </select> | ||||||
|  |  | ||||||
|  |     <sql id="selectAppUserVo"> | ||||||
|  |         select user_id, name, age, sex, birth_date, education, political_affiliation, phone, avatar, salary_min, salary_max, area, status, del_flag, login_ip, login_date, create_by, create_time, update_by, update_time, remark,job_title_id,is_recommend,id_card,hire from app_user | ||||||
|  |     </sql> | ||||||
|  |  | ||||||
|  |     <select id="selectAppUserList" parameterType="com.ruoyi.cms.domain.Job" resultType="com.ruoyi.cms.domain.vo.CandidateVO"> | ||||||
|  |         select b.job_title jobName,l.name companyName,e.* from job_apply a | ||||||
|  |                 INNER join job b on a.job_id=b.job_id and b.del_flag='0' | ||||||
|  |                 INNER join app_user e on a.user_id =e.user_id and e.del_flag='0' | ||||||
|  |                 INNER join company l on b.company_id =l.company_id and l.del_flag='0' | ||||||
|  |         where a.del_flag='0' and a.hire='0' | ||||||
|  |         <if test="jobTitle != null  and jobTitle != ''"> and b.job_title like concat('%', cast(#{jobTitle, jdbcType=VARCHAR} as varchar), '%')</if> | ||||||
|  |         <if test="education != null  and education != ''"> and b.education = #{education}</if> | ||||||
|  |         <if test="experience != null  and experience != ''"> and b.experience = #{experience}</if> | ||||||
|  |         <if test="companyName != null  and companyName != ''"> and b.company_name like concat('%', cast(#{companyName, jdbcType=VARCHAR} as varchar), '%')</if> | ||||||
|  |         <if test="jobLocation != null  and jobLocation != ''"> and b.job_location = #{jobLocation}</if> | ||||||
|  |         <if test="postingDate != null and postingDate!=''"> and b.posting_date = #{postingDate}</if> | ||||||
|  |         <if test="vacancies != null "> and b.vacancies = #{vacancies}</if> | ||||||
|  |         <if test="latitude != null "> and b.latitude = #{latitude}</if> | ||||||
|  |         <if test="longitude != null "> and b.longitude = #{longitude}</if> | ||||||
|  |         <if test="view != null "> and b."view" = #{view}</if> | ||||||
|  |         <if test="companyId != null "> and b.company_id = #{companyId}</if> | ||||||
|  |         <if test="isHot != null "> and b.is_hot = #{isHot}</if> | ||||||
|  |         <if test="applyNum != null "> and b.apply_num = #{applyNum}</if> | ||||||
|  |         <if test="code != null "> and b.company_id in(select company_id from company where code=#{code})</if> | ||||||
|  |         <if test="compensation!=null "> | ||||||
|  |             <if test="compensation==0 "> | ||||||
|  |                 and b.min_salary < 1750 | ||||||
|  |             </if> | ||||||
|  |             <if test="compensation==1 "> | ||||||
|  |                 and b.max_salary < 2000 and b.min_salary >= 1750 | ||||||
|  |             </if> | ||||||
|  |             <if test="compensation==2 "> | ||||||
|  |                 and b.max_salary < 3000 and b.min_salary >= 2000 | ||||||
|  |             </if> | ||||||
|  |             <if test="compensation==3 "> | ||||||
|  |                 and b.max_salary < 4000 and b.min_salary >= 3000 | ||||||
|  |             </if> | ||||||
|  |             <if test="compensation==4 "> | ||||||
|  |                 and b.max_salary < 5000 and b.min_salary >= 4000 | ||||||
|  |             </if> | ||||||
|  |             <if test="compensation==5 "> | ||||||
|  |                 and b.min_salary > 5000 | ||||||
|  |             </if> | ||||||
|  |         </if> | ||||||
|  |     </select> | ||||||
|  |  | ||||||
|  |     <select id="selectApplyJobUserList" parameterType="com.ruoyi.common.core.domain.entity.AppUser" resultType="com.ruoyi.cms.domain.vo.CandidateVO"> | ||||||
|  |         select b.job_title jobName,l.name companyName,e.* from job_apply a | ||||||
|  |         INNER join job b on a.job_id=b.job_id and b.del_flag='0' | ||||||
|  |         INNER join app_user e on a.user_id =e.user_id and e.del_flag='0' | ||||||
|  |         INNER join company l on b.company_id =l.company_id and l.del_flag='0' | ||||||
|  |         where a.del_flag='0' | ||||||
|  |         <if test="company != null and company.jobTitle != null  and company.jobTitle != ''"> and b.job_title like concat('%', cast(#{company.jobTitle, jdbcType=VARCHAR} as varchar), '%')</if> | ||||||
|  |         <if test="company != null and company.education != null  and company.education != ''"> and b.education = #{company.education}</if> | ||||||
|  |         <if test="company != null and company.experience != null  and company.experience != ''"> and b.experience = #{company.experience}</if> | ||||||
|  |         <if test="company != null and company.companyName != null  and company.companyName != ''"> and b.company_name like concat('%', cast(#{company.companyName, jdbcType=VARCHAR} as varchar), '%')</if> | ||||||
|  |         <if test="company != null and company.companyId != null "> and b.company_id = #{company.companyId}</if> | ||||||
|  |         <if test="company != null and company.code != null "> and l.code =#{company.code}</if> | ||||||
|  |         <if test="name != null and name != '' "> and b.job_title like concat('%', cast(#{name, jdbcType=VARCHAR} as varchar), '%')</if> | ||||||
|  |     </select> | ||||||
|  |  | ||||||
| </mapper> | </mapper> | ||||||
| @@ -42,4 +42,17 @@ | |||||||
|         </where> |         </where> | ||||||
|     </select> |     </select> | ||||||
|  |  | ||||||
|  |     <insert id="batchInsert" parameterType="java.util.List"> | ||||||
|  |         INSERT INTO job_contact ( | ||||||
|  |         job_id, contact_person, contact_person_phone,position, | ||||||
|  |         create_by, create_time, del_flag,remark | ||||||
|  |         ) VALUES | ||||||
|  |         <foreach collection="list" item="item" separator=","> | ||||||
|  |             ( | ||||||
|  |             #{item.jobId}, #{item.contactPerson}, #{item.contactPersonPhone},#{item.position}, | ||||||
|  |             #{item.createBy}, #{item.createTime}, #{item.delFlag},#{item.remark} | ||||||
|  |             ) | ||||||
|  |         </foreach> | ||||||
|  |     </insert> | ||||||
|  |  | ||||||
| </mapper> | </mapper> | ||||||
|   | |||||||
| @@ -125,7 +125,7 @@ | |||||||
|             <if test="maxSalary != null "> and max_salary = #{maxSalary}</if> |             <if test="maxSalary != null "> and max_salary = #{maxSalary}</if> | ||||||
|             <if test="education != null  and education != ''"> and education = #{education}</if> |             <if test="education != null  and education != ''"> and education = #{education}</if> | ||||||
|             <if test="experience != null  and experience != ''"> and experience = #{experience}</if> |             <if test="experience != null  and experience != ''"> and experience = #{experience}</if> | ||||||
|             <if test="companyName != null  and companyName != ''"> and company_name like concat('%', #{companyName}, '%')</if> |             <if test="companyName != null  and companyName != ''"> and company_name like concat('%', cast(#{companyName, jdbcType=VARCHAR} as varchar), '%')</if> | ||||||
|             <if test="jobLocation != null  and jobLocation != ''"> and job_location = #{jobLocation}</if> |             <if test="jobLocation != null  and jobLocation != ''"> and job_location = #{jobLocation}</if> | ||||||
|             <if test="postingDate != null and postingDate!=''"> and posting_date = #{postingDate}</if> |             <if test="postingDate != null and postingDate!=''"> and posting_date = #{postingDate}</if> | ||||||
|             <if test="vacancies != null "> and vacancies = #{vacancies}</if> |             <if test="vacancies != null "> and vacancies = #{vacancies}</if> | ||||||
| @@ -167,7 +167,7 @@ | |||||||
|             <if test="maxSalary != null "> and max_salary = #{maxSalary}</if> |             <if test="maxSalary != null "> and max_salary = #{maxSalary}</if> | ||||||
|             <if test="education != null  and education != ''"> and education = #{education}</if> |             <if test="education != null  and education != ''"> and education = #{education}</if> | ||||||
|             <if test="experience != null  and experience != ''"> and experience = #{experience}</if> |             <if test="experience != null  and experience != ''"> and experience = #{experience}</if> | ||||||
|             <if test="companyName != null  and companyName != ''"> and company_name like concat('%', #{companyName}, '%')</if> |             <if test="companyName != null  and companyName != ''"> and company_name like concat('%', cast(#{companyName, jdbcType=VARCHAR} as varchar), '%')</if> | ||||||
|             <if test="jobLocation != null  and jobLocation != ''"> and job_location = #{jobLocation}</if> |             <if test="jobLocation != null  and jobLocation != ''"> and job_location = #{jobLocation}</if> | ||||||
|             <if test="postingDate != null and postingDate!='' "> and posting_date = #{postingDate}</if> |             <if test="postingDate != null and postingDate!='' "> and posting_date = #{postingDate}</if> | ||||||
|             <if test="vacancies != null "> and vacancies = #{vacancies}</if> |             <if test="vacancies != null "> and vacancies = #{vacancies}</if> | ||||||
| @@ -194,7 +194,7 @@ | |||||||
|                 Collect_time, ClearFlag, Province, City, County, importdate, YearMonth, |                 Collect_time, ClearFlag, Province, City, County, importdate, YearMonth, | ||||||
|                 IsRepeat, latitude, longitude,Std_class as JobCategory from row_work |                 IsRepeat, latitude, longitude,Std_class as JobCategory from row_work | ||||||
|     </select> |     </select> | ||||||
|     <select id="selectRowCompany" resultType="com.ruoyi.cms.domain.Company"> |     <select id="selectRowCompany" resultType="com.ruoyi.common.core.domain.entity.Company"> | ||||||
|         SELECT * |         SELECT * | ||||||
|         FROM ( |         FROM ( | ||||||
|                  SELECT |                  SELECT | ||||||
| @@ -215,7 +215,7 @@ | |||||||
|             ) |             ) | ||||||
|     </select> |     </select> | ||||||
|     <select id="selectAllJob" resultType="com.ruoyi.cms.domain.Job"> |     <select id="selectAllJob" resultType="com.ruoyi.cms.domain.Job"> | ||||||
|         SELECT j.*,c.industry,c.scale,c.nature as company_nature FROM job as j |         SELECT j.*,c.industry,c.scale,c.nature as company_nature,c.code FROM job as j | ||||||
|         left join company as c on c.company_id = j.company_id limit #{offset},#{batchSize} |         left join company as c on c.company_id = j.company_id limit #{offset},#{batchSize} | ||||||
|     </select> |     </select> | ||||||
|     <select id="selectAllInsertRowWork" resultType="com.ruoyi.cms.domain.RowWork"> |     <select id="selectAllInsertRowWork" resultType="com.ruoyi.cms.domain.RowWork"> | ||||||
| @@ -254,4 +254,13 @@ | |||||||
|                 left join  qd.bussiness_dict_data as ac on ac.dict_type = 'scale' and ac.dict_value = c.scale |                 left join  qd.bussiness_dict_data as ac on ac.dict_type = 'scale' and ac.dict_value = c.scale | ||||||
|         where job_id  =#{jobId} |         where job_id  =#{jobId} | ||||||
|     </select> |     </select> | ||||||
|  |  | ||||||
|  |     <sql id="selectAppUserResult"> | ||||||
|  |         select a.user_id, a.name, a.age, a.sex, a.birth_date, a.education, a.political_affiliation, a.phone, a.avatar, a.salary_min, a.salary_max, a.area, a.status, a.del_flag, a.login_ip, a.login_date, a.create_by, a.create_time, a.update_by, a.update_time, a.remark,a.job_title_id,a.is_recommend,a.id_card,a.work_experience,a.is_company_user from job_apply e | ||||||
|  |     </sql> | ||||||
|  |  | ||||||
|  |     <select id="selectApplyJobUserList" resultType="com.ruoyi.common.core.domain.entity.AppUser"> | ||||||
|  |         <include refid="selectAppUserResult"/>inner join app_user a on e.user_id =a.user_id and a.del_flag='0' | ||||||
|  |         where e.del_flag='0' and e.job_id=#{jobId} | ||||||
|  |     </select> | ||||||
| </mapper> | </mapper> | ||||||
| @@ -0,0 +1,40 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||||
|  |  | ||||||
|  | <mapper namespace="com.ruoyi.cms.mapper.SensitiveWordDataMapper"> | ||||||
|  |  | ||||||
|  | 	<!-- 可根据自己的需求,是否要使用 --> | ||||||
|  |     <resultMap type="SensitiveWordData" id="sensitiveWordDataResult"> | ||||||
|  |         <result property="id" column="id"/> | ||||||
|  |         <result property="sensitiveWord" column="sensitive_word"/> | ||||||
|  |         <result property="type" column="type"/> | ||||||
|  |         <result property="delFlag" column="del_flag"/> | ||||||
|  |         <result property="createBy" column="create_by"/> | ||||||
|  |         <result property="createTime" column="create_time"/> | ||||||
|  |         <result property="updateBy" column="update_by"/> | ||||||
|  |         <result property="updateTime" column="update_time"/> | ||||||
|  |         <result property="remark" column="remark"/> | ||||||
|  |     </resultMap> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     <sql id="sensitiveWordDataVo"> | ||||||
|  |         select id, sensitive_word, type, del_flag, create_by, create_time, update_by, update_time, remark from sensitive_word_data | ||||||
|  |     </sql> | ||||||
|  |  | ||||||
|  |     <select id="selectSensitiveworddataList" resultMap="sensitiveWordDataResult" parameterType="SensitiveWordData"> | ||||||
|  |         <include refid="sensitiveWordDataVo"/> | ||||||
|  |         <where>  del_flag = '0' | ||||||
|  |             <if test="sensitiveWord != null  and sensitiveWord != ''"> and sensitive_word like concat('%', #{sensitiveWord}, '%')</if> | ||||||
|  |             <if test="type != null  and type != ''"> and type = #{type}</if> | ||||||
|  |         </where> | ||||||
|  |     </select> | ||||||
|  |  | ||||||
|  |     <insert id="batchInsert" parameterType="java.util.List"> | ||||||
|  |         INSERT INTO sensitive_word_data (sensitive_word, type, create_time,create_by,del_flag,remark) | ||||||
|  |         VALUES | ||||||
|  |         <foreach collection="list" item="item" separator=","> | ||||||
|  |             (#{item.sensitiveWord}, #{item.type}, #{item.createTime},#{item.createBy},#{item.delFlag},#{item.remark}) | ||||||
|  |         </foreach> | ||||||
|  |     </insert> | ||||||
|  |  | ||||||
|  | </mapper> | ||||||
| @@ -0,0 +1,51 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||||
|  |  | ||||||
|  | <mapper namespace="com.ruoyi.cms.mapper.UserWorkExperiencesMapper"> | ||||||
|  |  | ||||||
|  | 	<!-- 可根据自己的需求,是否要使用 --> | ||||||
|  |     <resultMap type="userWorkExperiences" id="userWorkExperiencesResult"> | ||||||
|  |         <result property="id" column="id"/> | ||||||
|  |         <result property="companyName" column="company_name"/> | ||||||
|  |         <result property="position" column="position"/> | ||||||
|  |         <result property="userId" column="user_id"/> | ||||||
|  |         <result property="startDate" column="start_date"/> | ||||||
|  |         <result property="endDate" column="end_date"/> | ||||||
|  |         <result property="description" column="description"/> | ||||||
|  |         <result property="delFlag" column="del_flag"/> | ||||||
|  |         <result property="createBy" column="create_by"/> | ||||||
|  |         <result property="createTime" column="create_time"/> | ||||||
|  |         <result property="updateBy" column="update_by"/> | ||||||
|  |         <result property="updateTime" column="update_time"/> | ||||||
|  |         <result property="remark" column="remark"/> | ||||||
|  |     </resultMap> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     <sql id="selectWorkExperiencesVo"> | ||||||
|  |         select id, company_name, position, user_id, start_date, end_date, description, del_flag, create_by, create_time, update_by, update_time, remark from user_work_experiences | ||||||
|  |     </sql> | ||||||
|  |  | ||||||
|  |     <select id="getWorkExperiencesList" resultMap="userWorkExperiencesResult" parameterType="userWorkExperiences"> | ||||||
|  |         <include refid="selectWorkExperiencesVo"/> | ||||||
|  |         <where>  del_flag = '0' | ||||||
|  |             <if test="companyName != null  and companyName != ''"> and company_name like concat('%', #{companyName}, '%')</if> | ||||||
|  |             <if test="position != null  and position != ''"> and position = #{position}</if> | ||||||
|  |             <if test="description != null  and description != ''"> and description = #{description}</if> | ||||||
|  |             <if test="userId != null  and userId != ''"> and user_id = #{userId}</if> | ||||||
|  |         </where> | ||||||
|  |     </select> | ||||||
|  |  | ||||||
|  |     <insert id="batchInsert" parameterType="java.util.List"> | ||||||
|  |         INSERT INTO user_work_experiences ( | ||||||
|  |         company_name, position, user_id, start_date, end_date, description, | ||||||
|  |         create_by, create_time, del_flag,remark | ||||||
|  |         ) VALUES | ||||||
|  |         <foreach collection="list" item="item" separator=","> | ||||||
|  |             ( | ||||||
|  |             #{item.companyName}, #{item.position}, #{item.userId},#{item.startDate},#{item.endDate}, | ||||||
|  |             #{item.description},#{item.createBy}, #{item.createTime}, #{item.delFlag},#{item.remark} | ||||||
|  |             ) | ||||||
|  |         </foreach> | ||||||
|  |     </insert> | ||||||
|  |  | ||||||
|  | </mapper> | ||||||
| @@ -11,11 +11,12 @@ public class CacheConstants | |||||||
|      * 登录用户 redis key |      * 登录用户 redis key | ||||||
|      */ |      */ | ||||||
|     public static final String LOGIN_TOKEN_KEY = "login_tokens:"; |     public static final String LOGIN_TOKEN_KEY = "login_tokens:"; | ||||||
|  |     public static final String SITE_LOGIN_TOKEN_KEY = "site_login_tokens:"; | ||||||
|     /** |     /** | ||||||
|      * 验证码 redis key |      * 验证码 redis key | ||||||
|      */ |      */ | ||||||
|     public static final String CAPTCHA_CODE_KEY = "captcha_codes:"; |     public static final String CAPTCHA_CODE_KEY = "captcha_codes:"; | ||||||
|  |     public static final String SMG_CODE_KEY = "smg_codes:"; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 参数管理 cache key |      * 参数管理 cache key | ||||||
| @@ -42,4 +43,5 @@ public class CacheConstants | |||||||
|      * 登录账户密码错误次数 redis key |      * 登录账户密码错误次数 redis key | ||||||
|      */ |      */ | ||||||
|     public static final String PWD_ERR_CNT_KEY = "pwd_err_cnt:"; |     public static final String PWD_ERR_CNT_KEY = "pwd_err_cnt:"; | ||||||
|  |     public static final String PWD_ERR_CNT_KEY_SITE = "site:pwd_err_cnt:"; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -109,6 +109,10 @@ public class Constants | |||||||
|      * 令牌前缀 |      * 令牌前缀 | ||||||
|      */ |      */ | ||||||
|     public static final String LOGIN_USER_KEY = "login_user_key"; |     public static final String LOGIN_USER_KEY = "login_user_key"; | ||||||
|  |     public static final String APP_LOGIN_USER_KEY = "app_login_user_key"; | ||||||
|  |     public static final String LOGIN_USER_ID = "login_user_id"; | ||||||
|  |     public static final String APP_LOGIN_USER_ID = "login_user_id"; | ||||||
|  |     public static final String EXP = "exp"; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 用户ID |      * 用户ID | ||||||
|   | |||||||
| @@ -50,7 +50,7 @@ public class BaseEntity implements Serializable | |||||||
|     /** 更新时间 */ |     /** 更新时间 */ | ||||||
| //    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") | //    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss") | ||||||
|     @TableField(fill = FieldFill.INSERT_UPDATE) |     @TableField(fill = FieldFill.INSERT_UPDATE) | ||||||
|     @JsonIgnore | //    @JsonIgnore | ||||||
|     @ApiModelProperty(hidden = true) |     @ApiModelProperty(hidden = true) | ||||||
|     private String updateTime; |     private String updateTime; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -0,0 +1,46 @@ | |||||||
|  | package com.ruoyi.common.core.domain.entity; | ||||||
|  |  | ||||||
|  | import com.baomidou.mybatisplus.annotation.IdType; | ||||||
|  | import com.baomidou.mybatisplus.annotation.TableField; | ||||||
|  | import com.baomidou.mybatisplus.annotation.TableId; | ||||||
|  | import com.baomidou.mybatisplus.annotation.TableName; | ||||||
|  |  | ||||||
|  | import com.ruoyi.common.core.domain.BaseEntity; | ||||||
|  | import io.swagger.annotations.ApiModelProperty; | ||||||
|  | import lombok.Data; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 用户技能信息 | ||||||
|  |  *  | ||||||
|  |  * @author  | ||||||
|  |  * @email  | ||||||
|  |  * @date 2025-10-21 12:22:09 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | @TableName("app_skill") | ||||||
|  | public class AppSkill extends BaseEntity { | ||||||
|  | 	@TableField(exist = false) | ||||||
|  | 	private static final long serialVersionUID = 1L; | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * 主键id | ||||||
|  | 	 */ | ||||||
|  | 	@TableId(value = "id",type = IdType.AUTO) | ||||||
|  | 	@ApiModelProperty("用户ID") | ||||||
|  | 	private Long id; | ||||||
|  | 	/** | ||||||
|  | 	 * 用户id | ||||||
|  | 	 */ | ||||||
|  | 	@ApiModelProperty("用户id") | ||||||
|  | 	private Long userId; | ||||||
|  | 	/** | ||||||
|  | 	 * 技能名称 | ||||||
|  | 	 */ | ||||||
|  | 	@ApiModelProperty("技能名称") | ||||||
|  | 	private String name; | ||||||
|  | 	/** | ||||||
|  | 	 * 技能等级 | ||||||
|  | 	 */ | ||||||
|  | 	@ApiModelProperty("技能等级") | ||||||
|  | 	private String levels; | ||||||
|  | } | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| package com.ruoyi.cms.domain; | package com.ruoyi.common.core.domain.entity; | ||||||
| 
 | 
 | ||||||
| import java.util.Date; | import java.util.Date; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| @@ -104,9 +104,38 @@ public class AppUser extends BaseEntity | |||||||
|     @ApiModelProperty("身份证") |     @ApiModelProperty("身份证") | ||||||
|     private String idCard; |     private String idCard; | ||||||
| 
 | 
 | ||||||
|     @ApiModelProperty("是否录用 0录用,1未录用") |     /** | ||||||
|     private String hire; |      * 是否企业用户 0是,1否改为(0企业,1求职者,2网格员) | ||||||
| 
 |      */ | ||||||
|     @ApiModelProperty("是否企业用户 0是,1否") |     @ApiModelProperty("app角色:0企业,1求职者,2网格员 3内部政府人员") | ||||||
|     private String isCompanyUser; |     private String isCompanyUser; | ||||||
|  | 
 | ||||||
|  |     @TableField(exist = false) | ||||||
|  |     @ApiModelProperty("密码") | ||||||
|  |     private String password; | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * 微信小程序用户唯一标识 | ||||||
|  |      */ | ||||||
|  |     @ApiModelProperty("微信小程序用户唯一标识") | ||||||
|  |     private String openid; | ||||||
|  |     /** | ||||||
|  |      * 微信开放平台全局标识 | ||||||
|  |      */ | ||||||
|  |     @ApiModelProperty("微信开放平台全局标识") | ||||||
|  |     private String unionid; | ||||||
|  | 
 | ||||||
|  |     @ApiModelProperty("民族") | ||||||
|  |     private String nation; | ||||||
|  | 
 | ||||||
|  |     @ApiModelProperty("工作经验") | ||||||
|  |     private String workExperience; | ||||||
|  | 
 | ||||||
|  |     @TableField(exist = false) | ||||||
|  |     @ApiModelProperty("公司信息") | ||||||
|  |     private Company company; | ||||||
|  | 
 | ||||||
|  |     @TableField(exist = false) | ||||||
|  |     @ApiModelProperty("工作经历列表") | ||||||
|  |     private List<UserWorkExperiences> experiencesList; | ||||||
| } | } | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| package com.ruoyi.cms.domain; | package com.ruoyi.common.core.domain.entity; | ||||||
| 
 | 
 | ||||||
| import com.baomidou.mybatisplus.annotation.*; | import com.baomidou.mybatisplus.annotation.*; | ||||||
| import lombok.Data; | import lombok.Data; | ||||||
| @@ -50,7 +50,7 @@ public class Company extends BaseEntity | |||||||
|     @ApiModelProperty("单位介绍") |     @ApiModelProperty("单位介绍") | ||||||
|     private String description; |     private String description; | ||||||
| 
 | 
 | ||||||
|     @Excel(name = "性质") |     @Excel(name = "性质-已改为企业类型") | ||||||
|     @ApiModelProperty("性质") |     @ApiModelProperty("性质") | ||||||
|     private String nature; |     private String nature; | ||||||
| 
 | 
 | ||||||
| @@ -101,4 +101,26 @@ public class Company extends BaseEntity | |||||||
| 
 | 
 | ||||||
|     @ApiModelProperty("是否异常") |     @ApiModelProperty("是否异常") | ||||||
|     private String isAbnormal; |     private String isAbnormal; | ||||||
|  | 
 | ||||||
|  |     @TableField(exist = false) | ||||||
|  |     @ApiModelProperty("驳回时间") | ||||||
|  |     private String rejectTime; | ||||||
|  | 
 | ||||||
|  |     @ApiModelProperty("是否本地重点企业") | ||||||
|  |     private String isImpCompany; | ||||||
|  | 
 | ||||||
|  |     @ApiModelProperty("本地重点发展产业") | ||||||
|  |     private String impCompanyType; | ||||||
|  | 
 | ||||||
|  |     @ApiModelProperty("是否是就业见习基地 0是 1否") | ||||||
|  |     private String enterpriseType; | ||||||
|  | 
 | ||||||
|  |     @ApiModelProperty("法人姓名") | ||||||
|  |     private String legalPerson; | ||||||
|  | 
 | ||||||
|  |     @ApiModelProperty("法人身份证") | ||||||
|  |     private String legalIdCard; | ||||||
|  | 
 | ||||||
|  |     @ApiModelProperty("法人联系方式") | ||||||
|  |     private String legalPhone; | ||||||
| } | } | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| package com.ruoyi.cms.domain; | package com.ruoyi.common.core.domain.entity; | ||||||
| 
 | 
 | ||||||
| import com.baomidou.mybatisplus.annotation.IdType; | import com.baomidou.mybatisplus.annotation.IdType; | ||||||
| import com.baomidou.mybatisplus.annotation.TableField; | import com.baomidou.mybatisplus.annotation.TableField; | ||||||
| @@ -70,6 +70,9 @@ public class SysUser extends BaseEntity | |||||||
|     @Excel(name = "最后登录时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss", type = Type.EXPORT) |     @Excel(name = "最后登录时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss", type = Type.EXPORT) | ||||||
|     private Date loginDate; |     private Date loginDate; | ||||||
|  |  | ||||||
|  |     @Excel(name = "身份证/信用代码") | ||||||
|  |     private String idCard; | ||||||
|  |  | ||||||
|     /** 部门对象 */ |     /** 部门对象 */ | ||||||
|     @Excels({ |     @Excels({ | ||||||
|         @Excel(name = "部门名称", targetAttr = "deptName", type = Type.EXPORT), |         @Excel(name = "部门名称", targetAttr = "deptName", type = Type.EXPORT), | ||||||
| @@ -297,6 +300,14 @@ public class SysUser extends BaseEntity | |||||||
|         this.roleId = roleId; |         this.roleId = roleId; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public String getIdCard() { | ||||||
|  |         return idCard; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setIdCard(String idCard) { | ||||||
|  |         this.idCard = idCard; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public String toString() { |     public String toString() { | ||||||
|         return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) |         return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) | ||||||
| @@ -319,6 +330,7 @@ public class SysUser extends BaseEntity | |||||||
|             .append("updateTime", getUpdateTime()) |             .append("updateTime", getUpdateTime()) | ||||||
|             .append("remark", getRemark()) |             .append("remark", getRemark()) | ||||||
|             .append("dept", getDept()) |             .append("dept", getDept()) | ||||||
|  |             .append("idCard", getIdCard()) | ||||||
|             .toString(); |             .toString(); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,63 @@ | |||||||
|  | package com.ruoyi.common.core.domain.entity; | ||||||
|  |  | ||||||
|  | import com.baomidou.mybatisplus.annotation.IdType; | ||||||
|  | import com.baomidou.mybatisplus.annotation.TableField; | ||||||
|  | import com.baomidou.mybatisplus.annotation.TableId; | ||||||
|  | import com.baomidou.mybatisplus.annotation.TableName; | ||||||
|  |  | ||||||
|  | import com.ruoyi.common.core.domain.BaseEntity; | ||||||
|  | import io.swagger.annotations.ApiModelProperty; | ||||||
|  | import lombok.Data; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 用户工作经历表 | ||||||
|  |  *  | ||||||
|  |  * @author  | ||||||
|  |  * @email  | ||||||
|  |  * @date 2025-10-10 16:26:26 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | @TableName("user_work_experiences") | ||||||
|  | public class UserWorkExperiences extends BaseEntity { | ||||||
|  |  | ||||||
|  | 	@TableField(exist = false) | ||||||
|  | 	private static final long serialVersionUID = 1L; | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * 主键id | ||||||
|  | 	 */ | ||||||
|  | 	@TableId(value = "id",type = IdType.AUTO) | ||||||
|  | 	@ApiModelProperty("id") | ||||||
|  | 	private Long id; | ||||||
|  | 	/** | ||||||
|  | 	 * 公司名称 | ||||||
|  | 	 */ | ||||||
|  | 	@ApiModelProperty("公司名称") | ||||||
|  | 	private String companyName; | ||||||
|  | 	/** | ||||||
|  | 	 * 职务 | ||||||
|  | 	 */ | ||||||
|  | 	@ApiModelProperty("职务") | ||||||
|  | 	private String position; | ||||||
|  | 	/** | ||||||
|  | 	 * 用户id | ||||||
|  | 	 */ | ||||||
|  | 	@ApiModelProperty("用户id") | ||||||
|  | 	private Long userId; | ||||||
|  | 	/** | ||||||
|  | 	 * 开始时间 | ||||||
|  | 	 */ | ||||||
|  | 	@ApiModelProperty("开始时间") | ||||||
|  | 	private String startDate; | ||||||
|  | 	/** | ||||||
|  | 	 * 截至时间 | ||||||
|  | 	 */ | ||||||
|  | 	@ApiModelProperty("截至时间") | ||||||
|  | 	private String endDate; | ||||||
|  | 	/** | ||||||
|  | 	 * 描述 | ||||||
|  | 	 */ | ||||||
|  | 	@ApiModelProperty("描述") | ||||||
|  | 	private String description; | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -26,6 +26,18 @@ public class LoginBody | |||||||
|      * 唯一标识 |      * 唯一标识 | ||||||
|      */ |      */ | ||||||
|     private String uuid; |     private String uuid; | ||||||
|  |     /** | ||||||
|  |      * 微信加密的手机号数据 | ||||||
|  |      */ | ||||||
|  |     private String encryptedData; | ||||||
|  |     /** | ||||||
|  |      * 加密向量 | ||||||
|  |      */ | ||||||
|  |     private String iv; | ||||||
|  |     /** | ||||||
|  |      * 0企业,1求职者 | ||||||
|  |      */ | ||||||
|  |     private String userType; | ||||||
|  |  | ||||||
|     public String getUsername() |     public String getUsername() | ||||||
|     { |     { | ||||||
| @@ -66,4 +78,28 @@ public class LoginBody | |||||||
|     { |     { | ||||||
|         this.uuid = uuid; |         this.uuid = uuid; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public String getEncryptedData() { | ||||||
|  |         return encryptedData; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setEncryptedData(String encryptedData) { | ||||||
|  |         this.encryptedData = encryptedData; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public String getIv() { | ||||||
|  |         return iv; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setIv(String iv) { | ||||||
|  |         this.iv = iv; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public String getUserType() { | ||||||
|  |         return userType; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setUserType(String userType) { | ||||||
|  |         this.userType = userType; | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,226 @@ | |||||||
|  | package com.ruoyi.common.core.domain.model; | ||||||
|  |  | ||||||
|  | import com.alibaba.fastjson2.annotation.JSONField; | ||||||
|  | import com.ruoyi.common.core.domain.entity.AppUser; | ||||||
|  | import org.springframework.security.core.GrantedAuthority; | ||||||
|  | import org.springframework.security.core.userdetails.UserDetails; | ||||||
|  |  | ||||||
|  | import java.util.Collection; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 登录用户身份权限 | ||||||
|  |  *  | ||||||
|  |  * @author ruoyi | ||||||
|  |  */ | ||||||
|  | public class LoginSiteUser implements UserDetails | ||||||
|  | { | ||||||
|  |     private static final long serialVersionUID = 1L; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 用户ID | ||||||
|  |      */ | ||||||
|  |     private Long userId; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 用户唯一标识 | ||||||
|  |      */ | ||||||
|  |     private String token; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 登录时间 | ||||||
|  |      */ | ||||||
|  |     private Long loginTime; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 过期时间 | ||||||
|  |      */ | ||||||
|  |     private Long expireTime; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 登录IP地址 | ||||||
|  |      */ | ||||||
|  |     private String ipaddr; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 登录地点 | ||||||
|  |      */ | ||||||
|  |     private String loginLocation; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 浏览器类型 | ||||||
|  |      */ | ||||||
|  |     private String browser; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 操作系统 | ||||||
|  |      */ | ||||||
|  |     private String os; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 用户信息 | ||||||
|  |      */ | ||||||
|  |     private AppUser user; | ||||||
|  |  | ||||||
|  |     public LoginSiteUser(){ | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |     public LoginSiteUser(Long userId, AppUser user){ | ||||||
|  |         this.userId = userId; | ||||||
|  |         this.user = user; | ||||||
|  |     } | ||||||
|  |     public Long getUserId() | ||||||
|  |     { | ||||||
|  |         return userId; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setUserId(Long userId) | ||||||
|  |     { | ||||||
|  |         this.userId = userId; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public String getToken() | ||||||
|  |     { | ||||||
|  |         return token; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setToken(String token) | ||||||
|  |     { | ||||||
|  |         this.token = token; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @JSONField(serialize = false) | ||||||
|  |     @Override | ||||||
|  |     public String getPassword() | ||||||
|  |     { | ||||||
|  |         return user.getPassword(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public String getUsername() | ||||||
|  |     { | ||||||
|  |         return user.getName(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 账户是否未过期,过期无法验证 | ||||||
|  |      */ | ||||||
|  |     @JSONField(serialize = false) | ||||||
|  |     @Override | ||||||
|  |     public boolean isAccountNonExpired() | ||||||
|  |     { | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 指定用户是否解锁,锁定的用户无法进行身份验证 | ||||||
|  |      *  | ||||||
|  |      * @return | ||||||
|  |      */ | ||||||
|  |     @JSONField(serialize = false) | ||||||
|  |     @Override | ||||||
|  |     public boolean isAccountNonLocked() | ||||||
|  |     { | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 指示是否已过期的用户的凭据(密码),过期的凭据防止认证 | ||||||
|  |      *  | ||||||
|  |      * @return | ||||||
|  |      */ | ||||||
|  |     @JSONField(serialize = false) | ||||||
|  |     @Override | ||||||
|  |     public boolean isCredentialsNonExpired() | ||||||
|  |     { | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 是否可用 ,禁用的用户不能身份验证 | ||||||
|  |      *  | ||||||
|  |      * @return | ||||||
|  |      */ | ||||||
|  |     @JSONField(serialize = false) | ||||||
|  |     @Override | ||||||
|  |     public boolean isEnabled() | ||||||
|  |     { | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public Long getLoginTime() | ||||||
|  |     { | ||||||
|  |         return loginTime; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setLoginTime(Long loginTime) | ||||||
|  |     { | ||||||
|  |         this.loginTime = loginTime; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public String getIpaddr() | ||||||
|  |     { | ||||||
|  |         return ipaddr; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setIpaddr(String ipaddr) | ||||||
|  |     { | ||||||
|  |         this.ipaddr = ipaddr; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public String getLoginLocation() | ||||||
|  |     { | ||||||
|  |         return loginLocation; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setLoginLocation(String loginLocation) | ||||||
|  |     { | ||||||
|  |         this.loginLocation = loginLocation; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public String getBrowser() | ||||||
|  |     { | ||||||
|  |         return browser; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setBrowser(String browser) | ||||||
|  |     { | ||||||
|  |         this.browser = browser; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public String getOs() | ||||||
|  |     { | ||||||
|  |         return os; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setOs(String os) | ||||||
|  |     { | ||||||
|  |         this.os = os; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public Long getExpireTime() | ||||||
|  |     { | ||||||
|  |         return expireTime; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setExpireTime(Long expireTime) | ||||||
|  |     { | ||||||
|  |         this.expireTime = expireTime; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     public AppUser getUser() | ||||||
|  |     { | ||||||
|  |         return user; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public void setUser(AppUser user) | ||||||
|  |     { | ||||||
|  |         this.user = user; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public Collection<? extends GrantedAuthority> getAuthorities() | ||||||
|  |     { | ||||||
|  |         return null; | ||||||
|  |     } | ||||||
|  | } | ||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user