php与XML、XSLT、Mysql的结合运用实现代码


Posted in PHP onNovember 19, 2009

使用php中的xml与xslt要用到一些dll库,
extension=php_domxml.dll //操作XML的函数库
extension=php_iconv.dll //转码用的,比如将GB2312的转成UTF-8的
extension=php_xslt.dll //XSLT的函数库
使用上面这三个库的时候,你要将php安装目录下的dlls目录加入到路径中,否则会找不到
这些类库的
在下面的课程中,我们会用到php中的PEAR类库,主要用了DB类库,Sql2XML类库,大家可以在
pear.php.net上下载最新的版本
下载完上面二个类库以后,大家最好在php.ini中设置一下
include_path = ".;d:phppear"
d:phppear 是我的pear的安装路径
设置完以后,重新启动一下机器,否则因为路径找不到而导致Apache启动不正常,无法正常使用

至此要使用PHP中的XML和XSLT的设置就完成了,是不是很简单:)
使用Linux的用户可以到
http://www.gingerall.com/下载关于XSLt的源码
http://www.gnu.org/software/libiconv/下载关于Iconv的源码
二 php与XML、XSLT、Mysql的结合运用,初级篇
下面我要讲的是一个简单的从数据库中抽取数据,生成XML文档,使用XSLT转换成HTML的过程,
该过程只讲使用这一技术的过程,不会涉及分页等其它的技术
该示例我使用下面的数据库表及数据
表名:企业用户信息表,英文名:yhxx
表结构:
#
# 数据表的结构 `yhxx`
#
CREATE TABLE yhxx (
nsrnm varchar(15) NOT NULL default '',
qymc varchar(200) NOT NULL default '',
qydh varchar(50) NOT NULL default '',
PRIMARY KEY (nsrnm)
) TYPE=MyISAM COMMENT='用户信息表';
#
# 数据表内容 `yhxx`
#
INSERT INTO yhxx VALUES ('310109040111985', '乔家饮食发展有限公司', '8621-63346626');
INSERT INTO yhxx VALUES ('310104040221736', '上海嘉陵贸易有限公司', '74292546');
INSERT INTO yhxx VALUES ('310108040331576', '翡翠艺术公司', '54861465');

接下来我开始写抽取数据的程序与显示数据的页面
为了使大家都能明白,我使用最简单的方法来写程序
程序文件名称:browesData.php
页面文件名称:browesData.html
程序及页面文件提供下载,本程序已经在win2000、mysql下通过测试
代码见下一页

如果大家对此技术感兴趣,我再为大家讲一下php与xml、xslt、数据库结合更深一步的应用

<?php 
require_once "DB.php"; //PEAR中的数据库处理类 
$dataType = "mysql" ; //数据库类型 
$user = "root"; //用户名 
$pass = "abcd" ; //密码 
$host="202.96.215.200"; //Mysql数据库服务器地址 
$db_name = "test"; //数据库名 
$dsn="$dataType://$user:$pass@$host/$db_name"; //连接数据库的DNS配制 
$db = DB::connect($dsn); //连接数据库 
if (DB::isError($db)) 
{ 
die ($db->getMessage()); //连接失败,输出出错信息 
} 
//下面二个是公共的函数 
/** 
* 读取xsl文档 
* 
* @param String $filename - xsl文件的名称 
* @return string 
*/ 
function readXsl($filename) 
{ 
if(false==file_exists($filename)) 
{ 
echo "要读取的文件<font color='red'>$filename</font>不存在</br />"; 
return false ; 
} 
return implode('', file($filename)); 
} //end function readXsl 
/** 
* 将xml文件或数组变量根据xsl文件转换成HTML内容 
* http://knowsky.com 
* @param array $arydata - 数组变量 
* @param String $xslstring - xsl文档数据 
* @param String $xmlstring - xml文档数据 
*/ 
function getHtml($arydata = false, $xslstring = false, $xmlstring = false) 
{ 
global $db ; //使用刚才的$db对象 
include_once("XML/sql2xml.php"); //把sql2xml包含进来 
$sql2xmlclass = new xml_sql2xml($db); //将sql2xml实例化 
$sql2xmlclass->setEncoding("GB2312"); //设置数据的转码类型 
if (false == $xmlstring) { // 如果用户传入数组数据,则应用该数组数据到xsl 
//设置生成XML文档数据的节点名称 
$options = array ( tagNameRow => "row" , 
tagNameResult => "result" 
); 
$sql2xmlclass->SetOptions($options); 
//添加要生成XML文档的数据 
$sql2xmlclass->add($arydata); 
} 
//得到xml文档 
$xmlstring = $sql2xmlclass->getxml(); 
//print $xmlstring; 
//下面开始将XML数据文档用XSLT转换成HTML文档 
$arguments = array('/_xml' => $xmlstring, 
'/_xsl' => $xslstring 
); 
$xh = xslt_create(); 
$result = xslt_process($xh, 'arg:/_xml', 'arg:/_xsl', null, $arguments); 
if ($result) { 
return $result; 
xslt_free($xh); 
} else { 
return "转换xml数据到xsl时出错"; 
xslt_free($xh); 
} 
} //end function getHtml() 
//从用户信息表中查询数据的SQL语句 
$sql = "select 
nsrnm, #代码 
qymc, #企业名称 
qydh #电话 
from 
yhxx #用户信息表"; 
// 执行SQL语句 
$res = $db->query($sql); 
if ($db->isError($res)) 
{ 
echo "执行SQL语句时出错"; 
} 
while ($row = $res->fetchRow(DB_FETCHMODE_ASSOC)) 
{ 
$data[] = $row; //将数据放到一个数组中 
} 
//print_r($data); 
//大家可以看到数据已经放到了一个多维的数组中了 
//至此,我们的程序已经基本上完成了,再接下去,我们要定义显示数据的页面 
//打开你的DW 或 FrontPage XP,制作显示的页面,我做了一个,并提供给大家下载 
//我们制作的数据显示页面文件为:browesData.html 
/* 
这是我们平时要显示的数据列表界面 
<html> 
<head> 
<meta http-equiv="Content-Language" content="zh-cn"> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title>数据浏览</title> 
</head> 
<body> 
<table border="1" cellpadding="0" cellspacing="0" style="border-collapse: collapse" bordercolor="#111111" width="100%" id="AutoNumber1"> 
<tr> 
<td width="21%" align="center" bgcolor="#C0C0C0">代码</td> 
<td width="50%" align="center" bgcolor="#C0C0C0">企业名称</td> 
<td width="29%" align="center" bgcolor="#C0C0C0">电话</td> 
</tr> 
<tr> 
<td width="21%"> </td> 
<td width="50%"> </td> 
<td width="29%"> </td> 
</tr> 
</table> 
</body> 
</html>

*/ 
//我把它加工成一个XSLT格式的HTML文档 
/* 
<?xml version="1.0" encoding="gb2312"?> 
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> 
<xsl:output method="html" version="1.0" encoding="GB2312" indent="yes" /> 
<xsl:template match="/"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title>数据浏览</title> 
</head> 
<body> 
<table border="1" cellpadding="0" cellspacing="0" style="border-collapse: collapse" bordercolor="#111111" width="100%" id="AutoNumber1"> 
<tbody> 
<tr> 
<td width="21%" align="center" bgcolor="#C0C0C0">代码</td> 
<td width="50%" align="center" bgcolor="#C0C0C0">企业名称</td> 
<td width="29%" align="center" bgcolor="#C0C0C0">电话</td> 
</tr> 
<xsl:for-each select="root/result/row"> 
<tr> 
<td width="21%"> <xsl:value-of select="nsrnm" /></td> 
<td width="50%"> <xsl:value-of select="qymc" /></td> 
<td width="29%"> <xsl:value-of select="qydh" /></td> 
</tr> </xsl:for-each> 
</tbody> 
</table> 
</body> 
</html> 
</xsl:template> 
</xsl:stylesheet> 
*/ 
$htmlFile="browesData.html" ; 
$htmlStr = readXsl($htmlFile); //将xslt格式的HTML文档读取到变量中 
echo getHtml($data, $htmlStr) ; 
//程序结束 
?>
PHP 相关文章推荐
杏林同学录(五)
Oct 09 PHP
PHP的中问验证码
Nov 25 PHP
基于PHP magic_quotes_gpc的使用方法详解
Jun 24 PHP
PHP图片等比缩放类SimpleImage使用方法和使用实例分享
Apr 10 PHP
Yii的CDbCriteria查询条件用法实例
Dec 04 PHP
Ubuntu中搭建Nginx、PHP环境最简单的方法
Mar 05 PHP
标准PHP的AES加密算法类
Mar 12 PHP
PHP实践教程之过滤、验证、转义与密码详解
Jul 24 PHP
swoole和websocket简单聊天室开发
Nov 18 PHP
php实现等比例压缩图片
Jul 26 PHP
Yii框架布局文件的动态切换操作示例
Nov 11 PHP
如何用PHP实现多线程编程
May 26 PHP
php 静态变量的初始化
Nov 15 #PHP
PHP 程序员的调试技术小结
Nov 15 #PHP
PHP 配置open_basedir 让各虚拟站点独立运行
Nov 12 #PHP
php $_SERVER当前完整url的写法
Nov 12 #PHP
php利用header函数实现文件下载时直接提示保存
Nov 12 #PHP
计算一段日期内的周末天数的php代码(星期六,星期日总和)
Nov 12 #PHP
php 分库分表hash算法
Nov 12 #PHP
You might like
php中获取主机名、协议及IP地址的方法
2014/11/18 PHP
原生JS实现Ajax通过GET方式与PHP进行交互操作示例
2018/05/12 PHP
解决PHP使用CURL发送GET请求时传递参数的问题
2019/10/11 PHP
解决thinkPHP 5 nginx 部署时,只跳转首页的问题
2019/10/16 PHP
常用参考资料(手册)下载或者链接
2006/07/22 Javascript
javascript String 对象
2008/04/25 Javascript
基于jquery打造的百分比动态色彩条插件
2012/09/19 Javascript
js中定义一个变量并判断其是否为空的方法
2014/05/13 Javascript
JavaScript实现三阶幻方算法谜题解答
2014/12/29 Javascript
JavaScript代码性能优化总结篇
2016/05/15 Javascript
解决同一页面中两个iframe互相调用jquery,js函数的方法
2016/12/12 Javascript
js实现简单的手风琴效果
2017/02/27 Javascript
vue分类筛选filter方法简单实例
2017/03/30 Javascript
详解vue-cli中配置sass
2017/06/21 Javascript
Node.Js中实现端口重用原理详解
2018/05/03 Javascript
vue中$set的使用(结合在实际应用中遇到的坑)
2018/07/10 Javascript
Vue props 单向数据流的实现
2018/11/06 Javascript
JavaScript函数的特性与应用实践深入详解
2018/12/30 Javascript
跟老齐学Python之用Python计算
2014/09/12 Python
Python设计模式之抽象工厂模式
2016/08/25 Python
Python WXPY实现微信监控报警功能的代码
2017/10/20 Python
Python判断文件和字符串编码类型的实例
2017/12/21 Python
PyQt5每天必学之布局管理
2018/04/19 Python
解决在pycharm中显示额外的 figure 窗口问题
2019/01/15 Python
python的一些加密方法及python 加密模块
2019/07/11 Python
django的分页器Paginator 从django中导入类
2019/07/25 Python
python 实现控制鼠标键盘
2020/11/27 Python
用python计算文件的MD5值
2020/12/23 Python
html5默认气泡修改的代码详解
2020/03/13 HTML / CSS
"火柴棍式"程序员面试题
2014/03/16 面试题
精细化工应届生求职信
2013/11/17 职场文书
个人求职信范文分享
2013/12/13 职场文书
艺人经纪人岗位职责
2014/04/15 职场文书
2014年计划生育协会工作总结
2014/11/14 职场文书
Nginx反向代理及负载均衡如何实现(基于linux)
2021/03/31 Servers
MySQL系列之六 用户与授权
2021/07/02 MySQL