Mailchimp API 3.0批量订阅

时间:2016-12-05 11:36:47

标签: curl mailchimp mailchimp-api-v3.0

在文档中,对/ lists / {list_id}的POST应该批量订阅或取消订阅列表成员。

如果我派两名成员;一个新成员和一个未订阅成员:

    {
        "update_existing":true,
        "members":[
            {
                "email_address":"yyyy@yyy.yy",
                "email_type":"html",
                "status":"subscribed"
            },
            {
                "email_address":"xxx@xxx.xx",
                "email_type":"html",
                "status":"subscribed"
            }
        ]
    }

文档(http://developer.mailchimp.com/documentation/mailchimp/reference/lists/#create-post_lists_list_id)声明生成的JSON将包含一个包含new_members,updated_members的数组和一个包含错误成员的数组:

  

响应体参数

     

错误:一组对象,每个对象代表无法添加到列表或更新的电子邮件地址,以及提供更多详细信息的错误消息。

但我得到了一个HTTP状态400,出现以下错误:

{
    "type":"http://developer.mailchimp.com/documentation/mailchimp/guides/error-  glossary/",
    "title":"Member Exists",
    "status":400,
    "detail":"xxx@xxx.xx is in a compliance state due to unsubscribe, bounce, or compliance review and cannot be subscribed.",
    "instance":""
}

1 个答案:

答案 0 :(得分:0)

对于 Batch subscribe ,请尝试以下代码。这是经过测试且100%正常运行的代码。

<?php
$apikey  = ''; // Your Mailchimp ApiKey
$list_id = ''; // your List ID Where you want to add subscriber

$servername = 'localhost';
$username   = 'root';
$password   = '';
$dbname     = 'dada_mail_to_mailchimp';
// Create connection
$conn = new mysqli($servername, $username, $password, $dbname);
// Check connection
if ($conn->connect_error) {
    die('Connection failed: ' . $conn->connect_error);
}

$sql       = 'SELECT * FROM emails Limit 2';
$result    = $conn->query($sql);
$finalData = [];
if ($result->num_rows > 0) {
    // output data of each row
    while ($row = $result->fetch_assoc()) {
        $individulData = array(
            'apikey'        => $apikey,
            'email_address' => $row['email'],
            'status'        => $row['status'],//subscribe,pending,unsubscribe
            'merge_fields'  => array(
                'FNAME' => $row['FNAME'],
                'LNAME' => $row['LNAME'],
            )
        );

        $json_individulData        = json_encode($individulData);
        $finalData['operations'][] =
            array(
                "method" => "POST",
                "path"   => "/lists/$list_id/members/",
                "body"   => $json_individulData
            );
    }
}

$api_response = batchSubscribe($finalData, $apikey);
print_r($api_response);
$conn->close();

/**
 * Mailchimp API- List Batch Subscribe added function
 *
 * @param array  $data   Passed you data as an array format.
 * @param string $apikey your mailchimp api key.
 *
 * @return mixed
 */
function batchSubscribe(array $data, $apikey)
{
    $auth          = base64_encode('user:' . $apikey);
    $json_postData = json_encode($data);
    $ch            = curl_init();
    $dataCenter    = substr($apikey, strpos($apikey, '-') + 1);
    $curlopt_url   = 'https://' . $dataCenter . '.api.mailchimp.com/3.0/batches/';
    curl_setopt($ch, CURLOPT_URL, $curlopt_url);

    curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: application/json',
        'Authorization: Basic ' . $auth));
    curl_setopt($ch, CURLOPT_USERAGENT, 'PHP-MCAPI/3.0');
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
    curl_setopt($ch, CURLOPT_TIMEOUT, 10);
    curl_setopt($ch, CURLOPT_POST, true);
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
    curl_setopt($ch, CURLOPT_POSTFIELDS, $json_postData);

    $result = curl_exec($ch);
    return $result;
}