CakePHP-국제화

다른 많은 프레임 워크와 마찬가지로 CakePHP는 국제화도 지원합니다. 단일 언어에서 여러 언어로 이동하려면 다음 단계를 따라야합니다.

1 단계

별도의 로케일 디렉토리 리소스 생성 \locales.

2 단계

src \ Locale 디렉터리 아래에 각 언어에 대한 하위 디렉터리를 만듭니다. 하위 디렉토리의 이름은 언어의 두 글자 ISO 코드이거나 en_US, fr_FR 등과 같은 전체 로케일 이름 일 수 있습니다.

3 단계

별도 생성 default.po각 언어 하위 디렉토리 아래의 파일. 이 파일에는 다음 형식의 항목이 포함되어 있습니다.msgidmsgstr, 다음 프로그램과 같이.

msgid "msg"
msgstr "CakePHP Internationalization example."

여기, msgid View 템플릿 파일에서 사용될 키이며 msgstr 번역을 저장하는 값입니다.

4 단계

View 템플릿 파일에서 위의 msgid로케일 설정 값에 따라 번역됩니다.

<?php echo __('msg'); ?>

기본 로케일은 config/app.php 다음 줄로 파일을 작성하십시오.

'defaultLocale' => env('APP_DEFAULT_LOCALE', 'en_US')

런타임에 로컬을 변경하려면 다음 줄을 사용할 수 있습니다.

use Cake\I18n\I18n;
I18n::locale('de_DE');

다음 프로그램과 같이 config / routes.php 파일을 변경하십시오.

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();
});

만들기 LocalizationsController.php 파일 src/Controller/LocalizationsController.php. 컨트롤러 파일에 다음 코드를 복사합니다.

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);
         }
      }
   }
?>

만들기 locales resources \의 디렉토리locales. 라는 3 개의 디렉토리를 만듭니다.en_US, fr_FR, de_DE로케일 디렉토리 아래. 라는 각 디렉토리 아래에 파일을 만듭니다.default.po. 각 파일에 다음 코드를 복사합니다.

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

디렉토리 생성 Localizations ...에서 src/Template 그 디렉토리 아래에 View 라는 파일 index.php. 해당 파일에 다음 코드를 복사하십시오.

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

다음 URL을 방문하여 위의 예를 실행하십시오. http : // localhost / cakephp4 / locale

산출

실행하면 다음 출력이 표시됩니다.

이메일

CakePHP는 이메일 관련 기능을 관리하는 이메일 클래스를 제공합니다. 모든 컨트롤러에서 이메일 기능을 사용하려면 먼저 다음 줄을 작성하여 Email 클래스를로드해야합니다.

use Cake\Mailer\Email;

Email 클래스는 아래에 설명 된 다양한 유용한 방법을 제공합니다.

통사론

From (문자열 | 배열 | null $ email null, 문자열 | null $ name null)

매개 변수
  • 이메일이있는 문자열

  • Name

보고

배열 | $ this

기술

이메일 주소를 지정합니다. 이메일이 전송됩니다

통사론

받는 사람 (문자열 | 배열 | null $ email null, string | null $ name null)

매개 변수
  • 이메일이있는 문자열

  • Name

보고

배열 | $ this

기술

이메일을받을 사람을 지정합니다.

통사론

보내기 (문자열 | 배열 | null $ content null)

매개 변수
  • 메시지가있는 문자열 또는 메시지가있는 배열.

보고 정렬
기술

지정된 콘텐츠, 템플릿 및 레이아웃을 사용하여 이메일 보내기

통사론

제목 (문자열 | null $ subject null)

매개 변수
  • 제목 문자열

보고

배열 | $ this

기술

주제 가져 오기 / 설정

통사론

Attachments (string | array | null $ attachment snull)

매개 변수
  • 파일 이름이있는 문자열 또는 파일 이름이있는 배열

보고

배열 | $ this

기술

이메일 메시지에 첨부 파일 추가

통사론

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

매개 변수
  • 이메일이있는 문자열

  • Name

보고

배열 | $ this

기술

숨은 참조

통사론

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

매개 변수
  • 이메일이있는 문자열

  • Name

보고

배열 | $ this

기술

참조

다음 프로그램과 같이 config / routes.php 파일을 변경하십시오.

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();
});

만들기 EmailsController.php 파일 src/Controller/EmailsController.php. 컨트롤러 파일에 다음 코드를 복사합니다.

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

디렉토리 생성 Emails ...에서 src/Template 그 디렉토리 아래에 View 파일을 만듭니다. index.php. 해당 파일에 다음 코드를 복사하십시오.

src/Template/Emails/index.php

Email Sent.

이메일을 보내기 전에 구성해야합니다. 아래 스크린 샷에서 기본 및 Gmail의 두 가지 전송이 있음을 알 수 있습니다. 우리는 Gmail 전송을 사용했습니다.

"GMAIL USERNAME"을 Gmail 사용자 이름으로, "APP PASSWORD"를 애플리케이션 비밀번호로 바꿔야합니다. Gmail에서 2 단계 인증을 켜고 이메일을 보내려면 새 APP 비밀번호를 만들어야합니다.

config/app.php

다음 URL을 방문하여 위의 예를 실행하십시오-http : // localhost / cakephp / email

산출

실행하면 다음 출력이 표시됩니다.