Seperti banyak rangka kerja lain, CakePHP juga menyokong Pengantarabangsaan. Kita perlu mengikut langkah-langkah ini untuk beralih daripada satu bahasa kepada berbilang bahasa.
Buat sumber direktori tempat yang berasingantempatan.
Buat subdirektori untuk setiap bahasa, di bawah direktori srcLocale. Nama subdirektori boleh terdiri daripada dua huruf kod ISO bahasa atau nama tempat penuh seperti en_US, fr_FR dll.
Buat fail default.po berasingan di bawah setiap subdirektori bahasa. Fail ini mengandungi entri dalam bentuk msgid dan msgstr, seperti yang ditunjukkan dalam atur cara berikut.
msgid "msg" msgstr "CakePHP Internationalization example."
Di sini, msgid ialah kunci yang akan digunakan dalam fail templat Lihat dan msgstr ialah nilai yang menyimpan terjemahan.
Dalam fail templat Lihat, kita boleh menggunakan msgid di atas, seperti yang ditunjukkan di bawah yang akan diterjemahkan berdasarkan nilai tempat yang ditetapkan.
<?php echo __('msg'); ?>
Petempatan lalai boleh ditetapkan dalam fail config/app.php melalui baris berikut.
'defaultLocale' => env('APP_DEFAULT_LOCALE', 'en_US')
Untuk menukar setempat semasa masa jalan, kita boleh menggunakan baris berikut.
use Cake\I18n\I18n; I18n::locale('de_DE');
Buat perubahan dalam fail config/routes.php seperti yang ditunjukkan dalam 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(); });
Buat fail LocalizationsController.php di src/Controller/LocalizationsController.php. Salin kod berikut dalam fail pengawal.
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); } } } ?>
Buat direktori tempatan di sumbertempatan. Buat 3 direktori yang dipanggil en_US, fr_FR, de_DE di bawah direktori locales. Cipta fail di bawah setiap direktori yang dipanggil default.po. Salin kod berikut dalam fail masing-masing.
sumber/locales/en_US/default.po
msgid "msg" msgstr "CakePHP Internationalization example."
sumber/locales/fr_FR/default.po
msgid "msg" msgstr "Exemple CakePHP internationalisation."
sumber/locales/de_DE/default.po
msgid "msg" msgstr "CakePHP Internationalisierung Beispiel."
Buat direktori Penyetempatan di src/Template dan di bawah direktori itu, buat fail Lihat bernama index.php. Salin kod berikut dalam fail itu.
src/Template/Localizations/index.php
Form->create(NULL,array('url'=>'/locale')); echo $this->Form->radio("locale", [ ['value'=>'en_US','text'=>'Pengantarabangsaan CakePHP'], ['value'=>'de_DE','text'=>'German'], ['value'=>'fr_FR','text'=>'French'], ] ); echo $this->Form->button('Change Language'); echo $this->Form->end(); ?> <?php echo __('msg'); ?>
Laksanakan contoh di atas dengan melawati URL berikut. http://localhost/cakephp4/locale
Setelah pelaksanaan, anda akan menerima output berikut.
CakePHP menyediakan kelas E-mel untuk mengurus fungsi berkaitan e-mel. Untuk menggunakan fungsi e-mel dalam mana-mana pengawal, kami perlu memuatkan kelas E-mel terlebih dahulu dengan menulis baris berikut.
use Cake\Mailer\Email;
Kelas E-mel menyediakan pelbagai kaedah berguna yang diterangkan di bawah.
Sintaks |
|
||||||||
---|---|---|---|---|---|---|---|---|---|
Parameter |
|
||||||||
Pemulangan |
|
||||||||
Penerangan | Ia menentukan dari alamat e-mel mana; e-mel akan dihantar
|
Sintaks | Kepada(rentetan|array|null $emailnull, string|null $namenull) |
---|---|
Parameter |
|
Pemulangan | tatasusunan|$ini |
Penerangan | Ia menentukan kepada siapa e-mel akan dihantar |
Sintaks | Hantar(rentetan|array|null $contentnull) |
---|---|
Parameter |
|
Pulangan | tatasusunan |
Penerangan | Hantar e-mel menggunakan kandungan, templat dan reka letak yang ditentukan |
Sintaks | Subjek(rentetan|null $subjectnull) |
---|---|
Parameter |
|
Pemulangan | tatasusunan|$ini |
Penerangan | Dapatkan/Tetapkan Subjek |
Syntax | Attachments(string|array|null $attachmentsnull) |
---|---|
Parameters |
|
Returns | array|$this |
Description | Add attachments to the email message |
Syntax | Bcc(string|array|null $emailnull, string|null $namenull) |
---|---|
Parameters |
|
Returns | array|$this |
Description | Bcc |
Syntax | cc( string|array|null $emailnull , string|null $namenull ) |
---|---|
Parameters |
|
Returns | array|$this |
Description | Cc |
Make changes in the config/routes.php file as shown in the following program.
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(); });
Create an EmailsController.php file at src/Controller/EmailsController.php. Copy the following code in the controller file.
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('abc@gmail.com') ->subject('About') ->send('My message'); } } ?>
Create a directory Emails at src/Template and under that directory, create a View file called index.php. Copy the following code in that file.
src/Template/Emails/index.php
Email Sent.
Before we send any email, we need to configure it. In the below screenshot, you can see that there are two transports, default and Gmail. We have used Gmail transport.
You need to replace the “GMAIL USERNAME” with your Gmail username and “APP PASSWORD” with your applications password. You need to turn on 2-step verification in Gmail and create a new APP password to send email.
config/app.php
Execute the above example by visiting the following URL − http://localhost/cakephp/email
Upon execution, you will receive the following output.
Atas ialah kandungan terperinci Pengantarabangsaan CakePHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!