芝麻web文件管理V1.00
编辑当前文件:/home2/sdektunc/xmintal-back/vendor/yiisoft/yii2/filters/PageCache.php
[ * 'class' => 'yii\filters\PageCache', * 'only' => ['index'], * 'duration' => 60, * 'dependency' => [ * 'class' => 'yii\caching\DbDependency', * 'sql' => 'SELECT COUNT(*) FROM post', * ], * 'variations' => [ * \Yii::$app->language, * ] * ], * ]; * } * ``` * * @author Qiang Xue
* @author Sergey Makinen
* @since 2.0 */ class PageCache extends ActionFilter implements DynamicContentAwareInterface { use DynamicContentAwareTrait; /** * Page cache version, to detect incompatibilities in cached values when the * data format of the cache changes. */ const PAGE_CACHE_VERSION = 1; /** * @var bool whether the content being cached should be differentiated according to the route. * A route consists of the requested controller ID and action ID. Defaults to `true`. */ public $varyByRoute = true; /** * @var CacheInterface|array|string the cache object or the application component ID of the cache object. * After the PageCache object is created, if you want to change this property, * you should only assign it with a cache object. * Starting from version 2.0.2, this can also be a configuration array for creating the object. */ public $cache = 'cache'; /** * @var int number of seconds that the data can remain valid in cache. * Use `0` to indicate that the cached data will never expire. */ public $duration = 60; /** * @var array|Dependency the dependency that the cached content depends on. * This can be either a [[Dependency]] object or a configuration array for creating the dependency object. * For example, * * ```php * [ * 'class' => 'yii\caching\DbDependency', * 'sql' => 'SELECT MAX(updated_at) FROM post', * ] * ``` * * would make the output cache depend on the last modified time of all posts. * If any post has its modification time changed, the cached content would be invalidated. * * If [[cacheCookies]] or [[cacheHeaders]] is enabled, then [[\yii\caching\Dependency::reusable]] should be enabled as well to save performance. * This is because the cookies and headers are currently stored separately from the actual page content, causing the dependency to be evaluated twice. */ public $dependency; /** * @var string[]|string|callable list of factors that would cause the variation of the content being cached. * Each factor is a string representing a variation (e.g. the language, a GET parameter). * The following variation setting will cause the content to be cached in different versions * according to the current application language: * * ```php * [ * Yii::$app->language, * ] * ``` * * Since version 2.0.48 you can provide an anonymous function to generate variations. This is especially helpful * when you need to access the User component, which is resolved before the PageCache behavior: * * ```php * 'variations' => function() { * return [ * Yii::$app->language, * Yii::$app->user->id * ]; * } * ``` * * The callable should return an array. */ public $variations; /** * @var bool whether to enable the page cache. You may use this property to turn on and off * the page cache according to specific setting (e.g. enable page cache only for GET requests). */ public $enabled = true; /** * @var \yii\base\View|null the view component to use for caching. If not set, the default application view component * [[\yii\web\Application::view]] will be used. */ public $view; /** * @var bool|array a boolean value indicating whether to cache all cookies, or an array of * cookie names indicating which cookies can be cached. Be very careful with caching cookies, because * it may leak sensitive or private data stored in cookies to unwanted users. * @since 2.0.4 */ public $cacheCookies = false; /** * @var bool|array a boolean value indicating whether to cache all HTTP headers, or an array of * HTTP header names (case-sensitive) indicating which HTTP headers can be cached. * Note if your HTTP headers contain sensitive information, you should white-list which headers can be cached. * @since 2.0.4 */ public $cacheHeaders = true; /** * {@inheritdoc} */ public function init() { parent::init(); if ($this->view === null) { $this->view = Yii::$app->getView(); } } /** * This method is invoked right before an action is to be executed (after all possible filters.) * You may override this method to do last-minute preparation for the action. * @param Action $action the action to be executed. * @return bool whether the action should continue to be executed. */ public function beforeAction($action) { if (!$this->enabled) { return true; } $this->cache = Instance::ensure($this->cache, 'yii\caching\CacheInterface'); if (is_array($this->dependency)) { $this->dependency = Yii::createObject($this->dependency); } $response = Yii::$app->getResponse(); $data = $this->cache->get($this->calculateCacheKey()); if (!is_array($data) || !isset($data['cacheVersion']) || $data['cacheVersion'] !== static::PAGE_CACHE_VERSION) { $this->view->pushDynamicContent($this); ob_start(); ob_implicit_flush(false); $response->on(Response::EVENT_AFTER_SEND, [$this, 'cacheResponse']); Yii::debug('Valid page content is not found in the cache.', __METHOD__); return true; } $this->restoreResponse($response, $data); Yii::debug('Valid page content is found in the cache.', __METHOD__); return false; } /** * This method is invoked right before the response caching is to be started. * You may override this method to cancel caching by returning `false` or store an additional data * in a cache entry by returning an array instead of `true`. * @return bool|array whether to cache or not, return an array instead of `true` to store an additional data. * @since 2.0.11 */ public function beforeCacheResponse() { return true; } /** * This method is invoked right after the response restoring is finished (but before the response is sent). * You may override this method to do last-minute preparation before the response is sent. * @param array|null $data an array of an additional data stored in a cache entry or `null`. * @since 2.0.11 */ public function afterRestoreResponse($data) { } /** * Restores response properties from the given data. * @param Response $response the response to be restored. * @param array $data the response property data. * @since 2.0.3 */ protected function restoreResponse($response, $data) { foreach (['format', 'version', 'statusCode', 'statusText', 'content'] as $name) { $response->{$name} = $data[$name]; } foreach (['headers', 'cookies'] as $name) { if (isset($data[$name]) && is_array($data[$name])) { $response->{$name}->fromArray(array_merge($data[$name], $response->{$name}->toArray())); } } if (!empty($data['dynamicPlaceholders']) && is_array($data['dynamicPlaceholders'])) { $response->content = $this->updateDynamicContent($response->content, $data['dynamicPlaceholders'], true); } $this->afterRestoreResponse(isset($data['cacheData']) ? $data['cacheData'] : null); } /** * Caches response properties. * @since 2.0.3 */ public function cacheResponse() { $this->view->popDynamicContent(); $beforeCacheResponseResult = $this->beforeCacheResponse(); if ($beforeCacheResponseResult === false) { echo $this->updateDynamicContent(ob_get_clean(), $this->getDynamicPlaceholders()); return; } $response = Yii::$app->getResponse(); $response->off(Response::EVENT_AFTER_SEND, [$this, 'cacheResponse']); $data = [ 'cacheVersion' => static::PAGE_CACHE_VERSION, 'cacheData' => is_array($beforeCacheResponseResult) ? $beforeCacheResponseResult : null, 'content' => ob_get_clean(), ]; if ($data['content'] === false || $data['content'] === '') { return; } $data['dynamicPlaceholders'] = $this->getDynamicPlaceholders(); foreach (['format', 'version', 'statusCode', 'statusText'] as $name) { $data[$name] = $response->{$name}; } $this->insertResponseHeaderCollectionIntoData($response, $data); $this->insertResponseCookieCollectionIntoData($response, $data); $this->cache->set($this->calculateCacheKey(), $data, $this->duration, $this->dependency); $data['content'] = $this->updateDynamicContent($data['content'], $this->getDynamicPlaceholders()); echo $data['content']; } /** * Inserts (or filters/ignores according to config) response cookies into a cache data array. * @param Response $response the response. * @param array $data the cache data. */ private function insertResponseCookieCollectionIntoData(Response $response, array &$data) { if ($this->cacheCookies === false) { return; } $all = $response->cookies->toArray(); if (is_array($this->cacheCookies)) { $filtered = []; foreach ($this->cacheCookies as $name) { if (isset($all[$name])) { $filtered[$name] = $all[$name]; } } $all = $filtered; } $data['cookies'] = $all; } /** * Inserts (or filters/ignores according to config) response headers into a cache data array. * @param Response $response the response. * @param array $data the cache data. */ private function insertResponseHeaderCollectionIntoData(Response $response, array &$data) { if ($this->cacheHeaders === false) { return; } $all = $response->headers->toOriginalArray(); if (is_array($this->cacheHeaders)) { $filtered = []; foreach ($this->cacheHeaders as $name) { if (isset($all[$name])) { $filtered[$name] = $all[$name]; } } $all = $filtered; } $data['headers'] = $all; } /** * @return array the key used to cache response properties. * @since 2.0.3 */ protected function calculateCacheKey() { $key = [__CLASS__]; if ($this->varyByRoute) { $key[] = Yii::$app->requestedRoute; } if ($this->variations instanceof Closure) { $variations = call_user_func($this->variations, $this); } else { $variations = $this->variations; } return array_merge($key, (array) $variations); } /** * {@inheritdoc} */ public function getView() { return $this->view; } }