想使用 cURL 而不是 SimpleXML_load_file()

K A*_*hir 5 php

使用下面的脚本我可以成功解析 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)

请让我知道我遗漏了什么或做错了什么。

谢谢,

K A*_*hir 4

好的,这是我的完整答案,希望对其他人有用。

我使用了两种方法从特定链接读取 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."&nbsp;".$m_id."&nbsp;".$ext_id."&nbsp;".$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."&nbsp;".$m_id."&nbsp;".$ext_id."&nbsp;".$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 正常

谢谢你,