Solon 开发,五、切面与环绕拦截

想要环绕拦截一个Bean的函数。需要三个前置条件:

  1. 通过注解做为切点,进行拦截(不能无缘无故给拦了吧?费性能)
  2. Bean 的 method 是被代理的(@Controller、@Service、@Dao 注解的类,都会代理 method)
  3. 在 Bean 被扫描之前,完成环绕拦截的注册

建议看一下《想法与架构笔记》,关于应用内在的启动过程

1、定义切点和注册环绕拦截

Solon 的切点,通过注解实现,得先定义一个。例如:@Logging

@Target({ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
public @interface Logging {
}

注册环绕拦截

Aop.context().beanAroundAdd(Logging.class, inv->{
    //此处为拦截处理
    Object rst = inv.invoke();
    
    log.info("Args: {}\nReturn: {}", inv.args(), rst);
    
    return rst;
});

现在切点定义好了,可以到处“埋”了...

2、应用:把切点“埋”到需要的地方

@Service
public class DemoController{
    @Logging
    public void addUser(UserModel user){
        //...
    }
}

就这样完成一个面向切面的开发了。

3、通过插件及插件配置,变成一个复用的东西

这是刚才定义注解:

@Target({ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
public @interface Logging {
}

开发插件:

@Slf4j
public class XPluginImp implements Plugin {
    @Override
    public void start(SolonApp app) {
        Aop.context().beanAroundAdd(Logging.class, inv->{
            Object rst = inv.invoke();

            log.info("Args: {}\nReturn: {}", inv.args(), rst);
        });
    }
}

配置插件:

solon.plugin=xxx.xxx.log.XPluginImp

一个可复用的插件开发完成了。关于Solon插件开发,可参考别的章节内容。

posted @ 2022-01-16 18:48  带刺的坐椅  阅读(113)  评论(0编辑  收藏  举报