# 模式擴展
[上一頁](149.html "上一頁")[下一頁](151.html "下一頁")
模式擴展屬于系統核心級別的擴展,可以改變底層的架構體系。在眾多擴展中,也只有模式擴展具有改變和替換核心MVC的可能,其他擴展只是在標準模式基礎之上的增強和替換,無法從根本上改變底層的架構。所以,大家會看到不同的模式擴展可能具有很大的用法區別,有些模式擴展是為某個特別的應用環境而定制的,例如CLI模式、AMF模式和PHPRPC模式。
新版對模式擴展的改進和行為擴展的增強使得開發人員對底層框架的DIY更加方便,也正是因為支持對框架底層進行DIY,使得ThinkPHP能夠滿足企業開發中更加復雜的項目需求。### 使用模式擴展
我們前面所涉及的所有用法都是基于框架內置的標準模式的,除了標準模式之外,官方還提供了一些常用的模式擴展,模式擴展的目錄位于Extend/Mode下面,已經提供的包括:Cli(命令模式)、Lite(精簡模式)、Thin(簡潔模式)、AMF模式、PHPRPC模式和REST模式,他們為不同的需求提供了不同的底層框架解決方案。通常來說不同的模式之間是無法進行切換。
要使用某個擴展模式,需要修改項目的入口文件,添加一行定義代碼:`define('MODE_NAME','模式擴展名稱');`每個項目只能使用一個模式擴展,所以即使采用了分組,不同的分組也只能采用相同的模式擴展。使用了模式擴展后,項目的編譯緩存文件有所變化,例如,如果你當前用的是REST模式,那么生成的編譯緩存文件則會變成~rest_runtime.php。
具體不同模式的用法需要參考每個模式擴展的幫助文件。### 簡潔模式
簡潔模式相當于標準模式的主要區別在于:
默認不使用任何模板引擎(可以自己在操作方法里面調用);
模型僅支持原生SQL操作和事務;
支持多數據庫切換和連接;
默認僅支持MySQL數據庫;
不支持語言包、模塊分組、模板主題和Dispatch功能;
去除了大部分擴展機制;
如果你的應用選擇了Mysql數據庫,并且完全使用原生SQL操作,并希望有一個輕巧的核心,那么簡潔模式是一個很好的選擇。
要使用簡潔模式,需要在項目的入口文件中添加模式定義:`define('MODE_NAME','Thin');//采用簡潔模式運行`### 精簡模式
精簡模式在簡潔模式的基礎上,增加了:
默認使用PHP模板;
支持不帶路由的Dispatch;
支持不帶回調接口的CURD操作;
支持連貫操作、統計查詢;
精簡模式比簡潔模式在模型方面多了CURD和連貫操作,如果你習慣于使用PHP作為模板,并且還是喜歡使用模型的CURD功能,但又不希望核心那么龐大,那么精簡模式是一個不錯的選擇。
要使用精簡模式,需要在項目的入口文件中添加模式定義:`define('MODE_NAME','Lite');//采用精簡模式運行`### 命令模式
命令模式用于支持命令行模式下面的PHP應用,需要在入口文件設置:`define('MODE_NAME',?'cli')?//采用CLI運行模式運行`在命令模式下面,支持兩種命令行的參數模式,
一、PATHINFO參數模式(URL_MODEL為1)
在PATHINFO參數模式下面,我們可以這樣調用模塊和操作`index.php?module/action/id/4`二、普通參數模式(URL_MODEL設置為其它)
在普通參數模式下面 ,我們需要這樣調用模塊和操作`index.php?module?action?id?4`在命令行模式下面,系統會自動把參數轉換為GET變量,無論采用哪種命令行參數模式,我們可以直接使用GET變量獲取參數,例如,采用下面的方式調用`index.php?Info/read/category/2/id/4`在控制器中,我們可以直接獲取$_GET['category'](這里傳入的是2)和$_GET['id'](這里傳入的是4)參數,如果你需要自己解析傳入的參數順序和值,就需要采用原生的系統變量$_SERVER['argv']來獲取參數了。### AMF模式
AMF模式采用了ZendAMF類庫,支持AMF開發和Flash進行通訊。首先,我們需要設置當前運行模式為Amf模式,在入口文件中增加下面代碼:`define('MODE_NAME',?'amf')?//采用Amf運行模式運行`然后在項目配置文件中定義`'APP_AMF_ACTIONS'=>'Index,User,Shop…'//?定義AMF模式的模塊列表`只有在APP_AMF_ACTIONS中定義的模塊才能在Amf模式中調用到。
最后一步就是在你的Flash客戶端或者AS腳本中修改Amf的網關地址為當前項目的入口地址即可。### PHPRPC模式
首先,我們設置當前運行模式為Phprpc模式:`define('MODE_NAME',?'phprpc')?//采用Phprpc運行模式運行`然后在項目配置文件中定義`'APP_PHPRPC_ACTIONS'=>'Index,User,Shop…'//?定義PHPRPC模式的模塊列表`只有在APP_PHPRPC_ACTIONS中定義的模塊才能在PHPRPC模式中調用到。### REST模式
Rest模式主要是為了支持RESTFul的開發,鑒于目前Rest主要用來提供接口服務,所以單獨作為模式擴展來使用。首先,我們設置當前運行模式為rest模式:`define('MODE_NAME',?'rest')?//采用rest模式運行`關于Rest的更多用法,請參考16.2 REST支持部分。### 定制模式擴展
要定制自己的模式擴展,首先要定義模式擴展的定義文件,定義文件位于Extend/Mode目錄下面,命名就是模式擴展的名稱(全部為小寫),定義文件是一個數組,包括:core 系統核心列表文件定義 config 模式配置文件 alias 模式別名定義文件 extends 模式系統行為定義 tags 應用行為定義文件 core是模式核心列表文件,如果core沒有定義,則表示采用標準模式的核心列表文件,被定義的文件列表會納入編譯緩存,核心列表可以包含函數文件和類庫文件,注意下面的文件無需定義:系統的Common公共文件、Think類、ThinkException類和Behavior類。下面的類必須定義:App類和Action類。
config是模式配置定義,可以采用文件名或者直接用數組定義的方式。
alias是模式別名定義,可以采用文件名或者直接用數組定義的方式。
extends是模式系統行為定義,可以采用文件名或者直接用數組定義的方式。
tags是應用行為定義,可以采用文件名或者直接用數組定義的方式。
上面這些定義,只有需要的時候才要定義,如果沒有則可不必定義,一般core定義是模式擴展必須的,改變核心列表文件的定義就能起到自定義MVC的目的。
例如,命令行模式的模式定義文件為:`//?命令行模式定義文件<br class="calibre5"></br>return?array(<br class="calibre5"></br>????'core'?=>???array(<br class="calibre5"></br>????????MODE_PATH.'Cli/functions.php',???//?命令行系統函數庫<br class="calibre5"></br>????????MODE_PATH.'Cli/Log.class.php',<br class="calibre5"></br>????????MODE_PATH.'Cli/App.class.php',<br class="calibre5"></br>????????MODE_PATH.'Cli/Action.class.php',<br class="calibre5"></br>????),<br class="calibre5"></br>????//?項目別名定義文件?[支持數組直接定義或者文件名定義]<br class="calibre5"></br>????'alias'?????????=>????array(<br class="calibre5"></br>????????'Model'????=>???MODE_PATH.'Cli/Model.class.php',<br class="calibre5"></br>????????'Db'????????=>????MODE_PATH.'Cli/Db.class.php',<br class="calibre5"></br>????????'Cache'?????????=>?CORE_PATH.'Core/Cache.class.php',<br class="calibre5"></br>????????'Debug'?????????=>?CORE_PATH.'Util/Debug.class.php',<br class="calibre5"></br>????),<br class="calibre5"></br>????//?系統行為定義文件<br class="calibre5"></br>????'extends'????=>????array(),<br class="calibre5"></br>);`模式擴展本身是一個擴展的集成,自身還可以包含其他擴展,例如行為擴展、函數擴展、類庫擴展等。如果模式擴展中包含了自己的行為擴展,那么可以放到模式擴展目錄下面的Behavior目錄下面,系統可以自動加載該目錄下面的行為類庫。
[上一頁](149.html "上一頁")[下一頁](151.html "下一頁")
- 序言
- 1. 入門
- 1.1 簡介
- 1.2 基礎概念
- 1.3 獲取ThinkPHP
- 1.4 環境要求
- 1.5 許可協議
- 1.6 目錄結構
- 1.7 命名規范
- 1.8 MVC分層
- 1.9 CBD架構
- 1.10 特性概述
- 1.11 系統流程
- 1.12 開發流程
- 2. 入口
- 2.1 入口文件
- 2.2 項目目錄
- 2.3 部署目錄
- 2.4 項目編譯
- 2.5 調試模式
- 3. 配置
- 3.1 配置格式
- 3.2 慣例配置
- 3.3 項目配置
- 3.4 調試配置
- 3.5 分組配置
- 3.6 讀取配置
- 3.7 動態配置
- 3.8 擴展配置
- 4. 函數和類庫
- 4.1 函數庫
- 4.2 類庫
- 5. 控制器
- 5.1 URL模式
- 5.2 模塊和操作
- 5.3 定義控制器
- 5.4 空操作
- 5.5 空模塊
- 5.6 模塊分組
- 5.7 URL偽靜態
- 5.8 URL路由
- 5.9 URL重寫
- 5.10 URL生成
- 5.11 URL大小寫
- 5.12 前置和后置操作
- 5.13 跨模塊調用
- 5.14 頁面跳轉
- 5.15 重定向
- 5.16 獲取系統變量
- 5.17 判斷請求類型
- 5.18 獲取URL參數
- 5.19 AJAX返回
- 5.20 Action參數綁定
- 5.21 多層控制器支持
- 6. 模型
- 6.1 模型定義
- 6.2 模型實例化
- 6.3 字段定義
- 6.4 數據主鍵
- 6.5 屬性訪問
- 6.6 跨庫操作
- 6.7 連接數據庫
- 6.8 切換數據庫
- 6.9 分布式數據庫
- 6.10 創建數據
- 6.11 字段映射
- 6.12 連貫操作
- 6.13 CURD操作
- 6.14 ActiveRecord
- 6.15 自動驗證
- 6.16 命名范圍
- 6.17 自動完成
- 6.18 查詢語言
- 6.19 查詢鎖定
- 6.20 字段排除
- 6.21 事務支持
- 6.22 高級模型
- 6.23 視圖模型
- 6.24 關聯模型
- 6.25 Mongo模型
- 6.26 動態模型
- 6.27 虛擬模型
- 6.28 多層模型支持
- 7. 視圖
- 7.1 模板定義
- 7.2 模板賦值
- 7.3 模板輸出
- 7.4 模板替換
- 7.5 獲取內容
- 7.6 模板引擎
- 7.7 布局模板
- 8. 模板引擎
- 8.1 變量輸出
- 8.2 系統變量
- 8.3 使用函數
- 8.4 默認值輸出
- 8.5 使用運算符
- 8.6 內置標簽
- 8.7 包含文件
- 8.8 導入文件
- 8.9 Volist標簽
- 8.10 Foreach標簽
- 8.11 For標簽
- 8.12 Switch標簽
- 8.13 比較標簽
- 8.14 三元運算
- 8.15 范圍判斷標簽
- 8.16 Present標簽
- 8.17 Empty標簽
- 8.18 Defined標簽
- 8.19 Define標簽
- 8.20 Assign標簽
- 8.21 IF標簽
- 8.22 標簽嵌套
- 8.23 使用PHP代碼
- 8.24 模板布局
- 8.25 模板繼承
- 8.26 原樣輸出
- 8.27 模板注釋
- 8.28 引入標簽庫
- 8.29 修改定界符
- 8.30 避免JS混淆
- 9. 日志
- 9.1 日志級別
- 9.2 記錄方式
- 9.3 手動記錄
- 10. 錯誤
- 10.1 異常處理
- 10.2 異常模板
- 10.3 異常顯示
- 11. 調試
- 11.1 運行狀態
- 11.2 頁面Trace
- 11.3 調試方法
- 12. 緩存
- 12.1 緩存方式
- 12.2 動態緩存
- 12.3 緩存隊列
- 12.4 快捷緩存
- 12.5 快速緩存
- 12.6 查詢緩存
- 12.7 SQL解析緩存
- 12.8 靜態緩存
- 13. 擴展
- 13.1 行為擴展
- 13.2 類庫擴展
- 13.3 控制器擴展
- 13.4 模型擴展
- 13.5 驅動擴展
- 13.6 Widget擴展
- 13.7 模式擴展
- 13.8 引擎擴展
- 14. 安全
- 14.1 表單令牌
- 14.2 字段類型驗證
- 14.3 防止SQL注入
- 14.4 輸入過濾
- 14.5 上傳安全
- 14.6 防止XSS攻擊
- 14.7 其他安全建議
- 14.8 目錄安全文件
- 14.9 保護模板文件
- 15. 性能
- 15.1 關閉調試模式
- 15.2 開啟緩存
- 15.3 合并字段緩存
- 15.4 優化SQL
- 15.5 替換入口
- 15.6 前端優化
- 16. 部署
- 16.1 PATH_INFO支持
- 16.2 隱藏index.php
- 16.3 二級域名部署
- 16.4 定制錯誤頁面
- 16.5 設置時區
- 17. SAE支持
- 17.1 SAE介紹
- 17.2 獲取SAE
- 17.3 SAE開發
- 18. REST支持
- 18.1 REST介紹
- 18.2 REST模式
- 18.3 REST配置
- 18.4 REST路由
- 18.5 REST方法
- 19. 雜項
- 19.1 Session支持
- 19.2 Cookie支持
- 19.3 日期和時間
- 19.4 WML開發
- 19.5 多語言
- 19.6 數據分頁
- 19.7 文件上傳
- 19.8 驗證碼
- 19.9 圖片添加水印
- 19.10 IP獲取和定位
- 20. 附錄
- 20.1 常量參考
- 20.2 配置參考
- 20.3 關于升級
- 20.4 大事記
- 鳴謝
- 關于