逐步提升php框架的性能
更新時間:2008年01月10日 20:32:43 作者:
逐步提升php框架的性能
一、當(dāng)前框架存在什么問題
目前主流的框架Zend Framework、Cakephp等都采用了MVC模式,同時實(shí)現(xiàn)了URL的路由分配。比如說http://www.xxx.com/user/login就會映射到userController對象中的loginAction方法,http://www.xxx.com/user/register對應(yīng)為userController對象中的registerAction方法。這樣對應(yīng)的userController對象就很可能是這樣的。
<?
class userController extends controller{
function loginAction(){
//login
}
function registerAction(){
}
}
?>
那么這存在什么樣的問題呢?很明顯:包含了不必要的代碼!比如說你訪問/user/login完全沒必要包含registerAction()方法里面的內(nèi)容。上面的代碼只是簡單的例子,一般來說controller對應(yīng)的是一個小功能模塊,它會有比較多的功能操作的,尤其在比較大的項(xiàng)目中。這樣,如果一個controller里面有十幾個方法,那么每請求就包含了很多冗余的代碼。而在PHP性能提升中很重要的一點(diǎn):盡量避免包含不相關(guān)代碼!
在我最近的小項(xiàng)目中,我采用自己的phpbean框架(框架類似Zend Framework),在后來的開發(fā)發(fā)現(xiàn)的確每個controller包含太多action了,后來不得不考慮分流。但很不理想。項(xiàng)目地址:http://www.songjin.net:8080。
二、問題不是因?yàn)槊鎸ο蟮腻e
很多人認(rèn)為“包含多余的冗余代碼是面對對象的錯誤”,我不同意。正如我上篇說的:面對對象能實(shí)現(xiàn)面對過程的所有功能,并且做的更好!關(guān)鍵是采用面對對象的思維來使用面對對象,而不是用面對過程的思維來寫面對對象的程序。
三、如何解決這個問題呢?
解決的關(guān)鍵就是把a(bǔ)ction分離開來。如何分離呢?首先要清楚controller的作用。controller是控制器,主要是做請求的轉(zhuǎn)發(fā),把http請求轉(zhuǎn)發(fā)到具體的action上。注意:在struts中是沒有存在controller文件的(注意不是說沒有控制器),它是直接映射到action文件。所以我們完全可以把controller直接放到路由轉(zhuǎn)發(fā)中,而真正的流程控制、邏輯處理等放到action中。
比如說上面的例子,我們就可以分離成兩個文件:
loginAction.php
<?
class loginAction extends Action{
function run(){
}
}
?>
和registerAction.php
<?
class registerAction extends Action{
function run(){
}
}
?>
這樣就實(shí)現(xiàn)了action的分離。當(dāng)你訪問/user/login請求的時候就不會包含registerAction的代碼。
但這樣又存在兩個問題:
第一、實(shí)際項(xiàng)目中action文件會非常多,如何有效的管理是個關(guān)鍵。
第二、同一功能模塊中的操作可能有共同的代碼,如何共享?
第一個問題比較好解決。把同一個模塊的action放到一個子文件夾中,也就是說允許多級目錄。比如說我們上面的代碼中就可以把loginAction.php和registerAction.php放到user目錄中。但注意這樣會增加路由分配的麻煩度,如何實(shí)現(xiàn)就看讀者自己去思考了。
第二個問題的解決也不難,關(guān)鍵是具有面向?qū)ο蟮乃季S。這里,我們就可以采用對象的繼承來實(shí)現(xiàn)。比如說上面的例子,我們可以先定義一個user抽象類。
<?
class user extends Action(){
function __contruct(){
//比如說權(quán)限檢查
}
}
?>
然后讓loginAction 和RegisterAction都繼承與user。這樣就可以很好解決了。
四、總結(jié)
上面的解決方案只是我這幾天的想法,可能還不夠完善。具體應(yīng)用大家可以再細(xì)化并優(yōu)化。對于MVC、框架我始終認(rèn)為在PHP5中,對象比過程更適合,也更有效(除去創(chuàng)建對象本身的成本)。對于使用函數(shù)來實(shí)現(xiàn)框架,前一段在PCTI的講課中我也試過,我覺得思路都差不多,但相對來說我更喜歡對象。
最后,上面的解決方案參考了java中的struts的部分思想。在此表示感謝!
目前主流的框架Zend Framework、Cakephp等都采用了MVC模式,同時實(shí)現(xiàn)了URL的路由分配。比如說http://www.xxx.com/user/login就會映射到userController對象中的loginAction方法,http://www.xxx.com/user/register對應(yīng)為userController對象中的registerAction方法。這樣對應(yīng)的userController對象就很可能是這樣的。
<?
class userController extends controller{
function loginAction(){
//login
}
function registerAction(){
}
}
?>
那么這存在什么樣的問題呢?很明顯:包含了不必要的代碼!比如說你訪問/user/login完全沒必要包含registerAction()方法里面的內(nèi)容。上面的代碼只是簡單的例子,一般來說controller對應(yīng)的是一個小功能模塊,它會有比較多的功能操作的,尤其在比較大的項(xiàng)目中。這樣,如果一個controller里面有十幾個方法,那么每請求就包含了很多冗余的代碼。而在PHP性能提升中很重要的一點(diǎn):盡量避免包含不相關(guān)代碼!
在我最近的小項(xiàng)目中,我采用自己的phpbean框架(框架類似Zend Framework),在后來的開發(fā)發(fā)現(xiàn)的確每個controller包含太多action了,后來不得不考慮分流。但很不理想。項(xiàng)目地址:http://www.songjin.net:8080。
二、問題不是因?yàn)槊鎸ο蟮腻e
很多人認(rèn)為“包含多余的冗余代碼是面對對象的錯誤”,我不同意。正如我上篇說的:面對對象能實(shí)現(xiàn)面對過程的所有功能,并且做的更好!關(guān)鍵是采用面對對象的思維來使用面對對象,而不是用面對過程的思維來寫面對對象的程序。
三、如何解決這個問題呢?
解決的關(guān)鍵就是把a(bǔ)ction分離開來。如何分離呢?首先要清楚controller的作用。controller是控制器,主要是做請求的轉(zhuǎn)發(fā),把http請求轉(zhuǎn)發(fā)到具體的action上。注意:在struts中是沒有存在controller文件的(注意不是說沒有控制器),它是直接映射到action文件。所以我們完全可以把controller直接放到路由轉(zhuǎn)發(fā)中,而真正的流程控制、邏輯處理等放到action中。
比如說上面的例子,我們就可以分離成兩個文件:
loginAction.php
<?
class loginAction extends Action{
function run(){
}
}
?>
和registerAction.php
<?
class registerAction extends Action{
function run(){
}
}
?>
這樣就實(shí)現(xiàn)了action的分離。當(dāng)你訪問/user/login請求的時候就不會包含registerAction的代碼。
但這樣又存在兩個問題:
第一、實(shí)際項(xiàng)目中action文件會非常多,如何有效的管理是個關(guān)鍵。
第二、同一功能模塊中的操作可能有共同的代碼,如何共享?
第一個問題比較好解決。把同一個模塊的action放到一個子文件夾中,也就是說允許多級目錄。比如說我們上面的代碼中就可以把loginAction.php和registerAction.php放到user目錄中。但注意這樣會增加路由分配的麻煩度,如何實(shí)現(xiàn)就看讀者自己去思考了。
第二個問題的解決也不難,關(guān)鍵是具有面向?qū)ο蟮乃季S。這里,我們就可以采用對象的繼承來實(shí)現(xiàn)。比如說上面的例子,我們可以先定義一個user抽象類。
<?
class user extends Action(){
function __contruct(){
//比如說權(quán)限檢查
}
}
?>
然后讓loginAction 和RegisterAction都繼承與user。這樣就可以很好解決了。
四、總結(jié)
上面的解決方案只是我這幾天的想法,可能還不夠完善。具體應(yīng)用大家可以再細(xì)化并優(yōu)化。對于MVC、框架我始終認(rèn)為在PHP5中,對象比過程更適合,也更有效(除去創(chuàng)建對象本身的成本)。對于使用函數(shù)來實(shí)現(xiàn)框架,前一段在PCTI的講課中我也試過,我覺得思路都差不多,但相對來說我更喜歡對象。
最后,上面的解決方案參考了java中的struts的部分思想。在此表示感謝!
您可能感興趣的文章:
- 深入理解PHP中的static和yield關(guān)鍵字
- PHP yield關(guān)鍵字功能與用法分析
- PHP5.5新特性之yield理解與用法實(shí)例分析
- php和C#的yield迭代器實(shí)現(xiàn)方法對比分析
- 分享五個PHP7性能優(yōu)化提升技巧
- PHP開啟opcache提升代碼性能
- PHP 7安裝使用體驗(yàn)之性能大提升,兼容性強(qiáng),擴(kuò)展支持不夠(升級PHP要謹(jǐn)慎)
- 提高PHP編程效率 引入緩存機(jī)制提升性能
- 提升PHP性能的21種方法介紹
- 使用Huagepage和PGO來提升PHP7的執(zhí)行性能
- php使用yield對性能提升的測試實(shí)例分析
相關(guān)文章
php數(shù)組保存文本與文本反編成數(shù)組實(shí)例
這篇文章主要介紹了php數(shù)組保存文本與文本反編成數(shù)組的方法,通過兩個自定義函數(shù)string2array與array2string實(shí)例展示了php數(shù)組保存文本與文本反編成數(shù)組的實(shí)現(xiàn)方法,具有不錯的參考借鑒價值,需要的朋友可以參考下2014-11-11
PHP通過調(diào)用新浪API生成t.cn格式短網(wǎng)址鏈接的方法詳解
這篇文章主要介紹了PHP通過調(diào)用新浪API生成t.cn格式短網(wǎng)址鏈接的方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了php調(diào)用新浪API生成t.cn格式短網(wǎng)址鏈接的具體操作步驟與相關(guān)注意事項(xiàng),需要的朋友可以參考下2019-02-02
PHP實(shí)現(xiàn)預(yù)定義鉤子和自定義鉤子的簡單示例
這篇文章主要給大家介紹了PHP實(shí)現(xiàn)預(yù)定義鉤子和自定義鉤子,在PHP中,鉤子(Hooks)是一種機(jī)制,允許開發(fā)人員在特定的時機(jī)插入自定義代碼,通過使用鉤子,開發(fā)人員可以在應(yīng)用程序的特定事件發(fā)生時執(zhí)行自定義的功能或邏輯,文中有詳細(xì)的代碼講解,需要的朋友可以參考下
2023-11-11
php通過header增加Key、Sign和Timestamp實(shí)現(xiàn)鑒權(quán)機(jī)制的流程步驟
在現(xiàn)代Web應(yīng)用程序中,鑒權(quán)是確保只有合法用戶能夠訪問資源的關(guān)鍵部分,在PHP中,你可以通過在HTTP請求的Header中添加Key、Sign和Timestamp來實(shí)現(xiàn)鑒權(quán)機(jī)制,需要的朋友可以參考下
2023-10-10 
