From f65ca791b5047ce1c8bb49d215fb66bc6d41ace6 Mon Sep 17 00:00:00 2001 From: sh Date: Thu, 23 Oct 2025 14:38:20 +0800 Subject: [PATCH] =?UTF-8?q?1.=E4=BF=AE=E6=94=B9=E7=94=A8=E6=88=B7=E6=8C=89?= =?UTF-8?q?=E5=90=8D=E7=A7=B0=E6=9F=A5=E8=AF=A2=E6=8A=A5=E9=94=99=E9=97=AE?= =?UTF-8?q?=E9=A2=98=202.=E4=BF=AE=E6=94=B9=E5=B2=97=E4=BD=8D=E5=88=97?= =?UTF-8?q?=E8=A1=A8=E3=80=81=E4=BC=81=E4=B8=9A=E5=88=97=E8=A1=A8=E5=BD=93?= =?UTF-8?q?=E6=98=AF=E4=BC=81=E4=B8=9A=E8=A7=92=E8=89=B2=E6=97=B6=EF=BC=8C?= =?UTF-8?q?=E5=8F=AA=E6=9F=A5=E8=AF=A2=E8=87=AA=E5=B7=B1=E7=9A=84=E6=95=B0?= =?UTF-8?q?=E6=8D=AE?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../cms/controller/cms/CmsJobController.java | 10 +++++ .../cms/controller/cms/CompanyController.java | 4 ++ .../java/com/ruoyi/cms/util/RoleUtils.java | 39 +++++++++++++++++++ .../java/com/ruoyi/cms/util/StringUtil.java | 3 ++ .../resources/mapper/system/SysUserMapper.xml | 4 +- 5 files changed, 58 insertions(+), 2 deletions(-) create mode 100644 ruoyi-bussiness/src/main/java/com/ruoyi/cms/util/RoleUtils.java diff --git a/ruoyi-bussiness/src/main/java/com/ruoyi/cms/controller/cms/CmsJobController.java b/ruoyi-bussiness/src/main/java/com/ruoyi/cms/controller/cms/CmsJobController.java index 97e7593..6af9137 100644 --- a/ruoyi-bussiness/src/main/java/com/ruoyi/cms/controller/cms/CmsJobController.java +++ b/ruoyi-bussiness/src/main/java/com/ruoyi/cms/controller/cms/CmsJobController.java @@ -2,12 +2,15 @@ package com.ruoyi.cms.controller.cms; import com.ruoyi.cms.domain.Job; import com.ruoyi.cms.domain.vo.CandidateVO; +import com.ruoyi.cms.service.ICompanyService; 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.Log; import com.ruoyi.common.core.controller.BaseController; 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.enums.BusinessType; import com.ruoyi.common.utils.poi.ExcelUtil; @@ -19,6 +22,7 @@ import org.springframework.web.bind.annotation.*; import javax.servlet.http.HttpServletResponse; import java.util.List; +import java.util.Objects; /** * 岗位Controller @@ -36,6 +40,8 @@ public class CmsJobController extends BaseController private IJobService jobService; @Autowired SensitiveWordChecker sensitiveWordChecker; + @Autowired + private ICompanyService companyService; /** * 查询岗位列表 */ @@ -44,6 +50,10 @@ public class CmsJobController extends BaseController @GetMapping("/list") public TableDataInfo list(Job job) { + if (RoleUtils.isCompanyAdmin()) { + Company company = companyService.queryCodeCompany(RoleUtils.getCurrentUseridCard()); + job.setCompanyId(Objects.nonNull(company) ? company.getCompanyId() : null); + } startPage(); List list = jobService.selectJobList(job); return getDataTable(list); diff --git a/ruoyi-bussiness/src/main/java/com/ruoyi/cms/controller/cms/CompanyController.java b/ruoyi-bussiness/src/main/java/com/ruoyi/cms/controller/cms/CompanyController.java index 58574f8..7e74ba8 100644 --- a/ruoyi-bussiness/src/main/java/com/ruoyi/cms/controller/cms/CompanyController.java +++ b/ruoyi-bussiness/src/main/java/com/ruoyi/cms/controller/cms/CompanyController.java @@ -1,6 +1,7 @@ package com.ruoyi.cms.controller.cms; +import com.ruoyi.cms.util.RoleUtils; import com.ruoyi.common.core.domain.entity.Company; import com.ruoyi.cms.service.ICompanyService; import com.ruoyi.common.annotation.Log; @@ -40,6 +41,9 @@ public class CompanyController extends BaseController @GetMapping("/list") public TableDataInfo list(Company company) { + if (RoleUtils.isCompanyAdmin()) { + company.setCode(RoleUtils.getCurrentUseridCard()); + } startPage(); List list = companyService.selectCompanyList(company); return getDataTable(list); diff --git a/ruoyi-bussiness/src/main/java/com/ruoyi/cms/util/RoleUtils.java b/ruoyi-bussiness/src/main/java/com/ruoyi/cms/util/RoleUtils.java new file mode 100644 index 0000000..800e0be --- /dev/null +++ b/ruoyi-bussiness/src/main/java/com/ruoyi/cms/util/RoleUtils.java @@ -0,0 +1,39 @@ +package com.ruoyi.cms.util; + +import com.ruoyi.common.core.domain.entity.SysUser; +import com.ruoyi.common.core.domain.model.LoginUser; +import com.ruoyi.common.utils.SecurityUtils; + +/** + * 判断是否企业用户 + */ +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(); + } +} \ No newline at end of file diff --git a/ruoyi-bussiness/src/main/java/com/ruoyi/cms/util/StringUtil.java b/ruoyi-bussiness/src/main/java/com/ruoyi/cms/util/StringUtil.java index f8b2c23..1fa8245 100644 --- a/ruoyi-bussiness/src/main/java/com/ruoyi/cms/util/StringUtil.java +++ b/ruoyi-bussiness/src/main/java/com/ruoyi/cms/util/StringUtil.java @@ -9,6 +9,9 @@ import java.util.Objects; import java.util.stream.Collectors; public class StringUtil { + + public static final Long COMPANY_ADMIN_ROLE_KEY = 100L; + public static Boolean isEmptyOrNull(String s){ if(Objects.isNull(s)){return true;} return s.isEmpty(); diff --git a/ruoyi-system/src/main/resources/mapper/system/SysUserMapper.xml b/ruoyi-system/src/main/resources/mapper/system/SysUserMapper.xml index a21e0d9..871436d 100644 --- a/ruoyi-system/src/main/resources/mapper/system/SysUserMapper.xml +++ b/ruoyi-system/src/main/resources/mapper/system/SysUserMapper.xml @@ -65,13 +65,13 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" AND u.user_id = #{userId} - AND u.user_name like concat('%', #{userName}, '%') + AND u.user_name like concat('%', CAST(#{userName} AS VARCHAR), '%') AND u.status = #{status} - AND u.phonenumber like concat('%', #{phonenumber}, '%') + AND u.phonenumber like concat('%', CAST(#{phonenumber} AS VARCHAR), '%') AND date_format(u.create_time,'%Y%m%d') >= date_format(#{params.beginTime},'%Y%m%d')