この記事の例では、Zend Framework+smarty の使用法について説明します。以下のように、参考としてみんなと共有してください:
1. 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 の 2 つがあります。
2. Zend Framework の構成
1. ディレクトリ構造
Zend Framework は標準のディレクトリ構造を使用することを要求していませんが、依然としていくつかの一般的なディレクトリ構造があります。このディレクトリ構造は、Apache の構成を完全に制御できることを前提としています。 (以下では例としてこのマシンを使用します。独自の状況に応じて変更する必要があります。私のサーバーのルート ディレクトリは Web フォルダーを指しています)
引用:
Web/
test/
/webapp
/controllers
/models
/templates
/templates_c
/library
/webroot
/images
/js
/css
プログラム内のモデル、ビュー、コントローラー ファイルを異なるサブディレクトリに分離しました。サポートされている画像、スクリプト、CSS ファイルは、webroot ディレクトリの下のさまざまなサブディレクトリに保存されています。ダウンロードした Zend Framework ファイルはライブラリ ディレクトリに配置されます。他のライブラリ ファイルが必要な場合は、ここに配置できます。この例では、Smarty テンプレート テクノロジを使用しているため、Smarty ライブラリ ファイルもライブラリ ファイルの下に配置する必要があります。
2. スタートアップ ファイル
1) 設定 .htaccess
単一のエントリ ファイルindex.php を使用してプログラムにアクセスします。これにより、プログラム内のすべてのページの中心点が提供され、実行環境が確実に設定されます。正しく。この目的を達成するために .htaccess ファイルを使用します。内容は次のとおりです:
RewriteEngine on RewriteRule !".(js|ico|gif|jpg|png|css)$ index.php
同時に、次のことも行う必要があります。 Apache の設定ファイル httpd.conf を開きます。
index.phpは、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(); ?>Zend_Loader: :loadClass 名前付きクラスをロードします。これは、アンダースコアをパス区切り文字に変換し、最後に .php 接尾辞を追加することによって実装されます。このようにして、クラス Zend_Controller_Front が Zend/Controller/font.php からロードされます。クラス ライブラリで同じ命名規則を使用している場合は、Zend_Loader::loadCass() を使用してそれらをロードできます。コントローラー クラスとルーティング クラスをロードする必要があります。 フロントエンド コントローラーはルーティング クラスを使用して、要求された URL を正しい PHP 関数にマップし、ページを表示します。ルーティングが機能するためには、URL のどの部分が Index.php へのパスであるかを解決し、その時点以降の URL 要素を検索できるようにする必要があります。 どのディレクトリでコントローラーを探すかを認識できるように、フロントエンド ルーターを構成する必要があります。
Zend_Loader::loadClass('Zend_Controller_Front');は例外をスローするように設定されていますが、サーバーが実際に動作した後は、ユーザーにエラー メッセージを表示すべきではありません。
$frontController = Zend_Controller_Front::getInstance(); $frontController->setControllerDirectory('./application/controllers');この例では Smarty テンプレート テクノロジーを使用しているためです。したがって、ZF 自体に付属するビューを閉じます。 $frontController->setParam('noViewRenderer', true); 後でジャンプするための URL を設定しやすくするために、ベース アドレスを設定します。 $frontController->setBaseUrl('/test');Zend_Registry::set('font', $frontController);次に、Smarty をセットアップします。まず、クラス ライブラリの Smarty.class.php クラスを参照しました。そして、その経路は政府がその位置を把握できるように設定されています。 :
$frontController->throwExceptions(true);ここでは、ZF のオブジェクト レジストリ (レジストリ) を使用して $view を保存し、それを呼び出してプログラム内の他のパーティで操作を実行できるようにします。 Zend_Registry::set('views', $views); 設定後、プログラムを実行します。 $frontController->dispatch();この時点で、http://127.0.0.1/test を実行してテストします。 「致命的エラー: キャッチされない例外 'Zend_Controller_Dispatcher_Exception' とメッセージ '無効なコントローラーが指定されました (インデックス)' 」のようなエラーが表示されます。これは、プログラムがまだセットアップされていないためです。 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,中文意思就是可扩展标记语言,标记语言就是那种用尖括号(a8093152e673feb7aba1828c43532094)括来括去的那种语言,比如说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 framework框架的PHP程序设计有所帮助。
Zend Framework+smarty の使用例と関連記事の詳細な説明については、PHP 中国語 Web サイトに注目してください。