< < 小于
>> 大于
& & 和号
' ' 单引号
" " 双引号
<?xml version="1.0″ encoding="utf-8″?>
<?php
header("Content-Type:application/xml;charset=utf-8");
header("Cache-Control: no-cache,must-revalidate");
header("Expries: Fri, 14 Mar 1980 20:00:00 GMT");
header("Last-Modified: ".date('r'));
header("Prama: no-cache");
$xml='<?xml version="1.0" encoding="utf-8"?>
<rss></rss>';
$sxe=new SimpleXMLElement($xml);
if(method_exists($sxe,'addChild')){
$sxe->addAttribute('version','2.0');
宝马娱乐在线, $channel=$sxe->addChild('channel');
$channel->addChild("title","服饰批发");
for($i=0;$i<5;$i++){
$item=$channel->addChild('item');
$item->addChild('title','商品'.$i);
$item->addChild('link',$i);
}
echo $sxe->asXML();
}else{
$dom=new DOMDocument("1.0");//生成一个新的DOM对象
$rss=$dom->createElement("rss");//生成rss元素
$rss->setAttribute("version","2.0");
$rss=$dom->appendChild($rss);
$channel=$dom->createElement("channel");
$channel=$rss->appendChild($channel);
$title=$dom->createElement('title');
$text=$dom->createTextNode("服饰批发");
$title->appendChild($text);
$title=$channel->appendChild($title);
for($i=0;$i<5;$i++){
$item=$dom->createElement("item");
$item=$channel->appendChild($item);
$title=$dom->createElement("title");
$text=$dom->createTextNode("商品".$i);
$title->appendChild($text);
$title=$item->appendChild($title);
$link=$dom->createElement("link");
$text=$dom->createTextNode("$i");
$link->appendChild($text);
$link=$item->appendChild($link);
}
echo $dom->saveXML();
//$dom->save("nnn.xml");
}
?>
下面我们以学生信息表student,需要提供给第三方调用,并有id,name,sex,age分别记录学生的姓名、性别、年龄等信息。
XML文件生成操作简单示例
<?PHP
$data_array = array(
array(
'title' => 'title1',
'content' => 'content1',
'pubdate' => '2009-10-11',
),
array(
'title' => 'title2',
'content' => 'content2',
'pubdate' => '2009-11-11',
)
);
$title_size = 1;
$xml = "<?xml version="1.0" encoding="utf-8"?>n";
$xml .= "<article>n";
foreach ($data_array as $data) {
$xml .= create_item($data['title'], $title_size,
$data['content'], $data['pubdate']);
}
$xml .= "</article>n";
echo $xml;
// 创建XML单项
function create_item($title_data, $title_size, $content_data,
$pubdate_data) {
$item = "<item>n";
$item .= "<title size="" . $title_size . "">" . $title_data
. "</title>n";
$item .= "<content>" . $content_data . "</content>n";
$item .= " <pubdate>" . $pubdate_data .
"</pubdate>n";
$item .= "</item>n";
return $item;
}
?>
xml声明,表示文档遵循的是xml的1.0版的规范
2、xml特点:
可扩展性,xml允许使用者创建和使用他们自己的标记而不是HTML的有限标签,企业可以用XML为电子商务和供应链集成等应用定义自己的标记语言,甚至特定行业一起来定义该领域的特殊标记语言,作为该领域信息共享与数据交换的基础。不过,这些自定义标记仅仅是用来识别信息数据的,它本身并不传达信息。
灵活性,xml更像一个小型的数据库,提供了一种结构化的数据表示方式,使得用户界面分离于结构化数据。
自描述性,xml表示数据的方式真正做到了独立于应用系统,并且数据能够重用,xml文档被看作文档的数据库化和数据的文档化。
3、xml与html区别
html是一个定型的标记语言,它用固有的标记来描述,显示网页内容。xml没有固定的标记,不能描述网页具体的外观、内容,它只是描述内容的数据形式和结构。网页将数据和显示混在一起,而xml则将数据和显示分开。
xml文档注意事项
所有标记都必须有一个相应的结束标记、标记都必须合理嵌套、标记区分大小写、标记的属性必须用“”括起来。
标记命名规则:名字中可以包含字母、数字、下划线以及其他字母,不能以数字或下划线开头、名字不能以xml(或XML或Xml…)开头、名字中不能包含空格、名字中也不能使用“.”,“.”被用来连接元素和属性。
ps:支持汉字作为标记名,要注意编码。文件编码与xml声明的编码要一致
在 XML 中,有 5 个预定义的实体引用:
$b = $doc->createElement("data");
1、XML,Extensible Markup Language(可扩展标记语言),是一种可以创建自定义标记符号(Tags)的标记语言,是用于表示结构化信息的一种标准文本格式,作为下一代数据交换格式的标准。和HTML一样,XML基于标准通用标记语言(Standard Generalized Markup Language,SGML)。文档结构,层次非常清晰。xml文档只是存储了数据,是很有规律的结构化文档,但没有定义如何显示这些数据。文档结构可称为“文档树”,主干是顶层的父元素,分支和叶是子元素。
PRIMARY KEY (`id`)
代码如下
<name>李王皓</name>
接着,建立xml,循环数组,将数据写入到xml对应的节点中。
}
$doc = new DOMDocument(’1.0′, ‘utf-8′); // 声明版本和编码
</data>
$i=1;
…
为了将数据name,sex和age分开,我们使用$i%3来判断取模,因为在获取的xml中,节点data下的信息是以3个子节点存在的。
`sex` varchar(10) NOT NULL,
$m = $i%3;
‘sex’ => $row['sex'],
}
`id` int(11) NOT NULL auto_increment,
header("Content-type:text/html; Charset=utf-8″);
);
<?xml version="1.0" encoding="utf-8"?>
<article>
<item>
<title size="1">title1</title>
<content>content1</content>
<pubdate>2009-10-11</pubdate>
</item>
<item>
<title size="1">title2</title>
<content>content2</content>
<pubdate>2009-11-11</pubdate>
</item>
</article>
</root>
那么我们用php如何生成xml格式数据呢
$arr[] = array(
CREATE TABLE `student` (
‘name’ => $row['name'],
$name = $reader->value; //读取node值
$age = $doc->createElement("age");
<root>
$sex->appendChild($doc->createTextNode($dat['sex']));
<?PHP
$data_array = array(
array(
'title' => 'title1',
'content' => 'content1',
'pubdate' => '2009-10-11',
),
array(
'title' => 'title2',
'content' => 'content2',
'pubdate' => '2009-11-11',
)
);
// 属性数组
$attribute_array = array(
'title' => array(
'size' => 1
)
);
// 创建一个XML文档并设置XML版本和编码。。
$dom=new DomDocument('1.0', 'utf-8');
// 创建根节点
$article = $dom->createElement('article');
$dom->appendchild($article);
foreach ($data_array as $data) {
$item = $dom->createElement('item');
$article->appendchild($item);
create_item($dom, $item, $data, $attribute_array);
}
echo $dom->saveXML();
function create_item($dom, $item, $data, $attribute) {
if (is_array($data)) {
foreach ($data as $key => $val) {
// 创建元素
$$key = $dom->createElement($key);
$item->appendchild($$key);
// 创建元素值
$text = $dom->createTextNode($val);
$$key->appendchild($text);
if (isset($attribute[$key])) { //
如果此字段存在相关属性需要设置
foreach ($attribute[$key] as $akey => $row) {
// 创建属性节点
$$akey = $dom->createAttribute($akey);
$$key->appendchild($$akey);
// 创建属性值节点
$aval = $dom->createTextNode($row);
$$akey->appendChild($aval);
}
} // end if
}
} // end if
} // end function
?>
}
$age = $reader->value;
include_once ("connect.php"); //连接数据库
方法1:使用纯粹的PHP代码生成字符串,并把这个字符串写入一个以XML为后缀的文件。这是最原始的生成XML的方法,不过有效!
PHP代码如下:
echo $doc->saveXML();
$sex = $reader->value;
现在我们假设要从第三方获取学生信息,数据格式是XML,我们需要使用PHP解析XML,然后将解析后的数据显示或者写入本地数据库。而这里关键的一步是解析XML。
$b->appendChild($sex);
获取XML格式数据
$b->appendChild($age);
$sql = "select * from student";
代码如下
while ($row = mysql_fetch_array($result)) {
代码如下
生成与读取xml文档的方法有很多,下面我就不介绍了,大家可参考下面的文档。
‘sex’ => $sex,
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
本文由宝马娱乐在线发布于网络频道,转载请注明出处:PHP生成XML格式数据与解析xml数据程序宝马娱乐在