Shopify - 使用PHP通过metafield API更新/删除元字段

时间:2015-05-22 13:39:16

标签: php curl shopify

我一直试图通过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';

知道我搞砸了吗?

3 个答案:

答案 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);

我现在可以删除一个元素。