站長資訊網
        最全最豐富的資訊網站

        如何用PHP搭建自己的web框架?

        本篇文章給大家一分鐘學會如何用PHP搭建自己的web框架?(分享)有一定的參考價值,有需要的朋友可以參考一下,希望對大家有所幫助。

        如何用PHP搭建自己的web框架?

        這里講的WEB是指運行在apache下的PHP WEB程序。

        首先要理解PHP在apache下的運行機制和請求的生命周期。

        PHP是腳本語言,它的執行過程就是從文件入口,一直到文件的最后的結尾,其中可以包含或引用其它文件,是面向過程的。在過程當中,可以使用對象來實現各種需要的邏輯處理。你可以把一個或者多個對象拿來完成所需要的功能,你也可以告訴一個對象你要完成什么功能,這是面向對象的開發方法,也是普遍的開發方法。所以,在面向過程的運行機制中,使用面向對象的開發方式。

        每一個HTTP請求的生命周期也是從入口開始,直到程序結束,其中的變量將不復存在,不同的HTTP請求的變量都是獨立互不影響的。我們可使用global聲明、$GLOBALS全局數組變量、static靜態變量在同一HTTP請求中共享數據;使用session來實現會話級別的共享;使用緩存來實現站點全局數據共享。global聲明一般在方法中,在面向過程的開發中使用,平時不會用到。$GLOBALS和static經常會用到,但不能直接操作,而是在對象里或專門的方法來管理,比如常用的單例模式使用$GLOBALS和static保存。

        PHP程序中,我們都會考慮盡量使框架簡潔、高效、清晰、易用,這對開發和維護都很有好處。

        基本的程序模式使用MVC模式,分層分模塊、同時需要一個好用的URL router配合MVC。

        URL router:很關鍵的一個組件,決定著源碼文件的組織結構、代碼的清晰度。一個好的router,能方便地找到邏輯入口,體現框架的易用性。

        Model: 一直用數組。用數組主要擔心數組內容不清楚,在項目中,屬性參考數據庫字段,因此數組內容還是相對明確的,Model的操作使用數據訪問層DAO封裝。數據庫訪問中,直接轉化為數組形式,也比較高效。對于其它系統的交互數據對象,一般有接口文檔定義。對于ORM中的Active Record技術,能不用還是不用的好。

        View: 開始使用smarty,但在性能報告中,smarty執行的方法耗時占比太多太多,后來使用tmd_tpl,就一個文件,簡單易用高效,易修改。在視圖模板中,結合PHP語法,并輔于模板變量。MVC的思想是分離,并不代表不能在View中使用PHP語法。如果是API接口,可以直接把數據轉化為具體格式結果并返回。

        Controller: 或者action,代表著一個行為、一個方法、一個接口。只有一層的controller往往是不夠用的,一般要分成接口層、業務層、數據訪問層,可能還需要通信層。接口負責參數校驗、接入權限控制,調用具體的業務,最后返回數據或顯示頁面等。所有的業務最好都以接口層開始,在這之前應只做框架方面的事情,當我們需要閱讀某個業務實現時,只要順著接口層入口開始讀即可。業務層是執行實際的業務功能,業務層從數據訪問層獲得數據并進行業務上加工處理。數據訪問層從數據庫或調用接口獲取數據,可進行簡單的數據轉換處理。如果PHP只是作為數據展示前端,后端由C/C++/GO等執行業務,那只需要封裝業務層,在業務層里把數據請求到后端,然后返回給接口層。

        如何用PHP搭建自己的web框架? 如何用PHP搭建自己的web框架?

        以上是程序的基本框架結構,或者說是業務的流程結構,通常作為系統最重要的部分。但離實用還有距離,還有很多基礎功能要增加,比如session的處理,數據庫訪問,日志處理等功能。這些基本功能一般是可以獨立于框架的,可以在不同的框架上應用。功能類不要與框架耦合太緊,一般使用組合方式。我們將這些基礎功能按照用起來順手的方式封裝成核心類,使用單例或多例來調用,或對類進一步封裝成全局使用的方法,方便使用。

        如何用PHP搭建自己的web框架?

        如上圖,中心把握好、梳理好了,體現的是業務能力,因為隨著業務發展,自然會形成業務分層的結構;而周邊結合得好,體現的是框架能力,如何用得/開發得舒適順手的問題。

        在調用功能類或者業務類時,都會涉及到類的加載或導入問題。那是否使用自動加載功能呢?根據個人體驗和IDE支持程度,我覺得不直觀,對IDE不友好,如F3找不到定義的方法,這是我們開源系統學習的感受,還有對性能的影響。還是直接require/include方便,雖然多寫了些代碼,但確實對開發維護閱讀帶了極大的方便(除了修改名稱后導致引用變更不很方便,但可通過全局搜索來修改)。一些公共的類在入口里全局引用,業務類按需引用。性能損失?因為業務大部分時候都是垂直的,一般使用require/include即可,不需要require_once/include_once,即使多使用幾個once也沒什么關系,首先可保證正確性,且程序總體性能不是這個決定的。自動加載會增加很多判斷、指令還有棧操作,文件的查找、損失的性能

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 国产精品成人va| 精品国产一区二区三区免费| 潮喷大喷水系列无码久久精品| 久久精品无码免费不卡| 国产精品免费看久久久| 亚洲国产精品国产自在在线| 尤物国产在线精品福利一区| 骚片AV蜜桃精品一区| 久久久91人妻无码精品蜜桃HD | 国产精品自产拍在线观看| 中文字幕精品视频在线| 精品国产呦系列在线观看免费| 精品久久久久久久久中文字幕| 久久精品人成免费| 欧美国产精品va在线观看| 国产精品久久久天天影视香蕉| 精品少妇一区二区三区视频| 精品人人妻人人澡人人爽人人 | 精品国产午夜理论片不卡| 亚洲日韩一页精品发布| 欧美精品播放| 蜜臀精品国产高清在线观看| 国产高清在线精品一区二区| 久久精品免费观看| 国产精品一二区| 2022精品天堂在线视频| 国产精品兄妹在线观看麻豆| 久久精品国产精品亚洲毛片| 一本一本久久aa综合精品| 日韩精品欧美激情国产一区| 精品久久久久久99人妻| 国产精品自在线拍国产电影 | 国产精品一在线观看| 国产精品岛国久久久久| 999久久久免费精品国产| 国产精品香港三级国产AV| 国产精品亚洲片在线观看不卡| 国产国产精品人在线视| 精品成在人线AV无码免费看| 97久久精品无码一区二区| 99re国产精品视频首页|