使用composer构建自己的php框架(fizzday)

【Fizzday03】构建MVC之控制器Controller

2017-07-31  本文已影响13617人  fizzday

控制器

顾名思义, 就是作为框架的业务控制而存在, 其实, 我们在路由部分, 为了测试路由的可用性, 已经建立控制器, 在此顺便规范和完善下我们的控制器:

控制器命名

关于命名, 其实我也做了下参考, 发现目前以 Controller 为名字后缀挺流行的, 于是乎, 我就毫不客气的也加上了, 毕竟, 咱们不能掉队...
对于控制器, 虽然说没有多少要讲的, 还是要注意以下几点:

  1. 命名首字母大写, 后缀 ControllerC 要大写, 如: BaseController.php
  2. 为了业务的控制方便, 我们添加一个总控制器为: BaseController. 为什么要添加这个总控制器呢? 理由请看下边的解释, 当然, 我们可以用另一种方案解决(middlerware)
  3. 理论上可以添加很多个总控制器, 如: AdminController.php. 可以为不同的规则创建不同的总控制器

为什么添加总控制器

其实, 总控制器的好处多多, 不妨请看:
方便统一入口, 方便前置控制等等. 如: 我们提供两种访问方式, 一种是登录访问,如: 后台; 一种是不用登录访问, 如: 首页; 这个时候, 如果我要访问后台的话, 是不是每个方法都要验证一遍? 如果在每个方法中验证, 就会显得很傻缺, 比较快捷省心的做法, 就是我在总控制器验证一下, 然后, 其他需要验证的控制器, 直接继承这个控制器, 就可以省去每个方法都验证的麻烦, 当然, 你也可以在每个控制器的初始化方法中验证, 但是, 那样能快过一个继承 extend 么.
类似的好处还有多多, 等待小伙伴们慢慢体味发掘 (目前的另一种做法是 middleware, 会在后边讲到) , 这里我们先用传统的总控制器方法实现

完善总控制器

$ cd ~/fizzday/app/Controllers && vi BaseController.php

添加内容:

<?php
namespace App\Controller;

class BaseController
{
    public function __construct(){

    }

    public function method1(){

    }

    public function __destruct(){

    }
}

如何使用

比如, 我们昨天的 TestController , 可以修改如下:

<?php
namespace App\Controller;

class TestControlelr extends BaseController;
{
    public function index()
    {
        echo "Fizzday's route success";
    }
}

说明: 一般引入文件, 需要使用 use , 但是, 我们的两个控制器都在同一个命名空间下 , 默认使用当前命名空间, 所以, 不用使用 use App\Controolers\BaseController.

到此, 控制器搞定.

为了更集中化的控制, 我们在这里将框架目录稍微做一下调整, 如下:

~
fizzday
|--|--app/
|--|--|--|--Controllers/
|--|--|--|--Models/
|--|--|--|--Views/
|--|--bootstrap/
|--|--|--|-=boot.php
|--|--config/
|--|--public/
|--|--|--|-=index.php
|--|--routes/
|--|--|--|-=routes.php
|--|--vendor/
|--|--|--|--composer/
|--|--|--|--fizzday/
|--|--|--|--|--|--fizzroute/
|--|--|--|--|--|--|--src/
|--|--|--|--|--|--|--|-=Route.php
|--|-=composer.json
<?php
define('ROOT_PATH', __DIR__ . '/');

require ROOT_PATH . '../bootstrap/boot.php';

变的更简洁了, 这里为了方便以后更多驱动的扩展, 引入了boot.php, 内容如下:

<?php
// 项目的源码根目录
define('BASE_PATH', __DIR__ . '/../');
// 配置目录
define('CONF_PATH', BASE_PATH . 'config/');
// 请求composer入口文件
require BASE_PATH . 'vendor/autoload.php';
// 路由目录
define('ROUTE_PATH', BASE_PATH.config('config.path.route').'/');
// 缓存目录
define('CACHE_PATH', BASE_PATH.config('config.path.cache').'/');

// 取别名, 这样就不需要在 routes/routes.php 中 use FizzRoute 了
class_alias('\\Fizzday\\FizzRoute\\Route', 'Route');
// 引入路由
require ROUTE_PATH . 'route.php';
// 驱动路由
Route::dispatch();

这里定义了各种常用常量, 以及composer的入口文件, 这里呢涉及到了一个自定义函数 config(), 为了方便使用, 我们把自定义函数放到自定义函数工具库中, 因此, 我们这里还需要引入函数文件, 我们同样采用compoer控制, 这样, 这个函数库就可以运用到任何地方了
使用composer引入:

cd ~/fizzday
composer require fizzday/fizzhelper dev-master

现在, 我们完成了框架运行的基本机构, 后边我们就开始填充这个框架, 让它变的更加丰满

完美手工~~~

上一篇 下一篇

猜你喜欢

热点阅读