Heim  >  Artikel  >  Backend-Entwicklung  >  CakePHP-Internationalisierung

CakePHP-Internationalisierung

PHPz
PHPzOriginal
2024-09-10 17:26:30511Durchsuche

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.

Schritt 1

Erstellen Sie ein separates Gebietsschema-Verzeichnis „Ressourcen“Gebietsschemas.

Schritt 2

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.

Schritt 3

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.

Schritt 4

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');

Beispiel

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

Ausgabe

Bei der Ausführung erhalten Sie die folgende Ausgabe.

CakePHP-Internationalisierung

E-Mail

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
Syntax

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

Parameters
  • String with email

  • Name

Returns

array|$this

Description

It specifies from which email address; the email will be sent

From(string|array|null $email null, string|null $name null )
Parameter
  • String mit E-Mail
    Syntax

    To(string|array|null $emailnull, string|null $namenull)

    Parameters
    • String with email

    • Name

    Returns

    array|$this

    Description

    It specifies to whom the email will be sent

  • Name
Returns
Syntax

Send(string|array|null $contentnull)

Parameters
  • String with message or array with messages.

Returns array
Description

Send an email using the specified content, template and layout

array|$this
Beschreibung
Es gibt an, von welcher E-Mail-Adresse; Die E-Mail wird gesendet
Syntax

Subject(string|null $subjectnull)

Parameters
  • Subject string

Returns

array|$this

Description

Get/Set Subject

Syntax To(string|array|null $emailnull, string|null $namenull)
Parameter
  • String mit E-Mail
  • Name
Returns array|$this
Beschreibung Gibt an, an wen die E-Mail gesendet wird
Syntax Send(string|array|null $contentnull)
Parameter
  • String mit Nachricht oder Array mit Nachrichten.
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
  • Betreffzeichenfolge
Returns array|$this
Beschreibung Betreff abrufen/festlegen
Syntax

Attachments(string|array|null $attachmentsnull)

Parameters
  • String with the filename or array with filenames

Returns

array|$this

Description

Add attachments to the email message

Syntax

Bcc(string|array|null $emailnull, string|null $namenull)

Parameters
  • String with email

  • Name

Returns

array|$this

Description

Bcc

Syntax

cc( string|array|null $emailnull , string|null $namenull )

Parameters
  • String with email

  • Name

Returns

array|$this

Description

Cc

Example

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

Program App

Execute the above example by visiting the following URL − http://localhost/cakephp/email

Output

Upon execution, you will receive the following output.

Documents Api

Das obige ist der detaillierte Inhalt vonCakePHP-Internationalisierung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn