PHP MVC框架核心類?
現(xiàn)在我們舉幾個(gè)核心框架的例子演示:在framework/core下建立一個(gè)Framework.class.php的文件。寫入以下代碼:?
// framework/core/Framework.class.php?
class Framework {?
?? public static function run() {?
?????? echo "run()";?
?? }?
兄弟連教育www.lampbrother.net在這個(gè)演示中創(chuàng)建了一個(gè)靜態(tài)方法run(),現(xiàn)在讓我們通過入口文件index.php測(cè)試一下:?
require "framework/core/Framework.class.php";?
Framework::run();?
你可以在你的瀏覽器里訪問index.php看到結(jié)果。通常這個(gè)靜態(tài)方法被命名為run()或者bootstrap()。在這個(gè)方法中,我們要做3件最主要的事情:?
class Framework {?
?? public static function run() {?
//??????? echo "run()";?
?????? self::init();?
?????? self::autoload();?
?????? self::dispatch();?
?? }?
?? private static function init() {?
?? }?
?? private static function autoload() {?
?? }?
?? private static function dispatch() {?
?? }?
}?
初始化?
init()方法:?
// Initialization?
private static function init() {?
??? // Define path constants?
??? define("DS", DIRECTORY_SEPARATOR);?
??? define("ROOT", getcwd() . DS);?
??? define("APP_PATH", ROOT . 'application' . DS);?
??? define("FRAMEWORK_PATH", ROOT . "framework" . DS);?
??? define("PUBLIC_PATH", ROOT . "public" . DS);?
??? define("CONFIG_PATH", APP_PATH . "config" . DS);?
??? define("CONTROLLER_PATH", APP_PATH . "controllers" . DS);?
??? define("MODEL_PATH", APP_PATH . "models" . DS);?
??? define("VIEW_PATH", APP_PATH . "views" . DS);?
??? define("CORE_PATH", FRAMEWORK_PATH . "core" . DS);?
??? define('DB_PATH', FRAMEWORK_PATH . "database" . DS);?
??? define("LIB_PATH", FRAMEWORK_PATH . "libraries" . DS);?
??? define("HELPER_PATH", FRAMEWORK_PATH . "helpers" . DS);?
??? define("UPLOAD_PATH", PUBLIC_PATH . "uploads" . DS);?
??? // Define platform, controller, action, for example:?
??? // index.php?p=admin&c=Goods&a=add?
??? define("PLATFORM", isset($_REQUEST['p']) ? $_REQUEST['p'] : 'home');?
??? define("CONTROLLER", isset($_REQUEST['c']) ? $_REQUEST['c'] : 'Index');?
??? define("ACTION", isset($_REQUEST['a']) ? $_REQUEST['a'] : 'index');?
??? define("CURR_CONTROLLER_PATH", CONTROLLER_PATH . PLATFORM . DS);?
??? define("CURR_VIEW_PATH", VIEW_PATH . PLATFORM . DS);?
??? // Load core classes?
??? require CORE_PATH . "Controller.class.php";?
??? require CORE_PATH . "Loader.class.php";?
??? require DB_PATH . "Mysql.class.php";?
??? require CORE_PATH . "Model.class.php";?
??? // Load configuration file?
??? $GLOBALS['config'] = include CONFIG_PATH . "config.php";?
??? // Start session?
??? session_start();?
}?
在注釋中你可以看到每一步的目的。?
自動(dòng)加載?
在項(xiàng)目中,我們不想在腳本中想使用一個(gè)類的時(shí)候手動(dòng)的去include或者require加載,這就是為什么PHP MVC框架都有自動(dòng)加載的功能。例如,在symfony中,如果你想要加載lib下的類,它將會(huì)被自動(dòng)引入。很神奇是吧?現(xiàn)在讓我們?cè)谧约旱目蚣苤屑尤胱詣?dòng)加載的功能。?
這里我們要用的PHP中的自帶函數(shù)spl_autoload_register:?
// Autoloading?
private static function autoload(){?
??? spl_autoload_register(array(__CLASS__,'load'));?
}?
// Define a custom load method?
private static function load($classname){?
??? // Here simply autoload app’s controller and model classes?
??? if (substr($classname, -10) == "Controller"){?
??????? // Controller?
??????? require_once CURR_CONTROLLER_PATH . "$classname.class.php";?
??? } elseif (substr($classname, -5) == "Model"){?
??????? // Model?
??????? require_once? MODEL_PATH . "$classname.class.php";?
??? }?
}?
每一個(gè)框架都有自己的命名規(guī)則,我們的也不例外。對(duì)于一個(gè)控制器類,它需要被命名成類似xxxController.class.php,對(duì)于一個(gè)模型類,需要被命名成xxModel.class.php。為什么在使用一個(gè)框架的時(shí)候你需要遵守它的命名規(guī)則呢?自動(dòng)加載就是一條原因。?
路由/分發(fā)?
// Routing and dispatching?
private static function dispatch(){?
??? // Instantiate the controller class and call its action method?
??? $controller_name = CONTROLLER . "Controller";?
??? $action_name = ACTION . "Action";?
??? $controller = new $controller_name;?
??? $controller->$action_name();?
}?
在這步中,index.php將會(huì)分發(fā)請(qǐng)求到對(duì)應(yīng)的Controller::Aciton()方法中。?
基礎(chǔ)Controller類?
通常在框架的核心類中都有一個(gè)基礎(chǔ)的控制器。在symfony中,被稱為sfAction;在iOS中,被稱為UIViewController。在這里我們命名為Controller,在framework/core下建立Controller.class.php?
// Base Controller?
class Controller{?
??? // Base Controller has a property called $loader, it is an instance of Loader class(introduced later)?
??? protected $loader;?
??? public function __construct(){?
??????? $this->loader = new Loader();?
??? }?
??? public function redirect($url,$message,$wait = 0){?
??????? if ($wait == 0){?
??????????? header("Location:$url");?
??????? } else {?
??????????? include CURR_VIEW_PATH . "message.html";?
??????? }?
??????? exit;?
??? }?
}?
基礎(chǔ)控制器有一個(gè)變量$loader,它是Loader類的實(shí)例化(后面介紹)。準(zhǔn)確的說,$this->loader是一個(gè)變量指向了被實(shí)例化的Load類。在這里我不過多的討論,但是這的確是一個(gè)非常關(guān)鍵的概念。我遇到過一些PHP開發(fā)者相信在這個(gè)語(yǔ)句之后:?
$this->loader = new Loader();?
$this->load是一個(gè)對(duì)象。不,它只是一個(gè)引用。這是從Java中開始使用的,在Java之前,在C++和Objective C中被稱為指針。引用是個(gè)封裝的指針類型。比如,在iOS(O-C)中,我們創(chuàng)建了一個(gè)對(duì)象:?
UIButton *btn = [UIButton alloc] init];?
加載類?
在framework.class.php中,我們已經(jīng)封裝好了應(yīng)用的控制器和模型的自動(dòng)加載。但是如何自動(dòng)加載在framework目錄中的類呢?現(xiàn)在我們可以新建一個(gè)Loader類,它會(huì)加載framework目錄中的類和函數(shù)。當(dāng)我們加載framework類時(shí),只需要調(diào)用這個(gè)Loader類中的方法即可。?
class Loader{?
??? // Load library classes?
??? public function library($lib){?
??????? include LIB_PATH . "$lib.class.php";?
??? }?
??? // loader helper functions. Naming conversion is xxx_helper.php;?
??? public function helper($helper){?
??????? include HELPER_PATH . "{$helper}_helper.php";?
??? }?
}

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Menilai kos/prestasi sokongan komersial untuk rangka kerja Java melibatkan langkah-langkah berikut: Tentukan tahap jaminan yang diperlukan dan jaminan perjanjian tahap perkhidmatan (SLA). Pengalaman dan kepakaran pasukan sokongan penyelidikan. Pertimbangkan perkhidmatan tambahan seperti peningkatan, penyelesaian masalah dan pengoptimuman prestasi. Timbang kos sokongan perniagaan terhadap pengurangan risiko dan peningkatan kecekapan.

Mengikut penanda aras, untuk aplikasi kecil dan berprestasi tinggi, Quarkus (permulaan pantas, memori rendah) atau Micronaut (TechEmpower cemerlang) adalah pilihan yang ideal. SpringBoot sesuai untuk aplikasi bertindan penuh yang besar, tetapi mempunyai masa permulaan dan penggunaan memori yang lebih perlahan.

Keluk pembelajaran rangka kerja PHP bergantung pada kecekapan bahasa, kerumitan rangka kerja, kualiti dokumentasi dan sokongan komuniti. Keluk pembelajaran rangka kerja PHP adalah lebih tinggi jika dibandingkan dengan rangka kerja Python dan lebih rendah jika dibandingkan dengan rangka kerja Ruby. Berbanding dengan rangka kerja Java, rangka kerja PHP mempunyai keluk pembelajaran yang sederhana tetapi masa yang lebih singkat untuk bermula.

Rangka kerja PHP yang ringan meningkatkan prestasi aplikasi melalui saiz kecil dan penggunaan sumber yang rendah. Ciri-cirinya termasuk: saiz kecil, permulaan pantas, penggunaan memori yang rendah, kelajuan dan daya tindak balas yang dipertingkatkan, dan penggunaan sumber yang dikurangkan: SlimFramework mencipta API REST, hanya 500KB, responsif yang tinggi dan daya pemprosesan yang tinggi.

Pelan hala tuju pembelajaran rangka kerja Java untuk bidang yang berbeza: Pembangunan web: SpringBoot dan PlayFramework. Lapisan kegigihan: Hibernate dan JPA. Pengaturcaraan reaktif bahagian pelayan: ReactorCore dan SpringWebFlux. Pengkomputeran masa nyata: ApacheStorm dan ApacheSpark. Pengkomputeran Awan: AWS SDK untuk Java dan Google Cloud Java.

Menulis dokumentasi yang jelas dan komprehensif adalah penting untuk rangka kerja Golang. Amalan terbaik termasuk mengikut gaya dokumentasi yang ditetapkan, seperti Panduan Gaya Pengekodan Google. Gunakan struktur organisasi yang jelas, termasuk tajuk, subtajuk dan senarai, serta sediakan navigasi. Menyediakan maklumat yang komprehensif dan tepat, termasuk panduan permulaan, rujukan API dan konsep. Gunakan contoh kod untuk menggambarkan konsep dan penggunaan. Pastikan dokumentasi dikemas kini, jejak perubahan dan dokumen ciri baharu. Sediakan sokongan dan sumber komuniti seperti isu dan forum GitHub. Buat contoh praktikal, seperti dokumentasi API.

Pilih rangka kerja Go terbaik berdasarkan senario aplikasi: pertimbangkan jenis aplikasi, ciri bahasa, keperluan prestasi dan ekosistem. Rangka kerja Common Go: Gin (aplikasi Web), Echo (Perkhidmatan Web), Fiber (daya pemprosesan tinggi), gorm (ORM), fasthttp (kelajuan). Kes praktikal: membina REST API (Fiber) dan berinteraksi dengan pangkalan data (gorm). Pilih rangka kerja: pilih fasthttp untuk prestasi utama, Gin/Echo untuk aplikasi web yang fleksibel, dan gorm untuk interaksi pangkalan data.

Terdapat lima salah faham dalam pembelajaran rangka kerja Go: terlalu bergantung pada rangka kerja dan fleksibiliti terhad. Jika anda tidak mengikut konvensyen rangka kerja, kod tersebut akan menjadi sukar untuk dikekalkan. Menggunakan perpustakaan lapuk boleh menyebabkan isu keselamatan dan keserasian. Penggunaan pakej yang berlebihan mengaburkan struktur kod. Mengabaikan pengendalian ralat membawa kepada tingkah laku yang tidak dijangka dan ranap sistem.
