设计php框架_利用 Composer 一步一步构建自己的 PHP 框架(三)——设计 MVC

利用 Composer 一步一步构建自己的 PHP 框架(三)——设计 MVC

2014-10-14 / 阅读数:50438 / 分类: PHP

终于可以 “一次编写,到处发布” 了,泪流满面!今天凌晨我从一点多开始搞了四个小时到 5:20,终于搞出了个 Emlog 的 MarkDown 插件!欢迎 Emloger 尝试!

回顾

在上一篇教程中,我们使用 codingbean/macaw 这个 Composer 包构建了两条简单路由,第一条是响应 GET ‘/fuck’ 的,另一条会 hold 住所有请求。其实对 PHP 框架来说,有了路由就有了一切。所以接下来我们要做的事情就是让 MFFC 框架更加规范,更加丰满。

这就牵扯到了 PHP 框架另外的价值:确立开发规范以便于多人协作,使用 ORM、模板引擎 等工具以提高开发效率。

正式开始

规划文件夹

新建 MFFC/app 文件夹,在 app 中创建 controllers、models、views 三个文件夹,开始正式开始踏上 MVC 的征程。

(谁说我抄 Laravel 了,我抄的明明是 Rails :-D)

使用命名空间

新建 controllers/BaseController.php 文件:<?php

/**

* BaseController

*/

class BaseController

{

public function __construct()

{

}

}

新建 controllers/HomeController.php 文件:<?php

/**

* \HomeController

*/

class HomeController extends BaseController

{

public function home()

{

echo "

控制器成功!

";

}

}

增加一条路由: Macaw::get('', 'HomeController@home');,打开浏览器直接访问 http://127.0.0.1:81/,出现以下提示: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,稍等片刻,刷新,你将看到以下内容(别忘了调节编码哦~):

0da9cc4e57746561d8dad2c69289e0c6.png

恭喜你,命名空间使用成功!

连接数据库

新建 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 '

'.$row["title"].'

';

echo '

'.$row["content"].'

';

}

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,'我是标题','

我是内容呀~~

我真的是内容,不信算了,哼~ O(∩_∩)O

'),

(2,'我是标题','

我是内容呀~~

我真的是内容,不信算了,哼~ O(∩_∩)O

');

/*!40000 ALTER TABLE `articles` ENABLE KEYS */;

UNLOCK TABLES;

然后,刷新!你将看到以下页面:

ae16e9987c6e43afd4ee375a9f37a10d.png

恭喜你!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);

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值