そこに登場したCodeIgniterは機能が豊富ですっきりとしている良質なモダンフレームワークとして人気なようです。
今回のFuelPHPはCodeIgniterの開発者なども参加しており、CodeIgniterや他のプロダクトのいいとこどりの期待のフレームワークだそうです。
主な特徴は
・MVC
・HMVC(画面要素の複数のMVCモジュールをひとつに纏めて1画面をつくれる)
・モジュール拡張可能
・セキュリティ対応(出力エンコーディング、入力フィルタ、XSS、CSRF、SQLインジェクション)
・豊富なコマンドライン
・ORMとSQLどちらもOK
・認証機構つき
・複数のビューテンプレート(smartyなど)に対応
・scaffoldできる
・migrateできる
・PHPUnitできる
こう見ると分かる通り、Railsから多くの影響を受けているようです。
では、さっそく触ってみます。
ここでは、
ドキュメントルートを/var/www/html
アプリベースを/opt/cloudpack/
として、blogアプリをつくってみたいと思います。
インストール
$ curl get.fuelphp.com/oil | sh $ cd /opt/cloudpack/ $ oil create blogこれだけでひと通りのセットが揃います。
次にセキュリティのためにpublicフォルダだけをDocumentRootに移動します。
# mv blog/public /var/www/html/blog
そして、index.phpに書いてある、アプリパスを変更します。
# vi /var/www/html/blog/index.php ~ /** * Path to the application directory. */ define('APPPATH', realpath('/opt/cloudpack/blog/fuel/app/').DIRECTORY_SEPARATOR); /** * Path to the default packages directory. */ define('PKGPATH', realpath('/opt/cloudpack/blog/fuel/packages/').DIRECTORY_SEPARATOR); /** * The path to the framework core. */ define('COREPATH', realpath('/opt/cloudpack/blog/fuel/core/').DIRECTORY_SEPARATOR);
それでは画面をみてみます。
おー、Welcome画面が表示されてました。
とりあえず問題ないようです。
Scaffolding
次にデータベースの設定をします。(mysqlサーバーがインストールされ起動していることを前提とします)
vi /opt/cloudpack/blog/fuel/app/config/db.php
'default' => array( 'type' => 'mysql', 'connection' => array( 'hostname' => 'localhost', 'port' => '8889', 'database' => 'blog', 'username' => 'memorycraft', 'password' => '*********', 'persistent' => false, ), 'identifier' => '`', 'table_prefix' => '', 'charset' => 'utf8', 'caching' => false, 'profiling' => false, ),
vi /opt/cloudpack/blog/fuel/app/config/development/db.php
'default' => array( 'connection' => array( 'dsn' => 'mysql:host=localhost;dbname=blog', 'username' => 'memorycraft', 'password' => '***********', ), ),
mysqlでデータベースとユーザーを作成します。
mysql> create database blog; mysql> GRANT ALL PRIVILEGES ON blog.* TO 'memorycraft@localhost' IDENTIFIED BY '*******';次に、scaffoldをつくってみます。
$ cd /opt/cloudpack/blog/ $ oil g scaffold blog title:string body:string tags:string created_at:date
そしてmigrate
$ oil refine migrate
これで、データベースblogにblogテーブルが作成されました。
mysql> show databases; +--------------------+ | Database | +--------------------+ | information_schema | | blog | | mysql | | performance_schema | | test | +--------------------+ 5 rows in set (0.00 sec)
それでは画面をみてみます。
ブログの管理画面ができています。
入力して
登録すると、、、、
おおー!一覧に保存内容がひょうじされました。
railsと同じノリですね。
あくまでひな形ですが、このくらいのスピードでDB、画面ができあがります。
PHPはもうこれでいいんじゃないかなと思うくらいの可能性を感じます。
これから使い込んでみたいと思います。
以上です。