使用Volusion API进行产品导入/插入

时间:2016-08-26 19:56:36

标签: php volusion

我试图通过Volusion API将我的产品导入/插入我的产品表我已经使用了Volusion提供的示例PHP代码。

    $file = file_get_contents('C:\Users\Ray\Desktop\3.txt', true);

//  Create the Xml to POST to the Webservice

    $Xml_to_Send = "<?xml version=\"1.0\" encoding=\"utf-8\" ?>";
    $Xml_to_Send .= "<Volusion_API>";
//  $Xml_to_Send .= "<!--";
    $Xml_to_Send .= $file;
//  $Xml_to_Send .= "\"\"";
//  $Xml_to_Send .= "-->";
    $Xml_to_Send .= "</Volusion_API>";

    $url = "http://.servertrust.com/net/WebService.aspx?Login=support@mysite.com&EncryptedPassword=1234&Import=Insert";

    $header  = array(
    "MIME-Version: 1.0",
    "Content-type: text/xml; charset=utf-8",
    "Content-transfer-encoding: text",
    "Request-number: 1",
    "Document-type: Request",
    "Interface-Version: Test 1.4"
);

    //  Post and Return Xml
    $ch = curl_init();
    curl_setopt($ch, CURLOPT_URL,$url);
    curl_setopt($ch, CURLOPT_POST, true);
    curl_setopt($ch, CURLOPT_POSTFIELDS, $Xml_to_Send); 
    curl_setopt($ch, CURLOPT_HTTPHEADER, $header);
    $data = curl_exec($ch);

    //  Check for Errors
    if (curl_errno($ch)) {
        print curl_error($ch);
    } else {
       curl_close($ch);
    }

   //  Display the Xml Returned on the Browser
    echo $data;

只要我的xml文件低于10MB,这个代码就可以正常工作,这是常规导入的限制。当我尝试导入任何内容时,我收到此错误:

<ReturnResult>
<Success>False</Success>
<Message>Maximum request length exceeded.</message>
</ReturnResults>Send Failure: Connection was reset

有没有办法绕过这个限制?就像我说的那样,代码工作得很好,直到我收到此错误时达到10MB的限制。我尝试导入的当前文件只有30MB。任何增加文件大小的脚本或解决方案???

2 个答案:

答案 0 :(得分:0)

你将不得不分解文件。我发现我不能一次导入超过10个左右的产品而不会遇到卷曲超时错误(错误代码28)。

答案 1 :(得分:0)

您还可以在上传到小块之前编写一个破坏文件的脚本。有关更多详细信息,请访问以下链接。

Splitting a file before upload

请记住,您的脚本不会从原始格式更改文件格式,例如文件是json格式,因此块必须是json格式。

您还可以动态地将产品发送到您的Volusion API。

另一个原因可能是价格计划,因为我也遇到过那种类型的问题,当时我的意识(商店)计划是MINI。有关价格计划以及该计划的权利,您可以访问此链接。

Volusion price plan and their rights