06/04/2021, 14:46

MVC PHP - Tìm hiểu file FT_Common.ph - Học MVC PHP nâng cao

Ở bài trước chúng ta đã tìm hiểu được sơ lược cách load controller trong project MVC PHP nhưng đó không phải là cách mà chúng ta sẽ sử dụng, vì vậy trong bài này ta sẽ sửa lại một số phần mà ở bài trước đã làm như sửa file admin.php, thêm file config init.php, xóa phương thức load() trong ...

Ở bài trước chúng ta đã tìm hiểu được sơ lược cách load controller trong project MVC PHP nhưng đó không phải là cách mà chúng ta sẽ sử dụng, vì vậy trong bài này ta sẽ sửa lại một số phần mà ở bài trước đã làm như sửa file admin.php, thêm file config init.php, xóa phương thức load() trong FT_Controller.php.

Trước tiên bạn xem lại cấu trúc folder project của chúng ta.

356/cau-hinh-system-core-mvc.png

Trong sơ đồ này ta có một file FT_Common.php , file này mục đích lưu trữ những hàm load hệ thống và trong bài này ta sẽ tìm hiểu nó.

1. Tạo config cho module

Trước tiên bạn cần tạo một folder config năm trong folder admin. Sau đó tạo một file init.php và dán nội dung sau vào:

 

<?php

return array(
    'default_controller'    => 'index', // controller mặc định
    'default_action'        => 'index', // action mặc định
    '404_controller'        => 'error', // controller lỗi 404
    '404_action'            => 'index'  // action lỗi 404
);

 

Và đây là sơ đồ file:

cau-truc-folder-mvc-php.png

Trong file này mình đã return về một mảng gồm các thông số cấu hình để chạy ứng dụng như thông số controller mặc định và thông số controller lỗi 404 (bài tiếp theo sẽ đề cập tới 404).

Có lẽ bạn sẽ thắc mắc tại sao phần cấu hình nằm trong file system/config/config.php mình đã tạo hai hằng số CONTROLLER_DEFAULT và ACTION_DEFAULT để xử Controller DefaultAction Default rồi mà giờ lại tạo trong file init.php. Đơn giản nếu ta đặt các thông số này trong phần system/config thì  tất cả các module đều có cấu hình chung. Tôi muốn mỗi module có thể tùy chỉnh và thay đổi thông số controller mặc định thì bắt buộc phải đưa nó vào admin/config.

Bây giờ bạn mở file system/config/config.phpxóa đi hai hằng số CONTROLLER_DEFAULT và ACTION_DEFAULT đi nhé vì chúng ta không sử dụng nó.

Sau khi xóa xong ta phải đổi lại file admin.php, lý do là trong file này có sử dụng hai hằng số đó.

 

<?php

// Đường dẫn tới hệ  thống
define('PATH_SYSTEM', __DIR__ .'/system');
define('PATH_APPLICATION', __DIR__ . '/admin');

// Lấy thông số cấu hình
require (PATH_SYSTEM . '/config/config.php');

//mở file FT_Common.php, file này chứa hàm FT_Load() chạy hệ thống
include_once PATH_SYSTEM . '/core/FT_Common.php';

// Chương trình chính
FT_load();

 

Ồ, nó hơi ngắn hơn trước phải không nào. Lý do là mình đã import vào file FT_Common.php và gọi đến hàm FT_Load() nằm trong nó. Để hiểu rõ hơn (hàm TF_Load() đâu ra)  thì ta qua phần 2 nhé.

2. Tìm hiểu file FT_Common.php

File FT_Common.php dùng để chứa những hàm sử dụng trong quá trình load hệ thống. Ví dụ như phương thức load() mà ta đã viết trong file FT_Controller.php thì thay vì viết ở đây ta sẽ viết nó nằm trong file FT_Common.php.

Bạn xóa phương thức load() trong FT_Controller đi nhé, lúc này nội dung nó còn như sau:

 

<?php if ( ! defined('PATH_SYSTEM')) die ('Bad requested!');

/**
 * @package		FT_Framework
 * @author		Zaidap.com Dev Team
 * @email       Zaidap.com.net@gmail.com
 * @copyright	Copyright (c) 2015
 * @since		Version 1.0
 * @filesource  system/core/FT_Controller.php
 */
class FT_Controller
{
    // Đối tượng view
    protected $view     = NULL;
    
    // Đối tượng model
    protected $model    = NULL;
    
    // Đối tượng library
    protected $library  = NULL;
    
    // Đối tượng helper
    protected $helper   = NULL;
    
    // Đối tượng config
    protected $config   = NULL;
    
    /**
	 * Hàm khởi tạo
     * 
     * @desc    Load các thư viện cần thiết
	 */
    public function __construct($is_controller = true) 
    {
        
    }
}

 

Tiếp bạn vào file FT_Common.php và dán nội dung sau vào:

 

<?php if ( ! defined('PATH_SYSTEM')) die ('Bad requested!');
/**
 * Hàm chạy ứng dụng
 */
function FT_load()
{
    // Lấy phần config khởi tạo ban đầu
    $config = include_once PATH_APPLICATION . '/config/init.php';

    // Nếu không truyền controller thì lấy controller mặc định
    $controller = empty($_GET['c']) ? $config['default_controller'] : $_GET['c'];

    // Nếu không truyền action thì lấy action mặc định 
    $action = empty($_GET['a']) ? $config['default_action'] : $_GET['a'];

    // Chuyển đổi tên controller vì nó có định dạng là {Name}_Controller
    $controller = ucfirst(strtolower($controller)) . '_Controller';

    // chuyển đổi tên action vì nó có định dạng {name}Action
    $action = strtolower($action) . 'Action';
    
    // Kiểm tra file controller có tồn tại hay không
    if (!file_exists(PATH_APPLICATION . '/controller/' . $controller . '.php')){
        die ('Không tìm thấy controller');
    }
    
    // Include controller chính để các controller con nó kế thừa
    include_once PATH_SYSTEM . '/core/FT_Controller.php';
    
    // Gọi file controller vào
    require_once PATH_APPLICATION . '/controller/' . $controller . '.php';

    // Kiểm tra class controller có tồn tại hay không
    if (!class_exists($controller)){
        die ('Không tìm thấy controller');
    }

    // Khởi tạo controller
    $controllerObject = new $controller();

    // Kiểm tra action có tồn tại hay không
    if ( !method_exists($controllerObject, $action)){
        die ('Không tìm thấy action');
    }
    
    // Chạy ứng dụng
    $controllerObject->{$action}();
}

 

Các bạn thấy nội dung của nó na ná phương thức load() mà ta đã xóa ở FT_Controller đúng không nào. Chỉ có sự khác nhau là:

  • Có lấy nội dung config trong file admin/config/init.php
  • Thay vì gọi đến hai hằng số mà ta đã xóa (CONTROLLER_DEFAULT ACTION_DEFAULT) thì ta sẽ htay nó bằng các giá trị config trong file init.php.
  • Có include file FT_Controller.php để các lớp controller trong admin có thể kế thừa

Ok bây giờ bạn chạy lại URL như bài trước thì kết quả sẽ y chang nhau.

3. Chạy thử ứng dụng

Trước tiên bạn mở controller News_Controller.php lên và sửa lại nội dung như sau:

 

<?php if ( ! defined('PATH_SYSTEM')) die ('Bad requested!');

class News_Controller extends FT_Controller
{
    public function indexAction()
    {
        echo '<pre>';
        print_r($this);
        echo '<h1>Index Action</h1>';
    }
}

 

Sau đó vào URL http://localhost/mvc/admin.php?c=news&a=index thì sẽ xuất hiện hình như sau là mọi chuyện đã xử lý xong:

357/chay-thu-mvc.png

Bạn có thắc mắc tại sao lại như hình không? Lý do mình sử dụng print_r($this) mà lớp này có kế thừa FT_Controller nên nó có chứa các thuộc tính dạng protected.

4. Lời kết

Trong bài này chủ yếu mình sửa một số đoạn code và giải thích cách sử dụng file FT_Common,php để chứa những hàm xử lý riêng của hệ thống.

Trong bài các bạn cần chú ý các vấn đề sau:

  • Có tạo mới file admin/config/init.php
  • Xóa đi phương thức load() trong FT_Controller.php
  • Chỉnh lại file bootstrap admin.php và nó có gọi qua hàm FT_Load() nằm trong file FT_Common.php
  • Thêm hàm FT_Load() vào file FT_Common.php

Chúc các bạn học tốt!

Trần Trung Dũng

15 chủ đề

2610 bài viết

0