Yii - Cache Fragmen

Caching fragmen menyediakan cache dari sebuah fragmen halaman web.

Step 1 - Tambahkan fungsi baru yang disebut actionFragmentCaching() ke SiteController.

public function actionFragmentCaching() {
   $user = new MyUser(); $user->name = "cached user name";
   $user->email = "[email protected]"; $user->save();
   $models = MyUser::find()->all(); return $this->render('cachedview', ['models' => $models]);
}

Pada kode di atas, kami membuat pengguna baru dan menampilkan file cachedview Lihat file.

Step 2 - Sekarang, buat file baru bernama cachedview.php dalam views/site map.

<?php if ($this->beginCache('cachedview')) { ?>
   <?php foreach ($models as $model): ?>
      <?= $model->id; ?> <?= $model->name; ?>
      <?= $model->email; ?> <br/> <?php endforeach; ?> <?php $this->endCache(); } ?>
<?php echo "Count:", \app\models\MyUser::find()->count(); ?>

Kami telah menyertakan logika pembuatan konten dalam pasangan metode beginCache () dan endCache (). Jika konten ditemukan dalam cache, metode beginCache () akan merendernya.

Step 3 - Buka URL http://localhost:8080/index.php?r=site/fragment-cachingdan muat ulang halaman. Berikut akan menjadi keluarannya.

Perhatikan, bahwa konten antara metode beginCache () dan endCache () di-cache. Dalam database, kami memiliki 13 pengguna tetapi hanya 12 yang ditampilkan.

Caching Halaman

Caching halaman menyediakan caching konten seluruh halaman web. Caching halaman didukung olehyii\filter\PageCache.

Step 1 - Ubah behaviors() fungsi SiteController.

public function behaviors() {
   return [
      'access' => [
         'class' => AccessControl::className(),
         'only' => ['logout'],
         'rules' => [
            [
               'actions' => ['logout'],
               'allow' => true,
               'roles' => ['@'],
            ],
         ],
      ],
      'verbs' => [
         'class' => VerbFilter::className(),
         'actions' => [
            'logout' => ['post'],
         ],
      ],
      [
         'class' => 'yii\filters\PageCache',
         'only' => ['index'],
         'duration' => 60
      ],
   ];
}

Kode di atas menyimpan halaman indeks selama 60 detik.

Step 2 - Buka URL http://localhost:8080/index.php?r=site/index. Kemudian, ubah pesan ucapan selamat dari file tampilan indeks. Jika Anda memuat ulang halaman, Anda tidak akan melihat perubahan apa pun karena halaman tersebut di-cache. Tunggu sebentar dan muat ulang halaman tersebut lagi.

Cache HTTP

Aplikasi web juga dapat menggunakan cache sisi klien. Untuk menggunakannya, Anda dapat mengkonfigurasi fileyii\filter\HttpCache filter untuk tindakan pengontrol.

Header Last-Modified menggunakan stempel waktu untuk menunjukkan apakah halaman telah dimodifikasi.

Step 1 - Untuk mengaktifkan pengiriman tajuk Last-Modified, konfigurasi properti yii \ filter \ HttpCache :: $ lastModified.

public function behaviors() {
   return [
      [
         'class' => 'yii\filters\HttpCache',
         'only' => ['index'],
         'lastModified' => function ($action, $params) { $q = new \yii\db\Query();
            return $q->from('news')->max('created_at');
         },
      ],
   ];
}

Pada kode di atas, kami mengaktifkan cache HTTP hanya untuk halaman indeks. Saat browser membuka halaman indeks untuk pertama kalinya, halaman tersebut dibuat di sisi server dan dikirim ke browser. Kedua kalinya, jika tidak ada berita yang dibuat, server tidak akan membuat ulang halaman.

Header Etag menyediakan hash yang mewakili konten halaman. Jika halaman diubah, hash juga akan berubah.

Step 2 - Untuk mengaktifkan pengiriman header Etag, konfigurasikan file yii\filters\HttpCache::$etagSeed Properti.

public function behaviors() {
   return [
      [
         'class' => 'yii\filters\HttpCache',
         'only' => ['index'],
         'etagSeed' => function ($action, $params) {
            $user = $this->findModel(\Yii::$app->request->get('id')); return serialize([$user->name, $user->email]);
         },
      ],
   ];
}

Pada kode di atas, kami mengaktifkan cache HTTP untuk indextindakan saja. Ini harus menghasilkan header HTTP Etag berdasarkan nama dan email pengguna. Saat browser membuka halaman indeks untuk pertama kalinya, halaman tersebut dibuat di sisi server dan dikirim ke browser. Kedua kalinya, jika tidak ada perubahan pada nama atau email, server tidak akan membuat ulang halaman.