Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Pengantarabangsaan CakePHP

Pengantarabangsaan CakePHP

PHPz
PHPzasal
2024-09-10 17:26:30534semak imbas

Seperti banyak rangka kerja lain, CakePHP juga menyokong Pengantarabangsaan. Kita perlu mengikut langkah-langkah ini untuk beralih daripada satu bahasa kepada berbilang bahasa.

Langkah 1

Buat sumber direktori tempat yang berasingantempatan.

Langkah 2

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.

Langkah 3

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.

Langkah 4

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

Contoh

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

Output

Setelah pelaksanaan, anda akan menerima output berikut.

Pengantarabangsaan CakePHP

E-mel

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
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

Dari(rentetan|array|null $email null, string|null $name null )
Parameter
  • Rentetan dengan e-mel
    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

  • Nama
Pemulangan
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

tatasusunan|$ini
Penerangan
Ia menentukan dari alamat e-mel mana; e-mel akan dihantar
Syntax

Subject(string|null $subjectnull)

Parameters
  • Subject string

Returns

array|$this

Description

Get/Set Subject

Sintaks Kepada(rentetan|array|null $emailnull, string|null $namenull)
Parameter
  • Rentetan dengan e-mel
  • Nama
Pemulangan tatasusunan|$ini
Penerangan Ia menentukan kepada siapa e-mel akan dihantar
Sintaks Hantar(rentetan|array|null $contentnull)
Parameter
  • Rentetan dengan mesej atau tatasusunan dengan mesej.
Pulangan tatasusunan
Penerangan Hantar e-mel menggunakan kandungan, templat dan reka letak yang ditentukan
Sintaks Subjek(rentetan|null $subjectnull)
Parameter
  • Rentetan subjek
Pemulangan tatasusunan|$ini
Penerangan Dapatkan/Tetapkan Subjek
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

Atas ialah kandungan terperinci Pengantarabangsaan CakePHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel sebelumnya:Pengendalian Borang CakePHPArtikel seterusnya:Pengendalian Borang CakePHP