当前位置: 移动技术网 > IT编程>开发语言>PHP > Zend Framework+smarty用法实例详解

Zend Framework+smarty用法实例详解

2017年12月12日  | 移动技术网IT编程  | 我要评论

本文实例讲述了zend framework+smarty用法。分享给大家供大家参考,具体如下:

一、zend framework简介

zend framework使用模型-视图-控制器(model-view-controller(mvc))结构。这个用来把你的程序分离成不同部分使得开发和维护变得容易。

运行zend framework需要:php 5.1.4 (或更高) 、web 服务器支持 mod_rewrite功能,本实例采用apache。 从这里http://framework.zend.com/download下载 zend framework,有两种格式.zip或者.tar.gz。

二、zend framework的配置

1、目录结构

虽然zend framework 没有强求使用一个标准的目录结构,但是还是有一些通用的目录结构。这个目录结构假设你完全控制apache 的配置。(下面以本机做例子,各位需根据自己的情况进行更改,我的服务器的根目录指向的是web文件夹)

引用:

web/
test/
/webapp
/controllers
/models
/templates
/templates_c
/library
/webroot
/images
/js
/css

我们已经把程序中的模型、视图和控制器的文件分离到不同的子目录中。支持的图像,脚本和css 文件被存放在webroot 目录下的不同子目录中。下载的zend framework 文件放在 library 目录下。如果我们还需要其他库文件,都可以放在这里。在这个实例中,我们使用到了smarty模版技术,所以smarty 的库文件我们也应该放在library文件下!

2、启动文件

1) 配置.htaccess

我们使用单一的入口文件index.php来对我们的程序进行访问,这给我们提供了程序中所有页面的中心点并确保运行环境配置正确。我们用.htaccess 文件来实现这个目的,添加.htaccess 文件在test 的根目录中,内容如下:

rewriteengine on
rewriterule !".(js|ico|gif|jpg|png|css)$ index.php

2)配置apache
与此同时,我们还需要对apache进行一些设置,打开apache的配置文件 httpd.conf。

1、找到“#loadmodule rewrite_module modules/mod_rewrite.so 这句话,把前面的#去掉!

2、然后再找到“allowoverride none 改成allowoverride all,重新启动apache即可。

3、启动文件index.php
index.php放在test的根目录下,下面是index.php的内容::

<?php 
//打开错误提示
error_reporting(e_all|e_strict); 
//设定时区
date_default_timezone_set('asia/shanghai'); 
//指明引用文件的路径
set_include_path('.' .
path_separator . './library/'.
path_separator . './webapp/models/'.
path_separator . get_include_path());
//必须手动加载loader.php
include "zend/loader.php"; 
//自动加载类,使用时,直接实例化使用
function __autoload($class){
zend_loader::loadclass($class);
}
//getinstance()方法用来获取前端控制器实例
$frontcontroller = zend_controller_front::getinstance(); 
//设定前端路由器的工作目录
$frontcontroller->setcontrollerdirectory(array("default"=>'./webapp/controllers')); 
//抛出异常
$frontcontroller->throwexceptions(true); 
//设置基地址,方便以后url的跳转用户,.注意,区分大小写!
$frontcontroller->setbaseurl('/test'); 
//使用smarty模版需关闭本身的视图助手. 
$frontcontroller->setparam('noviewrenderer', true); 
// 关闭错误提示,发生请求错误时候,转到errorcontroller的erroraction控制器
//$frontcontroller->throwexceptions(false);
//对。。进行注册
zend_registry::set('font', $frontcontroller);
//------------配置smarty模版 ----------------
include 'smarty/smarty.class.php'; 
/**
* 对smarty模版进行初始化
**/
$views = new smarty();
//$views->left_delimiter = "{{";
//$views->right_delimiter = "}}";
$views->compile_dir = './webapp/templates_c';
$views->cache_dir = './webapp/templates_c/cache_c';
$views->template_dir = "./webapp/templates";
function smarty_block_dynamic($param,$content,&$views)
{
return $content;
} 
$views->register_block('dynamic','smarty_block_dynamic',false);
zend_registry::set('views', $views);
//开始运行程序
$frontcontroller->dispatch(); 
?>

4)启动文件说明

zend framework 是这样设计的,所有的文件必须包含在 include_path 中。我们也把我们的模型目录包含在 include path 中,这样我们以后就能很容易加载我们的模型类。一开始,我们必须 include zend/loader.php,这样我们就能访问zend_loader 类,在zend_loader 类中有静态方法使我们能够加载其他zend framework 类,例如:

zend_loader::loadclass('zend_controller_front');

zend_loader::loadclass 加载已经命名的类。它是把下划线转换成路径隔离符来实现的,并在最后加上.php 后缀。这样,类zend_controller_front 将从zend/controller/font.php 加载。如果你在你的类库里使用相同的命名规则,就可以用zend_loader::loadcass()来加载它们。我们需要加载控制器类和路由类。

前端控制器用路由类来映射请求的 url 到正确的 php 函数,然后显示页面。为了能使路由工作,需要解决 url 的哪一部分是指向index.php 的路径,这样它就可以在那个点后面寻找url 元素。

我们需要配置前端路由器,这样它就知道从哪个目录里找出我们的控制器。

$frontcontroller = zend_controller_front::getinstance(); 
$frontcontroller->setcontrollerdirectory('./application/controllers');

设置抛出异常,但是在服务器真正工作以后,我们不应该显示错误信息给用户看。

$frontcontroller->throwexceptions(true);

由于在本实例中我们使用smarty模版技术。所以我们关闭zf本身自带的view。$frontcontroller->setparam('noviewrenderer', true);设置基地址,方便以后设置url来进行跳转。$frontcontroller->setbaseurl('/test');zend_registry::set('font', $frontcontroller);接下来,我们对smarty进行设置。首先我们在类库中引用了smarty.class.php这个类。并且对它的路径进行了设置,以便让zf知道它的位置。:

include 'smarty/smarty.class.php'; 
/**
* 对smarty模版进行初始化
**/
$views = new smarty();
//$views->left_delimiter = "{{";
//$views->right_delimiter = "}}";
$views->compile_dir = './webapp/templates_c';
$views->cache_dir = './webapp/templates_c/cache_c';
$views->template_dir = "./webapp/templates";
function smarty_block_dynamic($param,$content,&$views)
{
return $content;
} 
$views->register_block('dynamic','smarty_block_dynamic',false);

在这里,我们用zf的对象注册表(registry)来对$view来进行存贮,这样,在程序的任何对方,我们都可以调用它来进行操作。zend_registry::set('views', $views);设置好了以后,运行程序。$frontcontroller->dispatch();

这个时候,你如果运行http://127.0.0.1/test 来进行测试。会发现有个错误类似 fatal error: uncaught exception 'zend_controller_dispatcher_exception' with message 'invalid controller specified (index)' in…这个是因为我们还没有设置好我们程序。

3、设置程序

在设置文件以前,理解zend framework 如何组织页面很重要。每个应用程序的页面叫做 action ,许多 action 组成控制器。例如,对于这样一个格式的 url http://localhost/test/news/view/id/1 来说,控制器是news, action 是view,后面的id和1,分别是往这个actionview传递的参数和值。

zend framework 控制器把 index 作为一个缺省的action 而保留为特别的action。这样,对于http://localhost/test/news/ 这样的url,在news控制器里的 index action将被执行。zend framework 也保留了一个缺省的控制器,也叫做index。这样,http://localhost/test/ 将执行 index控制器下的 action index。

4、设置控制器

现在可以设置控制器了。在zend framework 里,控制器是一个必需被叫做{controller name}controller 的类。注意{controller name}必需以大写字母开头。并且,这个类必须在叫做{controller name}controller.php这样的文件中,这个文件还必需在特定的控制器目录中。强调一下,{controller name}必需以大写字母开头并其他字母一定是小写。每个action是在控制器类里的public 函数,名字必需是{action name}action。在这里,{action name}应该以小写字母开头。这样在文件 test/webapp/controllers/indexcontroller.php 里我们的控制器类叫做 indexcontroller,位置:test/webapp/controllers/indexcontroller.php:

<?php 
class indexcontroller extends zend_controller_action 
{ 
function init()
{
} 
function indexaction() 
{ 
} 
function addaction() 
{ 
} 
} 
?>

我们现在有三个我们想使用的action,直到我们设置好视图,它们才工作。其中function init是个特殊的函数,简单的说,它就是在controller中的构造函数时调用的函数。

每个action的 url 如下:

http://localhost/test/ in indexcontroller::indexaction()
http://localhost/test/index/add in indexcontroller::addaction()

现在,我们在程序里有个能工作的路由器和每个页面的 action。

5、设置视图

因为本实例使用的的是smarty模版,所以和zf本身的view视图在实现过程中,稍微有点区别!下面我直接介绍在zf里是任何使用smarty的。在使用smarty之前,我们应该先取出在index.php里定义的$view,并且定义好,需要在模版显示的变量。:

class indexcontroller extends zend_controller_action 
{ 
var $views; /*模板对象*/
var $data; /*传递模版变量的对象*/
function init()
{
//拿回注册过的对象
$this->views = zend_registry::get('views'); 
} 
function indexaction() 
{ 
//定义模版显示的变量 
$data[`title′]=〞hello world〞;
//传递变量到模版
$this->views->assign($data);
//显示模版
$this->views->display('index/index.tpl'); 
} 
function addaction() 
{ 
} 
}

下面我们开始做视图文件,它们的位置是test/webapp/templates/index/index.tpl:

代码:

{$title}

这个时候,输入http://127.0.0.1/test看看。应该会出现“hello world 了。

这样,一个简单的实例就完成了。下面我们结合xmlrpc技术来实现一个稍微复杂一点的实例!

三、xmlrpc

1、什么是xmlrpc

xmlrpc,顾名思义,就是应用了xml技术的rpc。那么什么是xml和rpc了?

rpc是remote procedure call的缩写,翻译成中文就是远程过程调用,是一种在本地的机器上调用远端机器上的一个过程(方法)的技术,这个过程也被大家称为“分布式计算 ,是为了提高各个分立机器的“互操作性 而发明出来的技术。

xml和rpc一样也是一个东西的缩写,这个东西就是extensible markup language,中文意思就是可扩展标记语言,标记语言就是那种用尖括号(<>)括来括去的那种语言,比如说html。xml的可扩展性也体现在它只定义了语言的格式,而并没有定义过多的关键字,也就是通常所说的标记(tag),所以用户可以自由地选择定义标记。它的这种自由和简单的语法规则也使得它广为流传,用来表示各种数据。

2、在zf中使用xmlrpc

1)创建indexcontroller.php

下面我们来完成一个实例,为了方便起见,就不建立新的controller,把刚才我们建立的indexcontroller修改一下,就能使用了!另外我们还需要建立一个xmlrpc的服务端程序。位置在web服务器的根目录上(在本机中,也就是在test文件的上级目录中,取名为1.php),由于xmlrpc使用到了类库,我们还需要下载libphpxmlrpc放在library文件夹下!

文件位置:test/webapp/controller/indexcontroller.php:

class indexcontroller extends zend_controller_action 
{
var $views; /*模板对象*/
var $data; /*传递模版变量的对象*/
public function init()
{
//拿回注册过的对象
$this->views = zend_registry::get('views'); 
$this->font = zend_registry::get('font'); 
//得到基地址 
$this->baseurl=$this->font->getbaseurl();
}
function indexaction() 
{ 
@include "libphpxmlrpc/xmlrpc.inc";
@include "libphpxmlrpc/xmlrpcs.inc"; 
if (isset($_post['var1']) && isset($_post['var2'])) 
{ 
//创建客户端
$client = new xmlrpc_client('http://127.0.0.1/1.php');
//创建一个实例
@ $msg = new xmlrpcmsg("add", array(
new xmlrpcval($_post['var1'], "int"),
new xmlrpcval($_post['var2'], "int")));
//发送信息,
$response=$client->send($xmlrpc_message);,服务器返回xmlrpcresp的一个实例
$retval = $client->send($msg);
if ($retval->faultcode()) 
{
print_r("发生一个错误: "); 
print_r("原因: " . htmlspecialchars($retval->faultstring())); 
} 
else 
{
//$retval->value()获取应答的xmlrpcval(也就是服务器端返回的结果),
$retval->value()->scalarval();得到描述应答结果的php变量
$sum = $retval->value()->scalarval();
}
}
@$data['var1']=$_post['var1'];
@$data['var2']=$_post['var2'];
@$data['sum']=$sum; 
@$data[`action′]= "$this->baseurl/index/"; 
//构造完整的url给模版 
$time=date("y-m-d h:i:s")
@$data['url']="$this->baseurl/index/add/id/$sum/time/$time"; 
/传递变量到模版
$this->views->assign($data);
//显示模版
$this->views->display('index/index.tpl'); 
} 
function addaction() 
{ 
$data['title']="实验一下"; 
//得到传递的值 
$id=$this->_request->getparam("id");
$time=$this->_request->getparam("time"); 
$data['id']="$id";
$data['time']="$time";
$this->views->assign($data);
$this->views->display('index/add.tpl'); 
}
}

2)创建显示模版文件

位置:test/webapp/templates/index/index.tpl:

hello,下面演示的是利用xmlrpc调用远程服务器方法的实例!并且我们把得到的结果传递到另外的一个函数中去!

代码:

{if $sum}
点一下看看!
{/if}

位置: test/webapp/templates/index/add.tpl:

现在是{$time}
{$title}你刚才传递的是 {$id}

3)创建xmlrpc服务器端程序

位置:web/1.php:

<?php
@include ("libphpxmlrpc/xmlrpc.inc");
@include ("libphpxmlrpc/xmlrpcs.inc");
if ($_server['request_method'] != 'post')
{
exit(0);
}
$add_sig = array(array($xmlrpcstring, $xmlrpcint, $xmlrpcint));
$add_doc = "add the two integer together";
function add($params)
{
//引入用户错误代码值
global $xmlrpcerruser;
//返回一个php数组
$val = php_xmlrpc_decode($params);
$ret = $val[0] + $val[1];
return new xmlrpcresp(new xmlrpcval($ret, "int"));
}
//创建一个xmlrpc_server的实例:
$server = new xmlrpc_server(array(
"add" => array(
"function" => "add",
"signature" => $add_sig,
"docstring" => $add_doc
)));
?>

ok,现在打开http;//127.0.0.1/test/看看。刚才建立的那个xmlrpc应该已经建立起来了,输入数字,测试一下吧!

更多关于zend相关内容感兴趣的读者可查看本站专题:《zend framework框架入门教程》、《php优秀开发框架总结》、《yii框架入门及常用技巧总结》、《thinkphp入门教程》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总

希望本文所述对大家基于zend framework框架的php程序设计有所帮助。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网