我正在努力在 PHP 中使用 cURL 向 URL 发送 XML 请求。
首先,我只是想确保我的请求发送了正确的数据,所以这里是我的代码片段。一旦我知道我正在发送正确的数据,我将在稍后添加 curl 语句。
到目前为止,这是我的代码:
$format = 'Y-m-j G:i:s';
$date = date ( $format );
$d = date ( $format, strtotime ( '-90 days' ) );
$sql = mysql_query("SELECT * FROM recurringPayments WHERE lastpmt <= '$d'");
$num_rows = mysql_num_rows($sql);
echo $num_rows . " results found";
echo "<table style=\"border:1px solid green;\">
<tr bgcolor=\"#bdd73b\">
<th>ID</th>
<th>Company Name</th>
<th>Annual Subscription</th>
<th>Package</th>
<th>Cost</th>
<th>Payer Ref</th>
<th>Payment Ref</th>
<th>Last Payment Date</th>
</tr>";
while ($row = mysql_fetch_array($sql))
{
echo "<tr>";
echo "<td>" . $row['ID'] . "</td>";
echo "<td>" . $row['compName'] . "</td>";
echo "<td>" . $row['annualSub'] . "</td>";
echo "<td>" . $row['package'] . "</td>";
echo "<td>" . $row['cost'] . "</td>";
echo "<td>" . $row['payerref'] . "</td>";
echo "<td>" . $row['pmtref'] . "</td>";
echo "<td>" . $row['lastpmt'] . "</td>";
}
echo "</table>";
while ($row = mysql_fetch_array($sql))
{
$xml_data ='<request type="receipt-in" timestamp="20030520151742">'.
'<merchantid>test</merchantid>'.
'<account>internet</account>'.
'<orderid>transaction01</orderid>'.
'<amount currency="EUR">'.$row['cost'].'</amount>'.
'<payerref>'.$row['payerref'].'</payerref>'.
'<paymentmethod>'.$row['pmtref'].'</paymentmethod>'.
'<autosettle flag="1" />'.
'<md5hash />'.
'<sha1hash>c81377ac77b6c0a8ca4152e00cc173d01c3d98eb</sha1hash'.
'</request>';
}
echo $xml_data;
当我尝试回显 $xml_data 时,我收到以下错误消息:
Notice: Undefined variable: xml_data in C:\wamp\www\Internal\paymentDue.php on line 63
我的逻辑是我可以在输出表格时输出 XML,但是我可能(可能)错了。任何指导表示赞赏。
谢谢。
附言:
我在发帖时也刚刚意识到,如果我在当前上下文中使用 while 循环,每次循环时 $xml_data 都会被覆盖。对此的任何帮助也会很棒。
最佳答案
您正在从头到尾循环遍历您的结果集以构建 html 表,然后尝试再次循环遍历它以获取您的 xml,即使您已经过了结果集的末尾。在同一个循环中构建两者。
在循环之前将 xml_data 设置为 '',然后使用 xml_data .= 构建它(甚至使用 SimpleXML 或 XMLWriter 而不是将其构建为字符串)
关于php - PHP 中的 undefined variable ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3907475/