使用注解和AOP实现接口权限控制

本文介绍了一种通过在Java方法上添加自定义注解`@RequirePermission`和创建切面类`PermissionAspect`来实现运行时权限检查的机制。在`@RequirePermission`注解中定义了需要的权限码,在切面类中,通过AOP拦截注解标记的方法,检查当前用户是否具备所需权限,从而实现细粒度的权限控制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 首先先写一个注解

@Documented
@Retention(value = RetentionPolicy.RUNTIME)
@Target({ElementType.METHOD, ElementType.TYPE})
public @interface RequirePermission {
    PermissionCode[] value();
}

2.在需要权限控制的方法上加上注解

@PostMapping("/add")
    @RequirePermission(PermissionCode.SANCUS_ADMIN)
    public Result<Long> add(@RequestBody MarketingRules marketingRules) {
        OneLogUtil.createLog(LOG_ITEM_NAME, JSON.toJSONString(marketingRules));
        return RESULT_PROVIDER.getResult(marketingRulesManager.add(marketingRules));
    }

3. 写一个切面类

@Aspect
@Component
@Slf4j
public class PermissonAspect {

    @Autowired
    protected HttpServletRequest request;

    @Autowired
    private PermissionManager permissionManager;

    private static final ResultProvider RESULT_PROVIDER = ResultProvider.init(ModuleCode.NOT_USE);

    @Pointcut("@annotation(com.taobao.datasecurity.annotation.RequirePermission)")
    public void pointCut() {

    }

    @Around("pointCut()")
    public Object exceptionHandler(ProceedingJoinPoint joinPoint) throws Throwable {
        MethodSignature signature = (MethodSignature) joinPoint.getSignature();
        RequirePermission requirePermission = signature.getMethod().getAnnotation(RequirePermission.class);
        boolean requireAdmin = Arrays.stream(requirePermission.value()).anyMatch(it -> it.equals(PermissionCode.SANCUS_ADMIN));
        User currentUser = BucUserUtil.getCurrentUser(request);
        Boolean sancusAdmin = permissionManager.isSancusAdmin(currentUser);
        if (requireAdmin && sancusAdmin) {
            return joinPoint.proceed();
        }
        return RESULT_PROVIDER.getResult(UNAUTHORIZED);
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值