官网地址:http://www.laruence.com/manual (推荐看官方文档)
一. 安装与搭建 yaf框架 以及第一个 hello world
yaf下载地址 http://pecl.php.net/package/yaf然后在php.ini中载入yaf.so, 重启PHP
然后php-m 查看是否已有yaf扩展
对于Yaf的应用, 都应该遵循类似下面的目录结构.
一个典型的目录结构
+ public |- index.php //入口文件 |- .htaccess //重写规则 |+ css |+ img |+ js + conf |- application.ini //配置文件 + application |+ controllers |- Index.php //默认控制器 |+ views |+ index //控制器 |- index.phtml //默认视图 |+ modules //其他模块 |+ library //本地类库 |+ models //model目录 |+ plugins //插件目录一个经典的入口文件public/index.php
<?php define("APP_PATH", realpath(dirname(__FILE__) . '/../')); /* 指向public的上一级 */ $app = new Yaf_Application(APP_PATH . "/conf/application.ini"); $app->run();Apache的Rewrite (httpd.conf) .htaccess 重写路由
#.htaccess, 当然也可以写在httpd.conf RewriteEngine On RewriteCond %{REQUEST_FILENAME} !-f RewriteRule .* index.php在Yaf中, 配置文件支持继承, 支持分节. 并对PHP的常量进行支持. 你不用担心配置文件太大造成解析性能问题, 因为Yaf会在第一个运行的时候载入配置文件, 把格式化后的内容保持在内存中. 直到配置文件有了修改, 才会再次载入.
一个简单的配置文件application/conf/application.ini
[product] ;支持直接写PHP中的已定义常量 application.directory=APP_PATH "/application/"Yaf 配置选项
选项名称默认值可修改范围更新记录yaf.environproductPHP_INI_ALL环境名称, 当用INI作为Yaf的配置文件时, 这个指明了Yaf将要在INI配置中读取的节的名字yaf.libraryNULLPHP_INI_ALL全局类库的目录路径yaf.cache_config0PHP_INI_SYSTEM是否缓存配置文件(只针对INI配置文件生效), 打开此选项可在复杂配置的情况下提高性能yaf.name_suffix1PHP_INI_ALL在处理Controller, Action, Plugin, Model的时候, 类名中关键信息是否是后缀式, 比如UserModel, 而在前缀模式下则是ModelUseryaf.name_separator""PHP_INI_ALL在处理Controller, Action, Plugin, Model的时候, 前缀和名字之间的分隔符, 默认为空, 也就是UserPlugin, 加入设置为"_", 则判断的依据就会变成:"User_Plugin", 这个主要是为了兼容ST已有的命名规范yaf.forward_limit5PHP_INI_ALLforward最大嵌套深度yaf.use_namespace0PHP_INI_SYSTEM开启的情况下, Yaf将会使用命名空间方式注册自己的类, 比如Yaf_Application将会变成Yaf\Applicationyaf.use_spl_autoload0PHP_INI_ALL开启的情况下, Yaf在加载不成功的情况下, 会继续让PHP的自动加载函数加载, 从性能考虑, 除非特殊情况, 否则保持这个选项关闭对于默认模块, 控制器的目录是在application目录下的controllers目录下, Action的命名规则是"名字+Action"
默认控制器application/controllers/Index.php
<?php class IndexController extends Yaf_Controller_Abstract { public function indexAction() {//默认Action $this->getView()->assign("content", "Hello World"); } } ?>Yaf支持简单的视图引擎, 并且支持用户自定义自己的视图引擎, 比如Smarty.
对于默认模块, 视图文件的路径是在application目录下的views目录中以小写的action名的目录中.
一个默认Action的视图application/views/index/index.phtml
<html> <head> <title>Hello World</title> </head> <body> <?php echo $content;?> </body> </html>
在浏览器输入
http://127.0.01 (记得在apache配置文件中将访问目录指向到 public)
打印输出:hello world!
转载于:https://www.cnblogs.com/qiuhao/p/6992665.html
