本文實例講述了CodeIgniter自定義控制器MY_Controller用法。分享給大家供大家參考,具體如下:
Codeigniter所有的控制器都必須繼承CI_Controller類,但CI_Controller類位於system目錄下,不太方便修改。為方便做一些公用的處理,通常情況下我們會在core下創建MY_Controller,用來繼承CI_Controller,從而項目中所有的控制器繼承MY_Controller。
那麼,MY_Controller 通常會做些什麼呢?
所有的控制器都繼承了MY_Controller, MY_Controller常常會加載一些公用幫助函數、公用類庫,以及實現一些公用的方法。
公用的方法?公有的方法?
看到這些方法會意識到一個問題,如果方法是public的,那是否可以通過浏覽器訪問到。答案是可以的!這樣不該讓用戶訪問到的方法讓用戶訪問到了。那設置protected吧。。。
備注:CI_Controller中寫public方法不會被訪問到,框架限制了CI_Controller中方法通過浏覽器訪問。
隨著項目的不斷進展,MY_Controller中的公用方法會越來越多。如果此時要增加後台管理的功能,所有的控制器依然繼承MY_Controller,那其中的很多方法可能不適用了。如果後台需要的一些公用方法也寫在這裡,這裡將會變得混亂。
如何按模塊區分不同的控制器?
有兩種處理的方式,第一種是通過不同的公用控制器文件來區分,由控制器去決定繼承哪一個公用控制器,當然這裡得引入公用文件。還有這種方式是可以通過對象的一個屬性來維護,不同的模塊賦予該屬性不同的對象。如:
<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed'); class MY_Controller extends CI_Controller { public function __construct($type = NULL) { parent::__construct(); switch($type) { case 'api' : $this->load->library('api_helper', NULL, 'helper'); break; case 'admin' : $this->load->library('admin_helper', NULL, 'helper'); break; default : $this->load->library('app_helper', NULL, 'helper'); break } } } /* End of file MY_Controller.php */ /* Location: ./application/core/MY_Controller.php */
控制器調用MY_Controller構造函數並傳入type值,根據不同的type值會加載不同的類庫,然後給類定義一個統一的別名,方便處理。具體的library可以處理該模塊公用的方法或load公用的資源,相當於該模塊的一個公用類。當然處理方式也可以是直接通過路由中的目錄名或者控制器名稱來控制等等。
這樣避免了加載不同的文件,調用方法時只需要通過$this->helper對象調用。在仔細看看,可以發現不同模塊的公用類是放在library中,放在library或helper中都可以使用get_intance獲取控制器對象,但每次使用都需要獲取實例,相對麻煩,如果是模型呢?感覺也不太好。其中的公用方法有一些會跟業務邏輯相關,放在library感覺不太合適。
業務邏輯好像並沒有一個好的地方去實現,控制器的私有方法?模型?
先總結下上面的處理方法:
1、不同模塊之間可以按需加載以及實現自定義的公用方法,各個模塊之間互不影響。如果各模塊之間的公用方法比較多,也可以再去繼承一個公用的類。
2、公用方法放在library中,調用CI實例不方便。
3、如果不喜歡$this->herlper的調用方法,可以讓控制器去繼承不同的公用控制器,思路是一樣的,只是可能需要手動引入文件。
更多關於CodeIgniter相關內容感興趣的讀者可查看本站專題:《codeigniter入門教程》和《CI(CodeIgniter)框架進階教程》
希望本文所述對大家基於CodeIgniter框架的PHP程序設計有所幫助。