Skip to content

Commit

Permalink
Fixes yiisoft#4710: added cache busting support for assets
Browse files Browse the repository at this point in the history
  • Loading branch information
qiangxue committed Feb 9, 2015
1 parent 4efb36d commit 0068a94
Show file tree
Hide file tree
Showing 3 changed files with 50 additions and 4 deletions.
24 changes: 24 additions & 0 deletions docs/guide/structure-assets.md
Original file line number Diff line number Diff line change
Expand Up @@ -370,6 +370,30 @@ when it is being published. This is faster than file copying and can also ensure
always up-to-date.


### Cache Busting <span id="cache-busting"></span>

For Web application running in production mode, it is a common practice to enable HTTP caching for assets and other
static resources. A drawback of this practice is that whenever you modify an asset and deploy it to production, a user
client may still use the old version due to the HTTP caching. To overcome this drawback, you may use the cache busting
feature, which was introduced in version 2.0.3, by configuring [[yii\web\AssetManager]] like the following:

```php
return [
// ...
'components' => [
'assetManager' => [
'appendTimestamp' => true,
],
],
];
```

By doing so, the URL of every published asset will be appended with its last modification timestamp. For example,
the URL to `yii.js` may look like `/assets/5515a87c/yii.js?v=1423448645"`, where the parameter `v` represents the
last modification timestamp of the `yii.js` file. Now if you modify an asset, its URL will be changed, too, which causes
the client to fetch the latest version of the asset.


## Commonly Used Asset Bundles <span id="common-asset-bundles"></span>

The core Yii code has defined many asset bundles. Among them, the following bundles are commonly used and may
Expand Down
4 changes: 2 additions & 2 deletions framework/filters/PageCache.php
Original file line number Diff line number Diff line change
Expand Up @@ -91,8 +91,8 @@ class PageCache extends ActionFilter
*/
public $variations;
/**
* @var boolean whether to enable the fragment cache. You may use this property to turn on and off
* the fragment cache according to specific setting (e.g. enable fragment cache only for GET requests).
* @var boolean 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;
/**
Expand Down
26 changes: 24 additions & 2 deletions framework/web/AssetManager.php
Original file line number Diff line number Diff line change
Expand Up @@ -150,6 +150,15 @@ class AssetManager extends Component
* significantly degrade the performance.
*/
public $forceCopy = false;
/**
* @var boolean whether to append a timestamp to the URL of every published asset. When this is true,
* the URL of a published asset may look like `/path/to/asset?v=timestamp`, where `timestamp` is the
* last modification time of the published asset file.
* You normally would want to set this property to true when you have enabled HTTP caching for assets,
* because it allows you to bust caching when the assets are updated.
* @since 2.0.3
*/
public $appendTimestamp = false;

private $_dummyBundles = [];

Expand Down Expand Up @@ -252,9 +261,22 @@ protected function loadDummyBundle($name)
public function getAssetUrl($bundle, $asset)
{
if (($actualAsset = $this->resolveAsset($bundle, $asset)) !== false) {
return Url::isRelative($actualAsset) ? $this->baseUrl . '/' . $actualAsset : $actualAsset;
$asset = $actualAsset;
$basePath = $this->basePath;
$baseUrl = $this->baseUrl;
} else {
$basePath = $bundle->basePath;
$baseUrl = $bundle->baseUrl;
}

if (!Url::isRelative($asset)) {
return $asset;
}

if ($this->appendTimestamp && ($timestamp = @filemtime("$basePath/$asset")) > 0) {
return "$baseUrl/$asset?v=$timestamp";
} else {
return Url::isRelative($asset) ? $bundle->baseUrl . '/' . $asset : $asset;
return "$baseUrl/$asset";
}
}

Expand Down

0 comments on commit 0068a94

Please sign in to comment.