# 13.1 項目規劃
做任何事情都需要做好規劃,那么我們在開發博客系統之前,同樣需要做好項目的規劃,如何設置目錄結構,如何理解整個項目的流程圖,當我們理解了應用的執行過程,那么接下來的設計編碼就會變得相對容易了
## gopath以及項目設置
假設指定gopath是文件系統的普通目錄名,當然我們可以隨便設置一個目錄名,然后將其路徑存入GOPATH。前面介紹過GOPATH可以是多個目錄:在window系統設置環境變量;在linux/MacOS系統只要輸入終端命令`export gopath=/home/astaxie/gopath`,但是必須保證gopath這個代碼目錄下面有三個目錄pkg、bin、src。新建項目的源碼放在src目錄下面,現在暫定我們的博客目錄叫做beeblog,下面是在window下的環境變量和目錄結構的截圖:

圖13.1 環境變量GOPATH設置

圖13.2 工作目錄在$gopath/src下
## 應用程序流程圖
博客系統是基于模型-視圖-控制器這一設計模式的。MVC是一種將應用程序的邏輯層和表現層進行分離的結構方式。在實踐中,由于表現層從Go中分離了出來,所以它允許你的網頁中只包含很少的腳本。
- 模型 (Model) 代表數據結構。通常來說,模型類將包含取出、插入、更新數據庫資料等這些功能。
- 視圖 (View) 是展示給用戶的信息的結構及樣式。一個視圖通常是一個網頁,但是在Go中,一個視圖也可以是一個頁面片段,如頁頭、頁尾。它還可以是一個 RSS 頁面,或其它類型的“頁面”,Go實現的template包已經很好的實現了View層中的部分功能。
- 控制器 (Controller) 是模型、視圖以及其他任何處理HTTP請求所必須的資源之間的中介,并生成網頁。
下圖顯示了項目設計中框架的數據流是如何貫穿整個系統:

圖13.3 框架的數據流
1. main.go作為應用入口,初始化一些運行博客所需要的基本資源,配置信息,監聽端口。
2. 路由功能檢查HTTP請求,根據URL以及method來確定誰(控制層)來處理請求的轉發資源。
3. 如果緩存文件存在,它將繞過通常的流程執行,被直接發送給瀏覽器。
4. 安全檢測:應用程序控制器調用之前,HTTP請求和任一用戶提交的數據將被過濾。
5. 控制器裝載模型、核心庫、輔助函數,以及任何處理特定請求所需的其它資源,控制器主要負責處理業務邏輯。
6. 輸出視圖層中渲染好的即將發送到Web瀏覽器中的內容。如果開啟緩存,視圖首先被緩存,將用于以后的常規請求。
## 目錄結構
根據上面的應用程序流程設計,博客的目錄結構設計如下:
|——main.go 入口文件
|——conf 配置文件和處理模塊
|——controllers 控制器入口
|——models 數據庫處理模塊
|——utils 輔助函數庫
|——static 靜態文件目錄
|——views 視圖庫
## 框架設計
為了實現博客的快速搭建,打算基于上面的流程設計開發一個最小化的框架,框架包括路由功能、支持REST的控制器、自動化的模板渲染,日志系統、配置管理等。
## 總結
本小節介紹了博客系統從設置GOPATH到目錄建立這樣的基礎信息,也簡單介紹了框架結構采用的MVC模式,博客系統中數據流的執行流程,最后通過這些流程設計了博客系統的目錄結構,至此,我們基本完成一個框架的搭建,接下來的幾個小節我們將會逐個實現。
## links
* [目錄](<preface.md>)
* 上一章: [構建博客系統](<13.0.md>)
* 下一節: [自定義路由器設計](<13.2.md>)
- 目錄
- Go環境配置
- Go安裝
- GOPATH 與工作空間
- Go 命令
- Go開發工具
- 小結
- Go語言基礎
- 你好,Go
- Go基礎
- 流程和函數
- struct
- 面向對象
- interface
- 并發
- 小結
- Web基礎
- web工作方式
- Go搭建一個簡單的web服務
- Go如何使得web工作
- Go的http包詳解
- 小結
- 表單
- 處理表單的輸入
- 驗證表單的輸入
- 預防跨站腳本
- 防止多次遞交表單
- 處理文件上傳
- 小結
- 訪問數據庫
- database/sql接口
- 使用MySQL數據庫
- 使用SQLite數據庫
- 使用PostgreSQL數據庫
- 使用beedb庫進行ORM開發
- NOSQL數據庫操作
- 小結
- session和數據存儲
- session和cookie
- Go如何使用session
- session存儲
- 預防session劫持
- 小結
- 文本文件處理
- XML處理
- JSON處理
- 正則處理
- 模板處理
- 文件操作
- 字符串處理
- 小結
- Web服務
- Socket編程
- WebSocket
- REST
- RPC
- 小結
- 安全與加密
- 預防CSRF攻擊
- 確保輸入過濾
- 避免XSS攻擊
- 避免SQL注入
- 存儲密碼
- 加密和解密數據
- 小結
- 國際化和本地化
- 設置默認地區
- 本地化資源
- 國際化站點
- 小結
- 錯誤處理,調試和測試
- 錯誤處理
- 使用GDB調試
- Go怎么寫測試用例
- 小結
- 部署與維護
- 應用日志
- 網站錯誤處理
- 應用部署
- 備份和恢復
- 小結
- 如何設計一個Web框架
- 項目規劃
- 自定義路由器設計
- controller設計
- 日志和配置設計
- 實現博客的增刪改
- 小結
- 擴展Web框架
- 靜態文件支持
- Session支持
- 表單支持
- 用戶認證
- 多語言支持
- pprof支持
- 小結
- 參考資料