페이지 캐싱은 서버 측에서 전체 페이지의 내용을 캐싱하는 것을 의미합니다. 이후에 동일한 페이지가 요청되면 콘텐츠가 다시 생성되지 않고 캐시에서 가져옵니다. 다음 글에서는 주로 Yii2.0이 페이지 캐싱을 사용하는 방법에 대한 관련 정보를 소개합니다.
머리말
이 글은 주로 Yii2.0이 페이지 캐싱을 사용하는 방법에 대한 내용을 소개합니다. 참고 및 학습을 위해 공유합니다.
처음에는 페이지 캐싱을 사용했지만 매개변수가 포함된 방법에는 첫 번째 페이지만 캐시할 수 있어 다른 매개변수가 있는 모든 후속 페이지에 첫 번째 캐시된 페이지가 표시된다는 사실을 발견했습니다. 캐시; 그래서 페이지 캐시가 다시 작성되었습니다.
샘플 코드
<?php namespace common\lib; use Yii; use yii\caching\Cache; use yii\di\Instance; use yii\web\Response; use yii\filters\PageCache as PCache; /** * 重写页面缓存,增加varByParam参数一列 */ class PageCache extends PCache { /** * 参数设置,默认无参数 * 用法:'varByParam' => Yii::$app->request->get('id') * @var string */ public $varByParam = ''; public function beforeAction($action) { if (!$this->enabled) { return true; } $this->cache = Instance::ensure($this->cache, Cache::className()); if (is_array($this->dependency)) { $this->dependency = Yii::createObject($this->dependency); } $properties = []; foreach (['cache', 'duration', 'dependency', 'variations'] as $name) { $properties[$name] = $this->$name; } $id = $this->varyByRoute ? $action->getUniqueId().$this->varByParam : __CLASS__; $response = Yii::$app->getResponse(); ob_start(); ob_implicit_flush(false); if ($this->view->beginCache($id, $properties)) { $response->on(Response::EVENT_AFTER_SEND, [$this, 'cacheResponse']); return true; } else { $data = $this->cache->get($this->calculateCacheKey()); if (is_array($data)) { $this->restoreResponse($response, $data); } $response->content = ob_get_clean(); return false; } } } ?>
사용:
[ 'class' => 'common\lib\PageCache', 'only' => ['view'], 'duration' => 0, //永不过期 'varByParam' => Yii::$app->request->get('id'), ],
위 내용은 페이지 캐싱 방법에 대한 Yii 2.0 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!