Amazon SES API を使用して、カスタムの E メールテンプレートを作成し、AWSSDK for PHP バージョン 3 の SDK for - AWSSDK for PHP

翻訳は機械翻訳により提供されています。提供された翻訳内容と英語版の間で齟齬、不一致または矛盾がある場合、英語版が優先します。

Amazon SES API を使用して、カスタムの E メールテンプレートを作成し、AWSSDK for PHP バージョン 3 の SDK for

Amazon Simple Email Service (Amazon SES) では、テンプレートを使用して受取人ごとにパーソナライズされた E メールを送信できます。テンプレートには、件名、E メール本文のテキストパートと HTML パートが含まれています。件名および本文セクションには、受取人ごとにパーソナライズされたユニークな値を含めることもできます。

詳細については、「」を参照してください。Amazon SES を使用したパーソナライズされた E メールの送信Amazon Simple Email Service デベロッパーガイドを参照してください。

以下の例では、次の方法を示しています。

  • CreateTemplate を使用して E メールテンプレートを作成する。

  • ListTemplates を使用してすべての E メールテンプレートをリストする。

  • GetTemplate を使用して E メールテンプレートを取得する。

  • UpdateTemplate を使用して E メールテンプレートを更新する。

  • DeleteTemplate を使用して E メールテンプレートを削除する。

  • SendTemplatedEmail を使用してテンプレート E メールを送信する。

用のすべてのサンプルコードはAWSSDK for PHP バージョン 3 の SDK for PHP バージョン 3GitHub で。

Credentials

サンプルコードを実行する前に、AWS「」の説明に従っての認証情報例の認証情報AWSSDK for PHP バージョン 3 の SDK for。次にをインポートします。AWSSDK for PHP(の基本的な使用パターンAWSSDK for PHP バージョン 3 の SDK for

Amazon SES の使用方法については、「」を参照してください。Amazon SES デベロッパーガイド

E メールテンプレートを作成する

パーソナライズされた E メールメッセージを送信するためのテンプレートを作成するには、CreateTemplate オペレーションを使用します。このテンプレートは、メッセージの送信が承認されたどのアカウントでも、AWSテンプレートが追加されるリージョン。

注記

Amazon SES では HTML を検証しないため、必ずHtmlPartは電子メールを送信する前に有効です。

インポート

require 'vendor/autoload.php'; use Aws\Ses\SesClient; use Aws\Exception\AwsException;

サンプルコード

$SesClient = new Aws\Ses\SesClient([ 'profile' => 'default', 'version' => '2010-12-01', 'region' => 'us-east-2' ]); $name = 'Template_Name'; $html_body = '<h1>AWS Amazon Simple Email Service Test Email</h1>' . '<p>This email was sent with <a href="https://aws.amazon.com/ses/">' . 'Amazon SES</a> using the <a href="https://aws.amazon.com/sdk-for-php/">' . 'AWS SDK for PHP</a>.</p>'; $subject = 'Amazon SES test (AWS SDK for PHP)'; $plaintext_body = 'This email was send with Amazon SES using the AWS SDK for PHP.'; try { $result = $SesClient->createTemplate([ 'Template' => [ 'HtmlPart' => $html_body, 'SubjectPart' => $subject, 'TemplateName' => $name, 'TextPart' => $plaintext_body, ], ]); var_dump($result); } catch (AwsException $e) { // output error message if fails echo $e->getMessage(); echo "\n"; }

E メールテンプレートを取得する

件名、HTML 本文、プレーンテキストを含む既存の E メールテンプレートのコンテンツを表示するには、GetTemplate オペレーションを使用します。TemplateName のみ必須です。

インポート

require 'vendor/autoload.php'; use Aws\Ses\SesClient; use Aws\Exception\AwsException;

サンプルコード

$SesClient = new Aws\Ses\SesClient([ 'profile' => 'default', 'version' => '2010-12-01', 'region' => 'us-east-2' ]); $name = 'Template_Name'; try { $result = $SesClient->getTemplate([ 'TemplateName' => $name, ]); var_dump($result); } catch (AwsException $e) { // output error message if fails echo $e->getMessage(); echo "\n"; }

すべての E メールテンプレートをリストする

アカウントに関連付けられているすべての E メールテンプレートのリストを取得するにはAWSアカウントのAWSリージョンで、ListTemplatesオペレーション.

インポート

require 'vendor/autoload.php'; use Aws\Ses\SesClient; use Aws\Exception\AwsException;

サンプルコード

$SesClient = new Aws\Ses\SesClient([ 'profile' => 'default', 'version' => '2010-12-01', 'region' => 'us-east-2' ]); try { $result = $SesClient->listTemplates([ 'MaxItems' => 10, ]); var_dump($result); } catch (AwsException $e) { // output error message if fails echo $e->getMessage(); echo "\n"; }

E メールテンプレートを更新する

件名、HTML 本文、プレーンテキストを含む特定の E メールテンプレートのコンテンツを変更するには、UpdateTemplate オペレーションを使用します。

インポート

require 'vendor/autoload.php'; use Aws\Ses\SesClient; use Aws\Exception\AwsException;

サンプルコード

$SesClient = new Aws\Ses\SesClient([ 'profile' => 'default', 'version' => '2010-12-01', 'region' => 'us-east-2' ]); $name = 'Template_Name'; $html_body = '<h1>AWS Amazon Simple Email Service Test Email</h1>' . '<p>This email was sent with <a href="https://aws.amazon.com/ses/">' . 'Amazon SES</a> using the <a href="https://aws.amazon.com/sdk-for-php/">' . 'AWS SDK for PHP</a>.</p>'; $subject = 'Amazon SES test (AWS SDK for PHP)'; $plaintext_body = 'This email was send with Amazon SES using the AWS SDK for PHP.'; try { $result = $SesClient->updateTemplate([ 'Template' => [ 'HtmlPart' => $html_body, 'SubjectPart' => $subject, 'TemplateName' => $name, 'TextPart' => $plaintext_body, ], ]); var_dump($result); } catch (AwsException $e) { // output error message if fails echo $e->getMessage(); echo "\n"; }

E メールテンプレートを削除する

特定の E メールテンプレートを削除するには、DeleteTemplate オペレーションを使用します。必要なのは TemplateName だけです。

インポート

require 'vendor/autoload.php'; use Aws\Ses\SesClient; use Aws\Exception\AwsException;

サンプルコード

$SesClient = new Aws\Ses\SesClient([ 'profile' => 'default', 'version' => '2010-12-01', 'region' => 'us-east-2' ]); $name = 'Template_Name'; try { $result = $SesClient->deleteTemplate([ 'TemplateName' => $name, ]); var_dump($result); } catch (AwsException $e) { // output error message if fails echo $e->getMessage(); echo "\n"; }

テンプレートを使用して E メールを送信する

テンプレートを使用して E メールを受取人に送信するには、SendTemplatedEmail オペレーションを使用します。

インポート

require 'vendor/autoload.php'; use Aws\Ses\SesClient; use Aws\Exception\AwsException;

サンプルコード

$SesClient = new Aws\Ses\SesClient([ 'profile' => 'default', 'version' => '2010-12-01', 'region' => 'us-east-2' ]); $template_name = 'Template_Name'; $sender_email = 'email_address'; $recipient_emails = ['email_address']; try { $result = $SesClient->sendTemplatedEmail([ 'Destination' => [ 'ToAddresses' => $verified_recipient_emails, ], 'ReplyToAddresses' => [$sender_email], 'Source' => $sender_email, 'Template' => $template_name, 'TemplateData' => '{ }' ]); var_dump($result); } catch (AwsException $e) { // output error message if fails echo $e->getMessage(); echo "\n"; }