# beego 的 MVC 架構介紹
beego 是一個典型的 MVC 框架,它的整個執行邏輯如下圖所示:

通過文字來描述如下:
1. 在監聽的端口接收數據,默認監聽在 8080 端口。
2. 用戶請求到達 8080 端口之后進入 beego 的處理邏輯。
3. 初始化 Context 對象,根據請求判斷是否為 WebSocket 請求,如果是的話設置 Input,同時判斷請求的方法是否在標準請求方法中(GET、POST、PUT、DELETE、PATCH、OPTIONS、HEAD),防止用戶的惡意偽造請求攻擊造成不必要的影響。
4. 執行 BeforeRouter 過濾器,當然在 beego 里面有開關設置。如果用戶設置了過濾器,那么該開關打開,這樣可以提高在沒有開啟過濾器的情況下提高執行效率。如果在執行過濾器過程中,responseWriter 已經有數據輸出了,那么就提前結束該請求,直接跳轉到監控判斷。
5. 開始執行靜態文件的處理,查看用戶的請求 URL 是否和注冊在靜態文件處理 StaticDir 中的 prefix 是否匹配。如果匹配的話,采用 `http` 包中默認的 ServeFile 來處理靜態文件。
6. 如果不是靜態文件開始初始化 session 模塊(如果開啟 session 的話),這個里面大家需要注意,如果你的 BeforeRouter 過濾器用到了 session 就會報錯,你應該把它加入到 AfterStatic 過濾器中。
7. 開始執行 AfterStatic 過濾器,如果在執行過濾器過程中,responseWriter 已經有數據輸出了,那么就提前結束該請求,直接跳轉到監控判斷。
8. 執行過過濾器之后,開始從固定的路由規則中查找和請求 URL 相匹配的對象。這個匹配是全匹配規則,即如果用戶請求的 URL 是 `/hello/world`,那么固定規則中 `/hello` 是不會匹配的,只有完全匹配才算匹配。如果匹配的話就進入邏輯執行,如果不匹配進入下一環節的正則匹配。
9. 正則匹配是進行正則的全匹配,這個正則是按照用戶添加 beego 路由順序來進行匹配的,也就是說,如果你在添加路由的時候你的順序影響你的匹配。和固定匹配一樣,如果匹配的話就進行邏輯執行,如果不匹配進入 Auto 匹配。
10. 如果用戶注冊了 AutoRouter,那么會通過 `controller/method` 這樣的方式去查找對應的 Controller 和他內置的方法,如果找到就開始執行邏輯,如果找不到就跳轉到監控判斷。
11. 如果找到 Controller 的話,那么就開始執行邏輯,首先執行 BeforeExec 過濾器,如果在執行過濾器過程中,responseWriter 已經有數據輸出了,那么就提前結束該請求,直接跳轉到監控判斷。
12. Controller 開始執行 Init 函數,初始化基本的一些信息,這個函數一般都是 beego.Controller 的初始化,不建議用戶繼承的時候修改該函數。
13. 是否開啟了 XSRF,開啟的話就調用 Controller 的 XsrfToken,然后如果是 POST 請求就調用 CheckXsrfCookie 方法。
14. 繼續執行 Controller 的 Prepare 函數,這個函數一般是預留給用戶的,用來做 Controller 里面的一些參數初始化之類的工作。如果在初始化中 responseWriter 有輸出,那么就直接進入 Finish 函數邏輯。
15. 如果沒有輸出的話,那么根據用戶注冊的方法執行相應的邏輯,如果用戶沒有注冊,那么就調用 http.Method 對應的方法(Get/Post 等)。執行相應的邏輯,例如數據讀取,數據賦值,模板顯示之類的,或者直接輸出 JSON 或者 XML。
16. 如果 responseWriter 沒有輸出,那么就調用 Render 函數進行模板輸出。
17. 執行 Controller 的 Finish 函數,這個函數是預留給用戶用來重寫的,用于釋放一些資源。釋放在 Init 中初始化的信息數據。
18. 執行 AfterExec 過濾器,如果有輸出的話就跳轉到監控判斷邏輯。
18. 執行 Controller 的 Destructor,用于釋放 Init 中初始化的一些數據。
19. 如果這一路執行下來都沒有找到路由,那么會調用 404 顯示找不到該頁面。
20. 最后所有的邏輯都匯聚到了監控判斷,如果用戶開啟了監控模塊(默認是開啟一個 8088 端口用于進程內監控),這樣就會把訪問的請求鏈接扔給監控程序去記錄當前訪問的 QPS,對應的鏈接訪問的執行時間,請求鏈接等。
接下來就讓我們開始進入 beego 的 MVC 核心第一步,路由設置:
- [路由設置](controller/router.md)
- [控制器函數](controller/controller.md)
- [xsrf 過濾](controller/xsrf.md)
- [session 控制](controller/session.md)
- [flash 數據](controller/flash.md)
- [請求數據處理](controller/params.md)
- [多種格式數據輸出](controller/jsonxml.md)
- [表單數據驗證](controller/validation.md)
- [模板輸出](view/view.md)
- [模板函數](view/template.md)
- [錯誤處理](controller/errors.md)
- [靜態文件處理](view/static.md)
- [參數配置](controller/config.md)
- [日志處理](controller/logs.md)
- beego簡介
- 為 beego 貢獻
- 發布版本
- 升級指南
- beego安裝升級
- Bee 工具的使用
- 快速入門
- 新建項目
- 路由設置
- Controller 運行機制
- model 邏輯
- view 編寫
- 靜態文件處理
- beego 的 MVC 架構介紹
- controller 設計
- 參數配置
- 路由設置
- 控制器函數
- XSRF 過濾
- 請求數據處理
- session 控制
- 過濾器
- flash 數據
- URL構建
- 多種格式數據輸出
- 表單數據驗證
- 錯誤處理
- 日志處理
- model設計
- 概述
- ORM 使用
- CRUD 操作
- 高級查詢
- 原生 SQL 查詢
- 構造查詢
- 事務處理
- 模型定義
- 命令模式
- 測試用例
- 自定義字段
- FAQ
- view 設計
- 模板語法指南
- 模板處理
- 模板函數
- 靜態文件處理
- 模板分頁處理
- beego 的模塊設計
- session 模塊
- grace 模塊
- cache 模塊
- logs 模塊
- httplib 模塊
- context 模塊
- toolbox 模塊
- config 模塊
- i18n 模塊
- beego 高級編程
- 進程內監控
- API 自動化文檔
- 應用部署
- 獨立部署
- supervisor 部署
- Nginx 部署
- apache 部署
- beego 第三方庫
- 應用例子
- 在線聊天室
- 短域名服務
- Todo 列表
- beego實用庫
- 驗證碼
- 分頁
- FAQ