Framework PHP écrit en C et construit comme une extension PHP.
Yaf est une extension PECL, vous pouvez donc simplement l'installer en :
$pecl install yaf
$/path/to/phpize
$./configure --with-php-config=/path/to/php-config
$make && make install
Le manuel Yaf peut être trouvé à l'adresse : http://www.php.net/manual/en/book.yaf.php
efnet.org #php.yaf
Vous pouvez trouver un prototype de script documenté ici : https://github.com/elad-yosifon/php-yaf-doc
Une disposition classique du répertoire d'application :
- .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
Vous devez définir DocumentRoot
sur application/public
, ainsi seul le dossier public est accessible par l'utilisateur
index.php
dans le répertoire public est le seul moyen d'accéder à l'application, vous devez réécrire toutes les requêtes (vous pouvez utiliser .htaccess
dans le mod Apache+php)
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
est le fichier de configuration de l'application
[product]
; CONSTANTS is supported
application.directory = APPLICATION_PATH " /application/ "
Alternativement, vous pouvez utiliser un tableau PHP à la place :
$ config = array (
" application " => array (
" directory " => application_path . " /application/ " ,
),
);
$ app = new yaf_application ( $ config );
. . . .
Dans Yaf, le contrôleur par défaut est nommé IndexController
:
class IndexController extends Yaf_Controller_Abstract {
// default action name
public function indexAction () {
$ this -> getView ()-> content = " Hello World " ;
}
}
?>
Le script de vue pour le contrôleur par défaut et l'action par défaut se trouve dans application/views/index/index.phtml. Yaf fournit un moteur de vue simple appelé "Yaf_View_Simple", qui prend en charge le modèle de vue écrit en PHP.
Hello World
echo $ content ; ?>
http://www.exemple.com
Vous pouvez générer l'exemple ci-dessus en utilisant Yaf Code Generator : https://github.com/laruence/php-yaf/tree/master/tools/cg
./yaf_cg -d output_directory [-a application_name] [--namespace]
Plus d'informations peuvent être trouvées sur le manuel Yaf : http://www.php.net/manual/en/book.yaf.php