Yii - RESTful API sedang beraksi

Kelas pengontrol diturunkan dari yii\rest\ActiveControllerkelas, yang mengimplementasikan tindakan RESTful umum. Kami menentukan$modelClass properti sehingga pengontrol mengetahui model mana yang digunakan untuk memanipulasi data.

Step 1 - Buat file bernama UserController.php di dalam folder pengontrol.

<?php
   namespace app\controllers;
   use yii\rest\ActiveController;
   class UserController extends ActiveController {
      public $modelClass = 'app\models\MyUser';
   }
?>

Selanjutnya kita perlu menyiapkan komponen urlManager, sehingga data pengguna dapat diakses dan dimanipulasi dengan kata kerja HTTP yang berarti dan URL yang cantik. Untuk mengizinkan API mengakses data di JSON, kita harus mengonfigurasi properti parsers darirequest komponen aplikasi.

Step 2 - Ubah config/web.php mengajukan dengan cara ini -

<?php
   $params = require(__DIR__ . '/params.php'); $config = [
      'id' => 'basic',
      'basePath' => dirname(__DIR__),
      'bootstrap' => ['log'],
      'components' => [
         'request' => [
            // !!! insert a secret key in the following (if it is empty) - this is 
               //required by cookie validation
            'cookieValidationKey' => 'ymoaYrebZHa8gURuolioHGlK8fLXCKjO',
         ],
         'cache' => [
            'class' => 'yii\caching\FileCache',
         ],
         'user' => [
            'identityClass' => 'app\models\User',
            'enableAutoLogin' => true,
         ],
         'errorHandler' => [
            'errorAction' => 'site/error',
         ],
         'mailer' => [
            'class' => 'yii\swiftmailer\Mailer',
            // send all mails to a file by default. You have to set
            // 'useFileTransport' to false and configure a transport
            // for the mailer to send real emails.
            'useFileTransport' => true,
         ],
         'log' => [
            'traceLevel' => YII_DEBUG ? 3 : 0,
            'targets' => [
               [
                  'class' => 'yii\log\FileTarget',
                  'levels' => ['error', 'warning'],
               ],
            ],
         ],
         'urlManager' => [
            'enablePrettyUrl' => true,
            'enableStrictParsing' => true,
            'showScriptName' => false,
            'rules' => [
               ['class' => 'yii\rest\UrlRule', 'controller' => 'user'],
            ],
         ],
         'request' => [
            'parsers' => [
               'application/json' => 'yii\web\JsonParser',
            ]
         ],
         'db' => require(__DIR__ . '/db.php'),
      ],
      'modules' => [
         'hello' => [
            'class' => 'app\modules\hello\Hello',
         ],
      ],
      'params' => $params, ]; if (YII_ENV_DEV) { // configuration adjustments for 'dev' environment $config['bootstrap'][] = 'debug';
      $config['modules']['debug'] = [ 'class' => 'yii\debug\Module', ]; $config['bootstrap'][] = 'gii';
      $config['modules']['gii'] = [ 'class' => 'yii\gii\Module', ]; } return $config;
?>

Dengan sedikit usaha, kami baru saja membuat API RESTful untuk mengakses data pengguna. API tersebut meliputi -

  • GET /users - daftar semua pengguna halaman demi halaman

  • HEAD /users - menampilkan informasi ikhtisar daftar pengguna

  • POST /users - buat pengguna baru

  • GET /users/20 - mengembalikan detail pengguna 20

  • HEAD /users/20 - tampilkan informasi ikhtisar pengguna 20

  • PATCH /users/ 20 and PUT /users/20 - perbarui pengguna 20

  • DELETE /users/20 - hapus pengguna 20

  • OPTIONS /users - tampilkan kata kerja yang didukung terkait titik akhir / pengguna

  • OPTIONS /users/20 - tunjukkan kata kerja yang didukung terkait titik akhir / pengguna / 20

Perhatikan, bahwa Yii secara otomatis memajemukan nama pengontrol.

Step 3 - Sekarang, buka Postman, masuk http://localhost:8080/users, dan klik "Kirim". Anda akan melihat yang berikut ini.

Step 4 - Untuk membuat pengguna baru, ubah jenis permintaan ke POST, tambahkan dua parameter isi: nama dan email, dan klik "Kirim".

Step 5 - Anda bisa menggunakan fieldsparameter untuk menentukan bidang mana yang harus dimasukkan dalam hasil. Misalnya URLhttp://localhost:8080/users?fields=id, nama hanya akan mengembalikan id dan name bidang seperti yang ditunjukkan pada tangkapan layar berikut.