页面缓存指的是在服务器端缓存整个页面的内容。随后当同一个页面 被请求时,内容将从缓存中取出,而不是重新生成。
举例说明
class TestController extends Controller{
// 该方法会在其他方法之前执行
public function behaviors()
{
// 声明缓存配置
return [ // 需要注意的这里是二维数组
[
'class' => 'yii\filters\PageCache', // 设置需要加载的缓存文件
'only' => ['index'], // 设置需要缓存的控制器
'duration' => 100, // 设置过期时间
'dependency' => [ // 设置依赖关系
'class' => 'yii\caching\FileDependency',
'fileName' => 'robots.txt'
]
]
];
}
public function actionIndex(){
echo 2;
}
public function actionTest(){
echo 2;
}
}
上述代码表示缓存只在 index 页面中生效,并且页面最多缓存 100秒 ,并且会随着robots.txt文件的变化,而使缓存失效。
---------------------
参数说明
class:定义需要加载的缓存配置文件。
only:定义仅仅只需要在哪个页面设置缓存。如上列举例中,仅仅只有index页面会缓存下来,其他页面则不会缓存。
duration:定义缓存过期秒数。如上列举例中,100秒之后缓存将过期。
dependency:设置依赖关系。如上列举例中,使用的是文件依赖,当 “robots.txt” 文件内容改变时,缓存将失效。当然,还有其他的依赖关系,可以在数据缓存中查看。