7.3 CacheInterceptor

CacheInterceptor可以将action所需数据全部缓存起来,下次请求到来时如果cache存在则直接使用数据并render,而不会去调用action。此用法可使action完全不受cache相关代码所污染,即插即用,以下是示例代码:

  1. @Before(CacheInterceptor.class)
  2. public void list() {
  3.     List<Blog> blogList = Blog.dao.find(“select * from blog”);
  4.     User user = User.dao.findById(getParaToInt());
  5.     setAttr(“blogList”, blogList);
  6.     setAttr(“user”, user);
  7.     render(“blog.html”);
  8. }

上例中的用法将使用actionKey作为cacheName,在使用之前需要在ehcache.xml中配置以actionKey命名的cache如:,注意actionKey作为cacheName配置时斜杠”/”不能省略。此外CacheInterceptor还可以与CacheName 注解配合使用,以此来取代默认的actionKey作为cacheName,以下是示例代码:

  1. @Before(CacheInterceptor.class)
  2. @CacheName(“blogList”)
  3. public void list() {
  4.     List<Blog> blogList = Blog.dao.find(“select * from blog”);
  5.     setAttr(“blogList”, blogList);
  6.     render(“blog.html”);
  7. }

以上用法需要在ehcache.xml中配置名为blogList的cache如: