CakePHP - Internasionalisasi

Seperti banyak kerangka kerja lainnya, CakePHP juga mendukung Internasionalisasi. Kita perlu mengikuti langkah-langkah ini untuk beralih dari satu bahasa ke banyak bahasa.

Langkah 1

Buat sumber daya direktori lokal terpisah \locales.

Langkah 2

Buat subdirektori untuk setiap bahasa, di bawah direktori src \ Locale. Nama subdirektori dapat berupa kode ISO dua huruf dari bahasa tersebut atau nama lokal lengkap seperti en_US, fr_FR, dll.

LANGKAH 3

Buat terpisah default.pofile di bawah setiap subdirektori bahasa. File ini berisi entri dalam bentukmsgid dan msgstr, seperti yang ditunjukkan pada program berikut.

msgid "msg"
msgstr "CakePHP Internationalization example."

Di sini msgid adalah kunci yang akan digunakan dalam file template View dan msgstr adalah nilai yang menyimpan terjemahan.

LANGKAH 4

Di file View template, kita bisa menggunakan cara di atas msgid, seperti yang ditunjukkan di bawah ini yang akan diterjemahkan berdasarkan nilai lokal yang ditetapkan.

<?php echo __('msg'); ?>

Lokal default dapat diatur di config/app.php file dengan baris berikut.

'defaultLocale' => env('APP_DEFAULT_LOCALE', 'en_US')

Untuk mengubah lokal saat runtime, kita dapat menggunakan baris berikut.

use Cake\I18n\I18n;
I18n::locale('de_DE');

Contoh

Lakukan perubahan pada file config / routes.php seperti yang ditunjukkan pada program berikut.

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class);
$routes->scope('/', function (RouteBuilder $builder) {
   $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
      'httpOnly' => true,
   ]));
   $builder->applyMiddleware('csrf');
   //$builder->connect('/pages',
      ['controller'=>'Pages','action'=>'display', 'home']);
   $builder->connect('locale',
      ['controller'=>'Localizations','action'=>'index']);
   $builder->fallbacks();
});

Membuat LocalizationsController.php mengajukan di src/Controller/LocalizationsController.php. Salin kode berikut di file pengontrol.

src/Controller/LocalizationsController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   use Cake\I18n\I18n;
   class LocalizationsController extends AppController {
      public function index() {
         if($this->request->is('post')) {
            $locale = $this->request->getData('locale');
            I18n::setLocale($locale);
         }
      }
   }
?>

Membuat locales direktori di resource \locales. Buat 3 direktori bernamaen_US, fr_FR, de_DEdi bawah direktori locales. Buat file di bawah setiap direktori yang disebutdefault.po. Salin kode berikut di file masing-masing.

resources/locales/en_US/default.po

msgid "msg"
msgstr "CakePHP Internationalization example."

resources/locales/fr_FR/default.po

msgid "msg"
msgstr "Exemple CakePHP internationalisation."

resources/locales/de_DE/default.po

msgid "msg"
msgstr "CakePHP Internationalisierung Beispiel."

Buat direktori Localizations di src/Template dan di bawah direktori itu, buat file View file bernama index.php. Salin kode berikut di file itu.

src/Template/Localizations/index.php

<?php
   echo $this->Form->create(NULL,array('url'=>'/locale'));
   echo $this->Form->radio("locale",
      [
         ['value'=>'en_US','text'=>'English'],
         ['value'=>'de_DE','text'=>'German'],
         ['value'=>'fr_FR','text'=>'French'],
      ]
   );
   echo $this->Form->button('Change Language');
   echo $this->Form->end();
?>
<?php echo __('msg'); ?>

Jalankan contoh di atas dengan mengunjungi URL berikut. http: // localhost / cakephp4 / locale

Keluaran

Setelah dieksekusi, Anda akan menerima keluaran berikut.

Surel

CakePHP menyediakan kelas Email untuk mengelola fungsi terkait email. Untuk menggunakan fungsionalitas email di pengontrol apa pun, pertama-tama kita perlu memuat kelas Email dengan menulis baris berikut.

use Cake\Mailer\Email;

Kelas Email menyediakan berbagai metode berguna yang dijelaskan di bawah ini.

Sintaksis

Dari (string | array | null $ email null, string | null $ name null)

Parameter
  • String dengan email

  • Name

Kembali

array | $ ini

Deskripsi

Ini menentukan dari mana alamat email; email akan terkirim

Sintaksis

Kepada (string | array | null $ email null, string | null $ name null)

Parameter
  • String dengan email

  • Name

Kembali

array | $ ini

Deskripsi

Ini menentukan kepada siapa email akan dikirim

Sintaksis

Kirim (string | array | null $ content null)

Parameter
  • String dengan pesan atau array dengan pesan.

Kembali Himpunan
Deskripsi

Kirim email menggunakan konten, template, dan tata letak yang ditentukan

Sintaksis

Subjek (string | null $ subject null)

Parameter
  • String subjek

Kembali

array | $ ini

Deskripsi

Dapatkan / Tetapkan Subjek

Sintaksis

Lampiran (string | array | null $ attachment snull)

Parameter
  • String dengan nama file atau array dengan nama file

Kembali

array | $ ini

Deskripsi

Tambahkan lampiran ke pesan email

Sintaksis

Bcc (string | array | null $ email null, string | null $ nama null)

Parameter
  • String dengan email

  • Name

Kembali

array | $ ini

Deskripsi

Bcc

Sintaksis

cc (string | array | null $ email null, string | null $ nama null)

Parameter
  • String dengan email

  • Name

Kembali

array | $ ini

Deskripsi

Cc

Contoh

Lakukan perubahan pada file config / routes.php seperti yang ditunjukkan pada program berikut.

config/routes.php

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class);
$routes->scope('/', function (RouteBuilder $builder) {
   $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
      'httpOnly' => true,
   ]));
   $builder->applyMiddleware('csrf');
   //$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']);
   $builder->connect('/email',['controller'=>'Emails','action'=>'index']);
   $builder->fallbacks();
});

Buat EmailsController.php mengajukan di src/Controller/EmailsController.php. Salin kode berikut di file pengontrol.

src/Controller/EmailsController.php

<?php
   namespace App\Controller;
   use App\Controller\AppController;
   use Cake\Mailer\Email;
   class EmailsController extends AppController{
      public function index(){
         $email = new Email('default');
         $email->to('[email protected]')
            ->subject('About')
            ->send('My message');
      }
   }
?>

Buat direktori Emails di src/Template dan di bawah direktori itu, buat file View bernama index.php. Salin kode berikut di file itu.

src/Template/Emails/index.php

Email Sent.

Sebelum kami mengirim email apa pun, kami perlu mengkonfigurasinya. Pada gambar di bawah, Anda dapat melihat bahwa ada dua transport, default dan Gmail. Kami telah menggunakan transportasi Gmail.

Anda perlu mengganti "GMAIL USERNAME" dengan nama pengguna Gmail Anda dan "APP PASSWORD" dengan sandi aplikasi Anda. Anda perlu mengaktifkan verifikasi 2 langkah di Gmail dan membuat kata sandi APP baru untuk mengirim email.

config/app.php

Jalankan contoh di atas dengan mengunjungi URL berikut - http: // localhost / cakephp / email

Keluaran

Setelah dieksekusi, Anda akan menerima keluaran berikut.