Laravel Mailchimp

取得 API Key

登入 MailChimp 後,在右上方帳號選單中,選擇 Account

帳號選單

在帳號選單頁面中,選擇 Extras 選單中的 API keys

帳號選單 Extra Menu API Key

在 API keys 頁面中,點選 Create A Key,建立 API Key

建立 API Key 開始

點選完後就可以看到你的 API Key 了

建立 API Key 完成

取得 API 網址前綴

在 API 的網址可以看到前方有 <dc> 的字樣,<dc> 是要看自己所屬的服務是哪一個區域,可以登入 MailChimp 後從網址那邊取得如下

https://<dc>.api.mailchimp.com/3.0

可以看到網址是 https://us19.admin.mailchimp.com/lists/,所以 API Key 的 <dc> 就是 us19

網址

取得清單編號 List ID

Mailchimp 可以管理許多不同的郵件清單,為了管理清單資料,需要有清單編號(List ID),到清單頁點選您要管理的清單

清單頁

在清單頁從 Settings 選單中點選 List name and defaults 選項

網址

List name and defaults 頁面中可以看到清單編號(List ID)在右上方

網址

安裝套件

Laravel : ~5.1.0|~5.2.0|~5.3.0|~5.4.0

1. Composer 下載安裝

composer require "spatie/laravel-newsletter:3.7.*"

2. 設定 app.php

// config/app.php
return [
    'providers' => [
        ...
        Spatie\Newsletter\NewsletterServiceProvider::class,
        ...
    ],
    // config/app.php
    'aliases' => [
        ..
        'Newsletter' => Spatie\Newsletter\NewsletterFacade::class,
    ],
]

3. 發佈產生設定檔

php artisan vendor:publish --provider="Spatie\Newsletter\NewsletterServiceProvider"

4. 設定 Mailchimp API Key & List Key

config/laravel-newsletter.php 設定檔中可以設定 API Key & List Key

return [
    'apiKey' => env('MAILCHIMP_APIKEY'),
    'lists' => [
        'subscribers' => [
             'id' => env('MAILCHIMP_LIST_ID'),
        ],
    ],
];

可以到 .env 檔案中加入剛剛取得的 API Key & List Key

# .env
MAILCHIMP_APIKEY=xxxxxxx
MAILCHIMP_LIST_ID=yyyyyyy

是否有此 email

// 回傳 true or false
$is_member_exist = Newsletter::hasMember($email);

訂閱

$SubscribeMember = Newsletter::subscribe($email);

訂閱後,在回傳資料的 status 欄位會看到狀態為 subscribed,曾經訂閱過的使用者無法再使用 subscribe() 去做訂閱,需要用 subscribeOrUpdate() 方法去做訂閱的更新

$SubscribeMember = [
    "id"               => "b08f6000ef0269370bc6d664a0bc42ae",
    "email_address"    => "[email protected]",
    "unique_email_id"  => "0c5596db5d",
    "email_type"       => "html",
    "status"           => "subscribed",
    "merge_fields"     => [
        "FNAME"    => "",
        "LNAME"    => "",
        "ADDRESS"  => "",
        "PHONE"    => "",
        "BIRTHDAY" => "",
    ],
    "stats"            => [
        "avg_open_rate"  => 0,
        "avg_click_rate" => 0,
    ],
    "ip_signup"        => "",
    "timestamp_signup" => "",
    "ip_opt"           => "1.1.1.1",
    "timestamp_opt"    => "2018-08-24T08:30:44+00:00",
    "member_rating"    => 2,
    "last_changed"     => "2018-08-24T08:30:44+00:00",
    "language"         => "",
    "vip"              => false,
    "email_client"     => "",
    "location"         => [
        "latitude"     => 0,
        "longitude"    => 0,
        "gmtoff"       => 0,
        "dstoff"       => 0,
        "country_code" => "",
        "timezone"     => "",
    ],
    "tags_count"       => 0,
    "tags"             => [],
    "list_id"          => "9fe4ab289a",
];

取得會員資料

$Member = Newsletter::getMember($email);
$Member = [
    "id"               => "4bd1ccfqwdqwbtrbrtc8e064b7e037b5826",
    "email_address"    => "[email protected]",
    "unique_email_id"  => "20bb281925",
    "email_type"       => "html",
    "status"           => "subscribed",
    "merge_fields"     => [
        "FNAME"    => "KJ",
        "LNAME"    => "Proj",
        "ADDRESS"  => [
            "addr1"   => "",
            "addr2"   => "",
            "city"    => "",
            "state"   => "",
            "zip"     => "",
            "country" => "US",
        ],
        "PHONE"    => "",
        "BIRTHDAY" => "",
    ],
    "stats"            => [
        "avg_open_rate"  => 0,
        "avg_click_rate" => 0,
    ],
    "ip_signup"        => "",
    "timestamp_signup" => "",
    "ip_opt"           => "1.1.1.1",
    "timestamp_opt"    => "2018-08-24T07:16:30+00:00",
    "member_rating"    => 2,
    "last_changed"     => "2018-08-24T07:16:30+00:00",
    "language"         => "en",
    "vip"              => false,
    "email_client"     => "",
    "location"         => [
        "latitude"     => 0,
        "longitude"    => 0,
        "gmtoff"       => 0,
        "dstoff"       => 0,
        "country_code" => "",
        "timezone"     => "",
    ],
    "tags_count"       => 0,
    "tags"             => [],
    "list_id"          => "9fe4ab289a",
];

解除訂閱

Newsletter::unsubscribe($email);

解除訂閱後,在回傳資料的 status 欄位會看到狀態為 unsubscribedunsubscribe_reason 則會看到為 N/A (Unsubscribed by admin)

$UnSubscribeMember = [
    "id"                 => "b08f6000ef0269370bc6d664a0bc42ae",
    "email_address"      => "[email protected]",
    "unique_email_id"    => "0c5596db5d",
    "email_type"         => "html",
    "status"             => "unsubscribed",
    "unsubscribe_reason" => "N/A (Unsubscribed by admin)",
    "merge_fields"       => [
        "FNAME"    => "",
        "LNAME"    => "",
        "ADDRESS"  => "",
        "PHONE"    => "",
        "BIRTHDAY" => "",
    ],
    "stats"              => [
        "avg_open_rate"  => 0,
        "avg_click_rate" => 0,
    ],
    "ip_signup"          => "",
    "timestamp_signup"   => "",
    "ip_opt"             => "1.1.1.1",
    "timestamp_opt"      => "2018-08-24T08:30:44+00:00",
    "member_rating"      => 2,
    "last_changed"       => "2018-08-24T08:57:21+00:00",
    "language"           => "",
    "vip"                => false,
    "email_client"       => "",
    "location"           => [
        "latitude"     => 0,
        "longitude"    => 0,
        "gmtoff"       => 0,
        "dstoff"       => 0,
        "country_code" => "",
        "timezone"     => "",
    ],
    "tags_count"         => 0,
    "tags"               => [],
    "list_id"            => "9fe4ab289a",
];

訂閱或更新使用者資料

$subscribe_member_info = [
    'FNAME'    => 'KJ',
    'LNAME'    => 'Hong',
    'PHONE'    => '0900000000',
];
$SubscribeMember = Newsletter::subscribeOrUpdate($email, subscribe_member_info);

訂閱後,在回傳資料的 status 欄位會看到狀態為 subscribed,也可以看到使用者的個人資料更新了

$SubscribeMember = [
    "id"               => "b08f6000ef0269370bc6d664a0bc42ae",
    "email_address"    => "[email protected]",
    "unique_email_id"  => "0c5596db5d",
    "email_type"       => "html",
    "status"           => "subscribed",
    "merge_fields"     => [
        "FNAME"    => "KJ",
        "LNAME"    => "Hong",
        "ADDRESS"  => "",
        "PHONE"    => "0900000000",
        "BIRTHDAY" => "",
    ],
    "stats"            => [
        "avg_open_rate"  => 0,
        "avg_click_rate" => 0,
    ],
    "ip_signup"        => "",
    "timestamp_signup" => "",
    "ip_opt"           => "1.1.1.1",
    "timestamp_opt"    => "2018-08-24T08:30:44+00:00",
    "member_rating"    => 2,
    "last_changed"     => "2018-08-24T09:11:58+00:00",
    "language"         => "",
    "vip"              => false,
    "email_client"     => "",
    "location"         => [
        "latitude"     => 0,
        "longitude"    => 0,
        "gmtoff"       => 0,
        "dstoff"       => 0,
        "country_code" => "",
        "timezone"     => "",
    ],
    "tags_count"       => 0,
    "tags"             => [],
    "list_id"          => "9fe4ab289a",
];

更新使用者 Email

$UpdateMemberEmail = Newsletter::updateEmailAddress($old_email, $new_email);

若新的 email 已存在,則會無法更新

$UpdateMemberEmail = [
    "id"               => "11d3e8047829c996b4602f92bdfdc2f9",
    "email_address"    => "[email protected]",
    "unique_email_id"  => "21b5f58334",
    "email_type"       => "html",
    "status"           => "subscribed",
    "merge_fields"     => [
        "FNAME"    => "KJ",
        "LNAME"    => "Hong",
        "ADDRESS"  => "",
        "PHONE"    => "0900000000",
        "BIRTHDAY" => "",
    ],
    "stats"            => [
        "avg_open_rate"  => 0,
        "avg_click_rate" => 0,
    ],
    "ip_signup"        => "",
    "timestamp_signup" => "",
    "ip_opt"           => "1.1.1.1",
    "timestamp_opt"    => "2018-08-24T08:30:44+00:00",
    "member_rating"    => 2,
    "last_changed"     => "2018-08-24T09:46:24+00:00",
    "language"         => "",
    "vip"              => false,
    "email_client"     => "",
    "location"         => [
        "latitude"     => 0,
        "longitude"    => 0,
        "gmtoff"       => 0,
        "dstoff"       => 0,
        "country_code" => "",
        "timezone"     => "",
    ],
    "tags_count"       => 0,
    "tags"             => [],
    "list_id"          => "9fe4ab289a",
];

刪除使用者 email

刪除使用者 email,是指整個 email 從此消失,再也找不回來了

$delete_status = Newsletter::delete($email);

刪除成功會回傳 true,刪除失敗則會將失敗的原因回傳

// 刪除失敗
$delete_status = [
    "type"     => "http://developer.mailchimp.com/documentation/mailchimp/guides/error-glossary/",
    "title"    => "Resource Not Found",
    "status"   => 404,
    "detail"   => "The requested resource could not be found.",
    "instance" => "bb6db1ab-97e6-4da7-9db3-f97b5588ce3e",
];

取得使用者近期活動資訊

$MemberActivity = Newsletter::getMemberActivity($email);
$MemberActivity = [
    "activity"    => [
        0 => [
            "action"      => "unsub",
            "timestamp"   => "2018-08-24T08:57:21+00:00",
            "type"        => "A",
            "campaign_id" => "",
        ],
    ],
    "email_id"    => "b08f6000ef0269370bc6d664a0bc42ae",
    "list_id"     => "9fe4ab289a",
    "total_items" => 1,
];

參考資料

KeJyun 最新新書推薦
Laravel 5 for beginner 新手道場:優雅運用框架快速開發 PHP 網站
Laravel框架开发详解:从零基础到运用框架快速开发PHP网站

Laravel 是 PHP 的框架(Framework),提供了很多開發網站或 API 所需的工具及環境,經過簡單的設定就可以完成資料的處理及顯示,使開發者可以很優雅且快速的開發出各個不同的產品。本書適合有 PHP 基礎的人,但不知道要怎麼選擇框架,或者不用框架的人也能夠明白它的好處。

雖然 WordPress 也能夠架站,但如果有客製化需求,要開發各式各樣的網站,或提供 App 使用的 API,如此一來你只能選擇用框架,而 Laravel 是目前最受歡迎的。

本書將解說為什麼要使用框架,以及理解框架的優缺點後,要怎麼選擇框架,並用框架快速建構一個網站。除非必要,否則書中會避免專業技術用語,盡量使用最生活化易懂的例子及語氣,讓大家更容易進入 Laravel 的世界。

購書連結

購書連結

results matching ""

    No results matching ""