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 |
|
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 |
|
Kembali | array | $ ini |
Deskripsi | Ini menentukan kepada siapa email akan dikirim |
Sintaksis | Kirim (string | array | null $ content null) |
---|---|
Parameter |
|
Kembali | Himpunan |
Deskripsi | Kirim email menggunakan konten, template, dan tata letak yang ditentukan |
Sintaksis | Subjek (string | null $ subject null) |
---|---|
Parameter |
|
Kembali | array | $ ini |
Deskripsi | Dapatkan / Tetapkan Subjek |
Sintaksis | Lampiran (string | array | null $ attachment snull) |
---|---|
Parameter |
|
Kembali | array | $ ini |
Deskripsi | Tambahkan lampiran ke pesan email |
Sintaksis | Bcc (string | array | null $ email null, string | null $ nama null) |
---|---|
Parameter |
|
Kembali | array | $ ini |
Deskripsi | Bcc |
Sintaksis | cc (string | array | null $ email null, string | null $ nama null) |
---|---|
Parameter |
|
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.