我有一个已在MailChimp中创建的列表,它在订阅和未订阅列表中有一些地址。
现在,我需要在PHP代码中使用api创建/更新订阅者列表。
$apiKey = "XXXXXXXXXXXXXXXXXXXXXXXXX-us12";
$subscribers = array(array(
'email_address' => 'subscriber1@gmail.com',
'status' => 'subscribed',
'merge_fields' => array(
'FNAME' => "subscriber1F",
'LNAME' => "Arunachalam1L"
)
),
array(
'email_address' => 'subscriber2@gmail.com',
'status' => 'subscribed',
'merge_fields' => array(
'FNAME' => "subscriber2F",
'LNAME' => "subscriber2L"
)
));
$listId = "b633deb4c8";
$url = "https://us12.api.mailchimp.com/3.0/batches";
$id = 1;
foreach ($subscribers as $subscriber) {
#echo $subscriber['email_address'];
$operation = array(
'method'=>'PUT',
'path'=>'/lists/'.$listId.'/members/'.md5(strtolower($subscriber['email_address'])),
'body'=>json_encode($subscriber));
$id++;
array_push($batch_operations, $operation);
}
$request_encoded = json_encode(array('operations'=>$batch_operations));
$curl = curl_init($url);
curl_setopt($curl, CURLOPT_USERPWD, 'user:' . $apiKey);
curl_setopt($curl, CURLOPT_HTTPHEADER, ['Content-Type: application/json']);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);//raw output
curl_setopt($curl, CURLOPT_CUSTOMREQUEST, 'POST');
curl_setopt($curl, CURLOPT_POSTFIELDS, $request_encoded);
$result = curl_exec($curl);
我收到回复200.然后我甚至试图获得批处理操作提交后返回的BatchId的响应。
它返回完成的操作,并且所有操作都成功但列表尚未更新。有没有人成功使用他们的批次api?
EDIT1: 我收到了对具有新电子邮件地址的操作的回复。
{"status_code":404,"operation_id":null,"response":"{\"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\":\"\"}"}
修改2
解释 对不起,我不明白你的意思。但我正在做的是首先发送批处理请求,(例如: - 它有2个操作,如在帖子中)。然后我在响应中得到一个BatchId我所做的请求。然后我用BatchId发出了一个Get请求,为此我得到一个响应,其中包含错误操作的信息。我得到了一个链接,用于获取批处理操作的响应以及我发送的所有地址的结果。只有所有操作,但如果地址已经存在,那么该操作是成功的(在某种意义上它只是添加到成功的操作计数中)但我所做的更改没有反映出来,如果地址不存在则添加在失败的行动中。
答案 0 :(得分:2)
我解决了这个问题。它是因为url路径。虽然Mailchimp文档说如下(即使我正在尝试批量操作)docs,
我在操作中改变了路径,它应该是这样的。
MethodName
现在它按预期工作了。尝试过' PUT'在操作方法中,它同时创建/更新mailchimp中列表的订阅者。
答案 1 :(得分:-1)
请删除以下代码并将类型更改为POST,问题已解决。
array_push($batch_operations, $operation);