美文网首页JFinal极速开发Java学习笔记程序员
JFinal3.0快速上手,极简AOP开发(二十四)

JFinal3.0快速上手,极简AOP开发(二十四)

作者: 葉糖糖 | 来源:发表于2017-06-18 13:23 被阅读473次

在前一小节我们已经学会了实现简单的AOP操作,那么今天继续来增强一下补充学习如何设置全局的拦截与清除。

一、讲在前面,理论先行

@Before注解可以用来对拦截器进行配置, @Clear可以清除对拦截器的配置。通过@Before注解可以配置ClassMethod的拦截器。

如你所愿@Before可以同时配置多个拦截器,语法:@Before({xxx.class,xxx.class}),其实很简单就是在注解中使用{}分别配置要使用到的拦截器。示例如下:

package com.demo.test;

import com.demo.util.ClassInterceptor;
import com.demo.util.DemoInterceptor;
import com.jfinal.aop.Before;
import com.jfinal.aop.Clear;
import com.jfinal.core.Controller;

@Before(ClassInterceptor.class)
public class OrderController extends Controller {
    
   
   @Before(DemoInterceptor.class)
   public void index(){
       System.out.println("开始执行index方法,我是目标执行方法。");
       render("test.html");
   }
   
   public void SayHello(){
       System.out.println("这是一个没有添加方法级的拦截的SayHello方法");
       renderNull();
   }
   
   @Clear
   public void SayBye(){
       System.out.println("这是一个干净的方法");
       renderNull();
   }
   
}

二、精彩验证,请勿走开

我们在控制器中编写了index()、SayHello()、SayBye()方法,你能根据上述的理论,猜到程序运行的结果么?先思考一下。

这边提供一下DemoInterceptor和ClassInterceptor的实现代码,分别如下:
1、DemoInterceptor实现

package com.demo.util;

import com.jfinal.aop.Interceptor;
import com.jfinal.aop.Invocation;

public class DemoInterceptor implements Interceptor {

    @Override
    public void intercept(Invocation inv) {
        System.out.println("Before method invoking");
        inv.invoke();
        System.out.println("After methon invoking");
        
    }

}

2、ClassInterceptor实现

package com.demo.util;

import com.jfinal.aop.Interceptor;
import com.jfinal.aop.Invocation;

public class ClassInterceptor implements Interceptor{

    @Override
    public void intercept(Invocation inv) {
        System.out.println("这是类级别拦截的前置执行效果");
        inv.invoke();
        System.out.println("这是类级别拦截的后置执行效果");
        
    }
   
}

在两个拦截器中,程序都只是向控制台输出打印了一段文字,你也许猜想到了执行效果,接下来就让我们一起来验证。

3、index方法

对index方法的拦截是比较有趣的,可以看出来拦截器是有执行顺序(优先级)的。在没有全局拦截器的情况下,先执行的是Class级别的拦截器,接着执行的是Method的级别的拦截器,最终执行的是目标方法。如果存在后置执行的方法则反之。这就像Java中的换括号表示作用域一样,最外层的包裹的作用域自然越大。index方法执行了本身的拦截,还执行了Class级别的拦截。

index运行结果

4、SayHello方法

SayHello没有在方法上使用拦截器,所以只会执行Class级别的拦截。
@Before(ClassInterceptor.class),这行代码就是告诉jfinal,让它对这个控制器中的action进行拦截。

SayHello运行结果

5、SayBye方法

@Clear清除了所有SayBye方法上层的拦截器对SayBye的拦截,所以SayBye不会执行Class级别的拦截。@Clear清除指定的拦截器语法如:@Clear(xxx.class);清除多个和添加一样使用{},进行处理:@Clear({xxx.ass, xxx.class})

SayBye运行结果

三、奇思妙想,大胆评测

如果在SayBye方法上添加一个Method的拦截器运行结果,会是怎么样的好奇么?让我们来试一试。

1、改造代码,添加方法级拦截器

   @Clear
   @Before(DemoInterceptor.class)
   public void SayBye(){
       System.out.println("这是一个干净的方法");
       renderNull();
   }

2、运行程序,检查效果

这下可以理解清除上层拦截这个概念了吧?@Clear清除只针对上层的拦截。对于本层和下层的拦截不影响。

自带主角光环的SayBye方法

PS:是不是感觉很好玩?那就赶快动起来吧。加油!亲爱的小伙伴们!想加群的朋友可以扫描,加入q群,一起玩转jfinal。

程序人生q群

相关文章

网友评论

    本文标题:JFinal3.0快速上手,极简AOP开发(二十四)

    本文链接:https://www.haomeiwen.com/subject/osyiqxtx.html