终于能够 “一次编写,处处发布” 了,泪流满面!
今天凌晨我从一点多开始搞了四个小时到 5:20,终于搞出了个 Emlog 的 MarkDown 插件!欢迎 Emloger 尝试!php
原文发表在个人我的网站:利用 Composer 一步一步构建本身的 PHP 框架(三)——设计 MVChtml
本教程示例代码见 https://github.com/johnlui/My-First-Framework-based-on-Composermysql
在上一篇教程中,咱们使用 codingbean/macaw
这个 Composer 包构建了两条简单路由,第一条是响应 GET ‘/fuck’
的,另外一条会 hold 住全部请求。其实对 PHP 框架来讲,有了路由就有了一切。因此接下来咱们要作的事情就是让 MFFC 框架更加规范,更加丰满。git
这就牵扯到了 PHP 框架另外的价值:确立开发规范以便于多人协做
,使用 ORM
、模板引擎
等工具以提升开发效率
。github
新建 MFFC/app
文件夹,在 app 中建立 controllers
、models
、views
三个文件夹,开始正式开始踏上 MVC 的征程。
(谁说我抄 Laravel 了,我抄的明明是 Rails :-D)web
新建 controllers/BaseController.php 文件:sql
<?php /** * BaseController */ class BaseController { public function __construct() { } }
新建 controllers/HomeController.php 文件:数据库
<?php /** * \HomeController */ class HomeController extends BaseController { public function home() { echo " <h1>控制器成功!</h1> "; } }
增长一条路由: Macaw::get('', 'HomeController@home');
,打开浏览器直接访问 http://127.0.0.1:81/
,出现如下提示:json
Fatal error: Class 'HomeController' not found in /Library/WebServer/Documents/wwwroot/MFFC/vendor/codingbean/macaw/Macaw.php on line 93
为何没找到 HomeController
类?由于咱们没有让他自动加载,修改 composer.json 为:数组
{ "require": { "codingbean/macaw": "dev-master" }, "autoload": { "classmap": [ "app/controllers", "app/models" ] } }
运行 composer dump-autoload
,稍等片刻,刷新,你将看到如下内容(别忘了调节编码哦~):
恭喜你,命名空间使用成功!
新建 models/Article.php 文件,内容为(数据库密码请自行更改):
<?php /** * Article Model */ class Article { public static function first() { $connection = mysql_connect("localhost","root","password"); if (!$connection) { die('Could not connect: ' . mysql_error()); } mysql_set_charset("UTF8", $connection); mysql_select_db("mffc", $connection); $result = mysql_query("SELECT * FROM articles limit 0,1"); if ($row = mysql_fetch_array($result)) { echo '<h1>'.$row["title"].'</h1>'; echo '<p>'.$row["content"].'</p>'; } mysql_close($connection); } }
修改 controllers/HomeController.php 文件:
<?php /** * \HomeController */ class HomeController extends BaseController { public function home() { Article::first(); } }
刷新,这时候会获得 Article
类未找到的信息,由于咱们没有更新自动加载配置:
composer dump-autoload
在等待的时间里,咱们去创建数据库 mffc
,在里面创建表 articles
,设计两个字段 title
、content
用于记录信息,并填充进至少一条数据。你也能够在创建完成 mffc
数据库之后运行如下 SQL 语句:
DROP TABLE IF EXISTS `articles`; CREATE TABLE `articles` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `title` varchar(255) DEFAULT NULL, `content` longtext, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; LOCK TABLES `articles` WRITE; /*!40000 ALTER TABLE `articles` DISABLE KEYS */; INSERT INTO `articles` (`id`, `title`, `content`) VALUES (1,'我是标题',' <h3>我是内容呀~~</h3> <p>我真的是内容,不信算了,哼~ O(∩_∩)O</p> '), (2,'我是标题',' <h3>我是内容呀~~</h3> <p>我真的是内容,不信算了,哼~ O(∩_∩)O</p> '); /*!40000 ALTER TABLE `articles` ENABLE KEYS */; UNLOCK TABLES;
而后,刷新!你将看到如下页面:
恭喜你!MVC 中的 M 和 C 都已经实现!接下来咱们开始调用 V (视图)。
修改 models/Article.php 为:
<?php /** * Article Model */ class Article { public static function first() { $connection = mysql_connect("localhost","root","C4F075C4"); if (!$connection) { die('Could not connect: ' . mysql_error()); } mysql_set_charset("UTF8", $connection); mysql_select_db("mffc", $connection); $result = mysql_query("SELECT * FROM articles limit 0,1"); if ($row = mysql_fetch_array($result)) { return $row; } mysql_close($connection); } }
将包含查询结果的数组返回。修改 HomeController:
<?php /** * \HomeController */ class HomeController extends BaseController { public function home() { $article = Article::first(); require dirname(__FILE__).'/../views/home.php'; } }
保存,刷新,你将获得跟上面如出一辙的页面,视图调用成功!
几乎全部人都是经过学习某个框架来了解 MVC 的,这样可能框架用的很熟,一旦离了框架一个简单的页面都写不了,更不要说本身设计 MVC 架构了,其实这里面也没有那么多门道,原理很是清晰,我说说个人感悟:
php test.php
没有任何区别,都只是一段字符串做为参数传递给 PHP 解释器而已。无非就是复杂的网站会根据 URL 来调用须要运行的文件和代码,而后返回相应的结果。CodeIgniter
这样 180 个文件
组成的“小框架”,仍是 Laravel
这样加上 vendor 一共 3700 多个文件
的 “大框架”,他们都会在每个 URL 的驱动下,组装一段能够运行的字符串,传给 PHP 解释器,再把从 PHP 解释器返回的字符串传给访客的浏览器。