首先先做一下准备工作及说明:
1、cache在web.php中的配置使用的是默认配置FileCache
2、使用的是yii的basic基础版
3、在controllers下面新建一个控制器叫CacheController.php
好了不累赘了,直接进入正题
一、数据缓存讲解
A、缓存的增删改查
首先要使用cache,首先加载使用cache的缓存组件
//yii中的全局使用,需要加上“\”
$cache = \YII::$app->cache;
添加(往缓存里面写数据)
$cache->add('name','lucy');
$cache->add('name','lily');
$cache->add('sex','man');
注意:如果缓存中有相同的key值,后者不会覆盖前者的值
需要删除摸个缓存使用delete
$cache->delete('name');
读取缓存使用get即可
echo $cache->get('name');
如果需要清除所有的缓存使用flush
$cache->flush();
设置缓存使用set,判断缓存存不存在使用exists
$cache->add('age',24);
if($cache->exists('age')){
$cache->set('age',25);
}
echo $cache->get('age');
B、设置缓存失效时间(直接使用第三个参数就可以了,以s为单位)
$cache = \YII::$app->cache;
//设置缓存时间为20秒
$cache->add('name','lucy',20);
echo $cache->get('name');
//set方法也可以设置缓存时间
$cache->set('name','lily',20);
echo $cache->get('name');
C、缓存依赖
//使用缓存组件
$cache = \YII::$app->cache;
//文件依赖(依赖文件一但修改,则缓存失效)
$denpendency = new \yii\caching\FileDependency(['fileName'=>'hw.txt']);//hw.txt在web目录下
$cache->add('file_key','hello world!',3000,$denpendency);
var_dump($cache->get('file_key'));
//表达式依赖(表达式为获取请求get参数name,一但name变化,缓存失效)
$denpendency = new \yii\caching\ExpressionDependency([
'expression' => '\YII::$app->request->get("name")'
]);
$cache->add('expression_key','hello world!',3000,$denpendency);
var_dump($cache->get('expression_key'));
//DB依赖(数据库依赖)【依赖的为数据库查询条数,一但order表中总数变化,缓存失效】
$dependency = new \yii\caching\DbDependency([
'sql' => 'select count(*) from yii.order'
]);
$cache->add('sql_key','hello world!',3000,$dependency);
var_dump($cache->get('sql_key'));
二、片段缓存
定义一个操作如下:
/*指向缓存片段测试页面*/
public function actionPianduan(){
return $this->renderPartial('pianduan');
}
在views目录下新建cache目录,在cache下面新建pianduan.php文件(内容讲解都在注释里面)
<?php
$duration = 20;
//缓存依赖
$dependency = [
'class' => 'yii\caching\FileDependency',
'fileName' => 'hw.txt'
];
//缓存开关
$enabled = true;
?>
<!--
片段缓存通过beginCache来实现,如果需要设置缓存时间的话需要在beginCache里面添加第二个参数,是个数组
['duration'=>20]
-->
<?php if($this->beginCache('cache_div',['duration'=>$duration,'dependency'=>$dependency,'enabled'=>$enabled])){ ?>
<div id='cache_div'>
<div>这里待会会被缓存</div>
<!--
片段缓存时间问题
如果外存缓存时间大于里层缓存时间,那么在外存未过期的情况下,里层即使过期了也没有机会重新刷新
所以,一般外存的缓存时间应该小于等于里层的缓存时间,但也不绝对
-->
<?php if($this->beginCache('cache_inner_div',['duration'=>1])){ ?>
<div id="cache_inner_div">这是一个嵌套缓存111</div>
<?php
$this->endCache();
}
?>
</div>
<?php
$this->endCache();
}
?>
<!--<div id='no_cache_div'>
<div>这里待不会被缓存1111</div>
</div>-->
三、页面缓存
/*测试 behaviors 方法先于其他操作之前执行*/
public function behaviors(){
//页面缓存
return [
[
//页面缓存类
'class' => 'yii\filters\PageCache',
//缓存时间
'duration' => 1000,
//设置需要缓存的操作
'only' => ['pagecache'],
//缓存依赖
'dependency' => [
'class' => 'yii\caching\FileDependency',
'fileName' => 'hw.txt'
]
]
];
}
public function actionPagecache(){
echo 5;
}
public function actionPagecache2(){
echo 6;
}
四、http缓存
public function behaviors(){
return [
[
'class' => 'yii\filters\HttpCache',
'lastModified' => function(){
return filemtime('hw.txt');
//return 1432817570;
},
'etagSeed' => function(){
$fp = fopen('hw.txt','r');
$title = fgets($fp);
fclose($fp);
return $title;
//return 'etagseed4';
}
]
];
}
public function actionHttppage(){
$content = file_get_contents('hw.txt');
return $this->renderPartial('httppage',['news'=>$content]);
}
httppage.php
<div>
<div>
<?=$news ;?>
</div>
</div>