Marco PHP escrito en c y construido como una extensión de PHP.
Yaf es una extensión PECL, por lo que puedes instalarla simplemente de la siguiente manera:
$pecl install yaf
$/path/to/phpize
$./configure --with-php-config=/path/to/php-config
$make && make install
El manual de Yaf se puede encontrar en: http://www.php.net/manual/en/book.yaf.php
efnet.org #php.yaf
Puede encontrar un script prototipo documentado aquí: https://github.com/elad-yosifon/php-yaf-doc
Un diseño de directorio de aplicación clásico:
- .htaccess // Rewrite rules
+ public
| - index.php // Application entry
| + css
| + js
| + img
+ conf
| - application.ini // Configure
- application/
- Bootstrap.php // Bootstrap
+ controllers
- Index.php // Default controller
+ views
|+ index
- index.phtml // View template for default controller
+ library // libraries
+ models // Models
+ plugins // Plugins
Debe configurar DocumentRoot
en application/public
, de modo que el usuario solo pueda acceder a la carpeta pública.
index.php
en el directorio público es la única forma de ingresar a la aplicación, debe reescribir todas las solicitudes (puede usar .htaccess
en Apache+php mod)
define ( " APPLICATION_PATH " , dirname ( dirname ( __FILE__ )));
$ app = new Yaf_Application ( APPLICATION_PATH . " /conf/application.ini " );
$ app -> bootstrap () //call bootstrap methods defined in Bootstrap.php
-> run ();
#.htaccess
RewriteEngine On
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule .* index.php
server {
listen ****;
server_name domain.com;
root document_root;
index index.php index.html index.htm;
if (!-e $request_filename) {
rewrite ^/(.*) /index.php/$1 last;
}
}
$HTTP["host"] =~ "(www.)?domain.com$" {
url.rewrite = (
"^/(.+)/?$" => "/index.php/$1",
)
}
application.ini
es el archivo de configuración de la aplicación
[product]
; CONSTANTS is supported
application.directory = APPLICATION_PATH " /application/ "
Alternativamente, puedes usar una matriz PHP en su lugar:
$ config = array (
" application " => array (
" directory " => application_path . " /application/ " ,
),
);
$ app = new yaf_application ( $ config );
. . . .
En Yaf, el controlador predeterminado se llama IndexController
:
class IndexController extends Yaf_Controller_Abstract {
// default action name
public function indexAction () {
$ this -> getView ()-> content = " Hello World " ;
}
}
?>
El script de vista para el controlador predeterminado y la acción predeterminada se encuentra en application/views/index/index.phtml. Yaf proporciona un motor de vista simple llamado "Yaf_View_Simple", que admite la plantilla de vista escrita en PHP.
Hello World
echo $ content ; ?>
http://www.ejemplo.com
Puede generar el ejemplo anterior utilizando Yaf Code Generator: https://github.com/laruence/php-yaf/tree/master/tools/cg
./yaf_cg -d output_directory [-a application_name] [--namespace]
Puede encontrar más información en el Manual de Yaf: http://www.php.net/manual/en/book.yaf.php