Heim > Artikel > Backend-Entwicklung > CakePHP-Internationalisierung
Wie viele andere Frameworks unterstützt auch CakePHP die Internationalisierung. Wir müssen diese Schritte befolgen, um von einer einzelnen Sprache zu mehreren Sprachen zu wechseln.
Erstellen Sie ein separates Gebietsschema-Verzeichnis „Ressourcen“Gebietsschemas.
Erstellen Sie für jede Sprache ein Unterverzeichnis unter dem Verzeichnis srcLocale. Der Name des Unterverzeichnisses kann ein zweibuchstabiger ISO-Code der Sprache oder ein vollständiger Gebietsschemaname wie en_US, fr_FR usw. sein.
Erstellen Sie in jedem Unterverzeichnis der Sprache eine separate Datei default.po. Diese Datei enthält Einträge in der Form msgid und msgstr, wie im folgenden Programm gezeigt.
msgid "msg" msgstr "CakePHP Internationalization example."
Hier ist msgid der Schlüssel, der in der View-Vorlagendatei verwendet wird, und msgstr ist der Wert, der die Übersetzung speichert.
In der View-Vorlagendatei können wir die obige msgid verwenden, wie unten gezeigt, die basierend auf dem festgelegten Wert von locale übersetzt wird.
<?php echo __('msg'); ?>
Das Standardgebietsschema kann in der Datei config/app.php durch die folgende Zeile festgelegt werden.
'defaultLocale' => env('APP_DEFAULT_LOCALE', 'en_US')
Um das Lokal zur Laufzeit zu ändern, können wir die folgenden Zeilen verwenden.
use Cake\I18n\I18n; I18n::locale('de_DE');
Nehmen Sie Änderungen in der Datei config/routes.php vor, wie im folgenden Programm gezeigt.
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(); });
Erstellen Sie eine LocalizationsController.php-Datei unter src/Controller/LocalizationsController.php. Kopieren Sie den folgenden Code in die Controller-Datei.
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); } } } ?>
Erstellen Sie ein Verzeichnis locales unter resourceslocales. Erstellen Sie drei Verzeichnisse mit den Namen en_US, fr_FR, de_DE im Verzeichnis „locales“. Erstellen Sie unter jedem Verzeichnis eine Datei mit dem Namen default.po. Kopieren Sie den folgenden Code in die entsprechende Datei.
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."
Erstellen Sie ein Verzeichnis Localizations unter src/Template und erstellen Sie unter diesem Verzeichnis eine View-Datei mit dem Namen index.php. Kopieren den folgenden Code in dieser Datei.
src/Template/Localizations/index.php
Form->create(NULL,array('url'=>'/locale')); echo $this->Form->radio("locale", [ ['value'=>'en_US','text'=>'CakePHP-Internationalisierung'], ['value'=>'de_DE','text'=>'German'], ['value'=>'fr_FR','text'=>'French'], ] ); echo $this->Form->button('Change Language'); echo $this->Form->end(); ?> <?php echo __('msg'); ?>
Führen Sie das obige Beispiel aus, indem Sie die folgende URL besuchen. http://localhost/cakephp4/locale
Bei der Ausführung erhalten Sie die folgende Ausgabe.
CakePHP bietet einen E-Mail-Kurs zur Verwaltung von E-Mail-bezogenen Funktionen. Um die E-Mail-Funktionalität in einem beliebigen Controller nutzen zu können, müssen wir zunächst die E-Mail-Klasse laden, indem wir die folgende Zeile schreiben.
use Cake\Mailer\Email;
Die E-Mail-Klasse bietet verschiedene nützliche Methoden, die unten beschrieben werden.
Syntax |
|
||||||||
---|---|---|---|---|---|---|---|---|---|
Parameter |
|
||||||||
Returns |
|
||||||||
Beschreibung | Es gibt an, von welcher E-Mail-Adresse; Die E-Mail wird gesendet
|
Syntax | To(string|array|null $emailnull, string|null $namenull) |
---|---|
Parameter |
|
Returns | array|$this |
Beschreibung | Gibt an, an wen die E-Mail gesendet wird |
Syntax | Send(string|array|null $contentnull) |
---|---|
Parameter |
|
Rückgabe | Array |
Beschreibung | Senden Sie eine E-Mail mit dem angegebenen Inhalt, der angegebenen Vorlage und dem angegebenen Layout |
Syntax | Subject(string|null $subjectnull) |
---|---|
Parameter |
|
Returns | array|$this |
Beschreibung | Betreff abrufen/festlegen |
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.
Das obige ist der detaillierte Inhalt vonCakePHP-Internationalisierung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!