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如:<cache name=”/blog/list” …>,注意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如:<cache name=”blogList” …>。