我试图通过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。任何增加文件大小的脚本或解决方案???
答案 0 :(得分:0)
你将不得不分解文件。我发现我不能一次导入超过10个左右的产品而不会遇到卷曲超时错误(错误代码28)。
答案 1 :(得分:0)
您还可以在上传到小块之前编写一个破坏文件的脚本。有关更多详细信息,请访问以下链接。
Splitting a file before upload
请记住,您的脚本不会从原始格式更改文件格式,例如文件是json格式,因此块必须是json格式。
您还可以动态地将产品发送到您的Volusion API。
另一个原因可能是价格计划,因为我也遇到过那种类型的问题,当时我的意识(商店)计划是MINI。有关价格计划以及该计划的权利,您可以访问此链接。