使用下面的脚本我可以成功解析 API 数据。
$xml_report_daily=simplexml_load_file("https://api.sitename.com/api/reports/api_get.asp?User=00012345&Key=abcdefghijklmnop&fromDate=11/12/2014&toDate=12/12/2014&mid=25");
foreach ($xml_report_daily as $report_daily):
$trans_id=$report_daily->TRANSID;
$trans_id=$report_daily->MID;
$trans_id=$report_daily->EXT;
$trans_id=$report_daily->USER;
endforeach;
Run Code Online (Sandbox Code Playgroud)
XML 数据是这样的:
<DATABASE>
<RECORD>
<TRANSID>1348818</TRANSID>
<MID/>
<EXT>0</EXT>
<USER>00012345</USER>
</RECORD>
.
.
.
so on...
</DATABASE>
Run Code Online (Sandbox Code Playgroud)
但我想使用 cURL 而不是 simplexml_load_file。所以我使用了下面的脚本,但它没有给出任何结果数据。
$url = "https://api.sitename.com/api/reports/api_get.asp?User=00012345&Key=abcdefghijklmnop&fromDate=11/12/2014&toDate=12/12/2014&mid=25";
$ch = curl_init();
curl_setopt ($ch, CURLOPT_URL, $url);
curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_HEADER, false);
$xml = curl_exec($ch);
echo $xml;
Run Code Online (Sandbox Code Playgroud)
请让我知道我遗漏了什么或做错了什么。
谢谢,
好的,这是我的完整答案,希望对其他人有用。
我使用了两种方法从特定链接读取 XML 数据。
方法# 1:使用 simplexml_load_file() - 托管服务器上的allow_url_fopen 应为ON,此方法才能正常工作。这个方法在我的本地和实际服务器上都运行良好。
$xml_report_daily=simplexml_load_file("https://api.sitename.com/api/reports/api_get.asp?User=00012345&Key=abcdefghijklmnop&fromDate=11/12/2014&toDate=12/12/2014&mid=25");
foreach ($xml_report_daily as $report_daily):
$trans_id=$report_daily->TRANSID;
$m_id=$report_daily->MID;
$ext_id=$report_daily->EXT;
$user_id=$report_daily->USER;
echo $trans_id." ".$m_id." ".$ext_id." ".$user_id."<br/>";
endforeach;
Run Code Online (Sandbox Code Playgroud)
方法# 2:使用 cURL - 按照此处的建议进行操作后,现在此方法在我的本地服务器和实际服务器上也运行良好。
$url = "https://api.sitename.com/api/reports/api_get.asp?User=00012345&Key=abcdefghijklmnop&fromDate=11/12/2014&toDate=12/12/2014&mid=25";
$ch = curl_init();
curl_setopt ($ch, CURLOPT_URL, $url);
curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_HEADER, false);
$xml = curl_exec($ch);
$xml_report_daily = simplexml_load_string($xml);
foreach ($xml_report_daily as $report_daily):
$trans_id=$report_daily->TRANSID;
$m_id=$report_daily->MID;
$ext_id=$report_daily->EXT;
$user_id=$report_daily->USER;
echo $trans_id." ".$m_id." ".$ext_id." ".$user_id."<br/>";
endforeach;
Run Code Online (Sandbox Code Playgroud)
使用 cURL 时,我没有得到任何结果数据,因此paul-crovella建议我检查错误。所以我使用了下面的脚本,我发现我正在尝试访问 https(SSL 证书)数据,正如Raffy Cortez也提到的那样
if(curl_exec($ch) === false)
{ echo 'Curl error: ' . curl_error($ch); }
else
{ echo 'Operation completed without any errors'; }
Run Code Online (Sandbox Code Playgroud)
要解决此 https(SSL 证书)相关问题,这里有一个非常有用的链接,您可以根据需要使用其中提到的任何方法。
HTTPS 和 SSL3_GET_SERVER_CERTIFICATE:证书验证失败,CA 正常
谢谢你,