在前一小节我们已经学会了实现简单的AOP操作,那么今天继续来增强一下补充学习如何设置全局的拦截与清除。
一、讲在前面,理论先行
@Before注解可以用来对拦截器进行配置, @Clear可以清除对拦截器的配置。通过@Before注解可以配置Class、 Method的拦截器。
如你所愿@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运行结果对index方法的拦截是比较有趣的,可以看出来拦截器是有执行顺序(优先级)的。在没有全局拦截器的情况下,先执行的是Class级别的拦截器,接着执行的是Method的级别的拦截器,最终执行的是目标方法。如果存在后置执行的方法则反之。这就像Java中的换括号表示作用域一样,最外层的包裹的作用域自然越大。index方法执行了本身的拦截,还执行了Class级别的拦截。
4、SayHello方法
SayHello运行结果SayHello没有在方法上使用拦截器,所以只会执行Class级别的拦截。
@Before(ClassInterceptor.class),这行代码就是告诉jfinal,让它对这个控制器中的action进行拦截。
5、SayBye方法
SayBye运行结果@Clear清除了所有SayBye方法上层的拦截器对SayBye的拦截,所以SayBye不会执行Class级别的拦截。@Clear清除指定的拦截器语法如:
@Clear(xxx.class)
;清除多个和添加一样使用{}
和,
进行处理:@Clear({xxx.ass, xxx.class})
。
三、奇思妙想,大胆评测
如果在SayBye方法上添加一个Method的拦截器运行结果,会是怎么样的好奇么?让我们来试一试。
1、改造代码,添加方法级拦截器
@Clear
@Before(DemoInterceptor.class)
public void SayBye(){
System.out.println("这是一个干净的方法");
renderNull();
}
2、运行程序,检查效果
自带主角光环的SayBye方法这下可以理解清除上层拦截这个概念了吧?@Clear清除只针对上层的拦截。对于本层和下层的拦截不影响。
PS:是不是感觉很好玩?那就赶快动起来吧。加油!亲爱的小伙伴们!想加群的朋友可以扫描,加入q群,一起玩转jfinal。
程序人生q群
网友评论