我一直试图通过shopify客户API更新或删除我在用户注册时创建的元字段。
起初我尝试使用客户API更新元数据,但它告诉我元数据已经存在,我无法再添加它。
然后我使用了用户ID并调用了使用metafield API检索链接到用户的所有元字段 - 这个工作并且它返回了我的所有元字段。
但是,当我想要删除或更新我创建的元字段时,我的问题就开始了。
我尝试过很多不同的REST调用,但似乎没什么用。
尝试删除我使用的:
$baseUrl = "https://".$apikey.":".$password."@".$hostname."/admin/";
......
$curl = curl_init($baseUrl.'metafields/'.$metaID.'.json');
curl_setopt($curl, CURLOPT_CUSTOMREQUEST, "DELETE");
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
curl_setopt($curl, CURLOPT_HTTPHEADER, array('Content-Type: application/json'));
// Make the REST call, returning the result
$response = curl_exec($curl);
var_dump($response);
这没有做任何事情,所以我尝试更深层次并使用以下网址:
$curl = curl_init($baseUrl.'customers/'.$custID.'/metafields/'.$metaID.'.json');
此网址也不起作用。
然后我决定我也可以尝试将元数据更新为它应该具有的新值。
然后我尝试了以下尝试更新值:
$metafield = array('metafields' => array(array(
'id' => $metaID,
'value' => '3',
'value_type' => 'string',
)));
$curl_url = $baseUrl.'customers/'.$custID.'/metafields/'.$metaID.'.json';
$ch = curl_init($curl_url);
$data_string = json_encode(array('metafield'=>$metafield));
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "PUT");
curl_setopt($ch, CURLOPT_POSTFIELDS, $data_string);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, array(
'Content-Type: application/json',
'Content-Length: ' . strlen($data_string))
);
$server_output = curl_exec ($ch);
curl_close ($ch);
var_dump($server_output);
之后我尝试了替代网址:
$curl_url = $baseUrl.'metafields/'.$metaID.'.json';
知道我搞砸了吗?
答案 0 :(得分:2)
第2部分现在有效 - 创建和更新元数据 因此,在编写和测试不同的代码集后,我得到了一些工作。
$data = array('metafield' =>
array(
'key' => 'level',
'value' => '1',
'value_type' => 'string',
'namespace' => 'Wholesaler'
)
);
$curl_url = $baseUrl.'customers/'.$custID.'/metafields.json';
//$ch = curl_init($baseUrl.$sid.'.json'); //set the url
$session = curl_init($curl_url);
curl_setopt($session, CURLOPT_HEADER, false);
curl_setopt($session, CURLOPT_RETURNTRANSFER, true);
curl_setopt($session, CURLOPT_HTTPHEADER, array('X-HTTP-Method-Override: POST') );
curl_setopt($session, CURLOPT_POSTFIELDS, json_encode($data));
curl_setopt($session, CURLOPT_CUSTOMREQUEST, 'POST');
curl_setopt($session, CURLOPT_HTTPHEADER, array('Content-Type: application/json'));
if(ereg("^(https)",$curl_url)) curl_setopt($session,CURLOPT_SSL_VERIFYPEER,false);
$response = curl_exec($session);
curl_close($session);
$json = json_decode( $response, true );
var_dump($json);
echo "<br>-------------------------------------------------<br>";
echo $curl_url;
此代码允许我为没有它的用户创建一个元数据域以及更新该元数据,只要关键字段和命名空间使其唯一,它将创建一个新字段,如果您使用密钥和已存在的命名空间将更新值。
我希望这可以帮助其他人。
答案 1 :(得分:1)
我做这个电话,每次都很完美:
DELETE /admin/customers/123456789/metafields/987654321.json
我的客户ID为123456789且我要杀死的metafield的ID为987654321
答案 2 :(得分:0)
第一部分完成 - 删除
经过大量的研究和尝试不同的剧本之后,以下内容对我有用:
$curl_url = $baseUrl.'customers/'.$custID.'/metafields/'.$metaID.'.json';
//$curl_url = $baseUrl.'metafields/'.$metaID.'.json';
$session = curl_init($curl_url);
curl_setopt($session, CURLOPT_HEADER, false);
curl_setopt($session, CURLOPT_RETURNTRANSFER, true);
curl_setopt($session, CURLOPT_CUSTOMREQUEST, 'DELETE');
curl_setopt($session, CURLOPT_HTTPHEADER, array('Content-Type: application/json'));
if(ereg("^(https)",$curl_url)) curl_setopt($session,CURLOPT_SSL_VERIFYPEER,false);
$response = curl_exec($session);
curl_close($session);
$json = json_decode( $response, true );
var_dump($json);
我现在可以删除一个元素。