aop+策略模式实战

本文介绍如何利用AOP(面向切面编程)结合策略模式,解决部分接口出现的越权访问问题。步骤包括:创建业务实现类、定义注解以携带关键参数、设置切面进行权限检查,以及定制相应的异常处理。
摘要由CSDN通过智能技术生成

部分接口发现越权,然后通过aop+策略模式解决

1.一个接口,需要对应业务的实现类;

2.定义一个注解(注解参数重要)

3.切面

public interface AuthCheckStrategy {

    AuthCheckResult authCheck(HttpServletRequest request, Object checkObject);

}
@Slf4j
@Component
public class AppointSaveAuthCheckStrategy implements AuthCheckStrategy {

    @Autowired
    private AppointService appointService;

    @Override
    public AuthCheckResult authCheck(HttpServletRequest request, Object checkObject) {
        UserInfo userInfo = UserUtils.getUserInfo(request);
        if (null == userInfo) {
            return AuthCheckResult.wrapErrorResult("非法访问");
        }

        JSONObject jsonObject = JSON.parseObject(JSON.toJSONString(checkObject));
        JSONObject appointJsonObject = jsonObject.getJSONObject("appoint");
        Long appointId = appointJsonObject.getLong("
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值