Home | Symfony2Doc »Symfony Standard Edition のバンドル »SensioFrameworkExtraBundle »@Cache

このページのコンテンツ

前のドキュメント

@Template

次のドキュメント

Symfony2 プロジェクトへの貢献

ソース



クイックリンク


コメントリスト

Powered by Disqus

ご質問や翻訳不備等お気軽にコメントください。


コンテンツ上部に更新日の記載のないページは、翻訳の内容が2.0相当のものになっております。最新の内容は原文のページをご確認ください。

@Cache

Usage

The @Cache annotation makes it easy to define HTTP caching:

use Sensio\Bundle\FrameworkExtraBundle\Configuration\Cache;

/**
 * @Cache(expires="tomorrow")
 */
public function indexAction()
{
}

You can also use the annotation on a class to define caching for all methods:

/**
 * @Cache(expires="tomorrow")
 */
class BlogController extends Controller
{
}

When there is a conflict between the class configuration and the method configuration, the latter overrides the former:

/**
 * @Cache(expires="tomorrow")
 */
class BlogController extends Controller
{
    /**
     * @Cache(expires="+2 days")
     */
    public function indexAction()
    {
    }
}

Attributes

Here is a list of accepted attributes and their HTTP header equivalent:

Annotation Response Method
@Cache(expires="tomorrow") $response->setExpires()
@Cache(smaxage="15") $response->setSharedMaxAge()
@Cache(maxage="15") $response->setMaxAge()
@Cache(vary=["Cookie"]) $response->setVary()

Note

The expires attribute takes any valid date understood by the PHP strtotime() function.

blog comments powered by Disqus