我正在尝试创建一个XML Feed,主要是一堆作业列表。我现在在数据库中有39个工作列表,我正在使用SimpleXML创建XML并且它工作得很好,除了它只输出xml中数据库中的最后一条记录。我确信这是一个简单的解决方案。
查看代码,我希望每个作业都在<job>
元素内,并且我希望为每个作业创建一个新的<job>
元素。所有这些都包含在一个<source>
元素中。这是我的PHP代码,下面是我得到的结果 - 你会看到只返回一行而不是全部39行。
<?php
Header('Content-type: text/xml');
class SimpleXMLExtended extends SimpleXMLElement {
public function addCData($cdata_text) {
$node = dom_import_simplexml($this);
$no = $node->ownerDocument;
$node->appendChild($no->createCDATASection($cdata_text));
}
}
$jobs = $dbjobs->find(array('job_title' => array('$exists' => true), 'job_title' => array('$nin'=> array('',' ', null))));
$jobs = iterator_to_array($jobs);
$xml = new SimpleXMLExtended('<source/>');
$i = 0;
foreach ($jobs as $job) {
$i++;
$xml->job = NULL;
$j = $xml->job;
$j->referencenumber = NULL;
$j->referencenumber->addCData($job['id']);
$j->title = NULL;
$j->title->addCData($job['job_title']);
$j->url = NULL;
$j->url->addCData('http://www.site.com/joblisting.php?jl=' . $job['id']);
$j->description = NULL;
$j->description->addCData($job['job_description']);
$j->company = NULL;
$j->company->addCData($job['company']);
$j->city = NULL;
$j->city->addCData($job['city']);
$j->state = NULL;
$j->state->addCData($job['state']);
$j->postalcode = NULL;
$j->postalcode->addCData('');
$j->country = NULL;
$j->country->addCData('US');
$j->date = NULL;
$j->date->addCData(date("Y-m-d", $job['added']->sec));
$j->site = NULL;
$j->site->addCData('site.com');
$j->count = NULL;
$j->count->addCData($i);
}
print($xml->asXML());
?>
以下是我得到的示例回复:
<source>
<job>
<referencenumber>230257</referencenumber>
<title>Home Phone Representative</title>
<url>http://www.site.com/joblisting.php?jl=230257</url>
<description></description>
<company>Media LLC</company>
<city>San Jose</city>
<state>CA</state>
<postalcode></postalcode>
<country>US</country>
<date>2013-09-16</date>
<site>site.com</site>
<count>39</count>
</job>
</source>
正如你可以看到它填充得很好,但我需要所有列表而不是循环中的最后一个。感谢您的帮助。
答案 0 :(得分:0)
您应该将Childs添加到根目录:
foreach ($jobs as $job) {
$i++;
$j=$xml->addChild('job')
...
答案 1 :(得分:0)
$xml->job = NULL;
是你的黄牌,因为你取消了最后一张唱片。
并且所有$j->xxxxxx = NULL;
都没用。
然后编码为
foreach ($jobs as $job) {
$i++;
$j = $xml->addChild('job');
$j->referencenumber->addCData($job['id']);
$j->title->addCData($job['job_title']);
(...)
更好。
了解有关查看SimpleXMLElement::addChild doc。
的更多信息