2. MVC包使用
在Iris框架中,封裝了mvc包作為對mvc架構的支持,方便開發者遵循mvc的開發原則進行開發。 iris框架支持請求數據、模型、持久數據分層處理,並支持各層級模塊代碼綁定執行。 MVC即:model、view、controller三個部分,分別代表數據層、視圖層、控制層。控制器層負責完成頁面邏輯、實體層負責完成數據准備與數據操作、視圖層負責展現UI效果。 在iris框架中,用一張圖表示前端請求、服務端處理請求、服務端返回數據到前端的請求過程圖,描述如下:

2.1 mvc.Application
iris框架中的mvc包中提供了Application結構體定義。開發者可以通過注冊自定義的controller來使用對應提供的API,其中包含路由組router.Party,以此用來注冊layout、middleware以及相應的handlers等。
2.2 iris.mvc特性
//自定義的控制器
type CustomController struct{}
//注冊自定義控制器處理請求
mvc.New(app).Handle(new(CustomController))
//自動處理基礎的Http請求
//Url: http://localhost:8000
//Type:GET請求
func (cc *CustomController) Get() mvc.Result{
//todo
return mvc.Response{
ContentType:"text/html",
}
}
/**
* Url:http://localhost:8000
* Type:POST
**/
func (cc *CustomController) Post() mvc.Result{
//todo
return mvc.Response{}
}
2.3 根據請求類型和請求URL自動匹配處理方法
在iris框架中的mvc設計包中,設定了自定義的控制器以后,支持根據請求類型和對應的URL自動匹配對應的處理方法。具體案例如下:
/**
* url:http://localhost:8000/info
* type:GET請求
**/
func (cc *CustomController) GetInfo() mvc.Result{
//todo
}
/**
* url:http://localhost:8000/login
* type:POST
**/
func (cc *CustomController) PostLogin() mvc.Result{
//todo
}
如上案例,當我們發起請求時,iris框架就能夠自動匹配對應的控制器的處理方法。除了上述get和post兩個方法之外,http請求的八種類型中的其他請求類型,也支持自動匹配。
2.4 BeforeActivation方法
在通過Configure和Handle進行了自定義Controller綁定以后,就可以使用自己自定義的Controller來進行自定義處理處理請求方法。開發者可以在BeforeActivation方法中來處理請求定義。如下所示,我們給出案例說明:
func (m *CustomController) BeforeActivation(a mvc.BeforeActivation){
a.Handle("GET","/users/info","QueryInfo")
}
//對應處理請求的方法
func (m *CustomController) QueryInfo() mvc.Result{
//todo
}
2.5 使用mvc.Configure配置路由組和控制器
除了使用mvc.new(app)來構建mvc.Application結構體對象和Handle方法來配置處理請求的控制器外,iris框架還支持使用mvc.Configure來配置路由組和控制器的設置。具體使用方法如下:
mvc.Configure(app.Party("/user"), func(mvc *mvc.Application) {
mvc.Handle(new(UserController))
})
本節課中我們學習了mvc包中控制器極其處理方法的基本用法,在實戰項目中,我們會在本節課學習內容的基礎上,繼續深入學習更詳細的操作。
2.6 代碼
package main
import (
"github.com/kataras/iris"
"github.com/kataras/iris/mvc"
)
func main() {
app := iris.New() //返回一個application對象
//設置自定義控制器
//type UserController struct {
//}
//mvc.New(app)返回一個MVC的application對象
//application的Handle方法,用來注冊一個自定義的控制器,把控制器設置給了app對象
mvc.New(app).Handle(new(UserController))
//new來聲明一個控制器,返回一致指針,make是初始化切片、map、channel的,返回本身,因為本身就是指針了
//路由組的mvc處理
mvc.Configure(app.Party("/user"), func(context *mvc.Application) {
//context是*mvc.Application類型
//和這個 mvc.New(app) 一樣
context.Handle(new(UserController))
})
app.Run(iris.Addr(":8009"))
}
//第一種智能處理請求
//url:http://localhost:8009
//type:Get
func (uc *UserController) Get() string { //給控制器聲明一個Get方法
iris.New().Logger().Info(" Get 請求 ")
return "hell world"
}
func (uc *UserController) Post() { //給控制器聲明一個Post方法
iris.New().Logger().Info(" post 請求 ")
}
func (uc *UserController) Put() { //給控制器聲明一個Put方法
iris.New().Logger().Info(" put 請求 ")
}
//第二種智能處理請求
//url:http://localhost:8009/info
//type:Get
func (uc *UserController) GetInfo() mvc.Result { //Info和路徑一致,首字母大寫
iris.New().Logger().Info(" get 請求, 請求路徑為info ")
return mvc.Response{
//返回到前端就是json格式
Object: map[string]interface{}{
"code": 1,
"msessage": "請求成功",
},
}
}
type UserController struct {
}
//第三種智能處理請求
//BeforeActivation自動執行的方法
func (uc *UserController) BeforeActivation(a mvc.BeforeActivation) {
a.Handle("GET", "/query", "UserInfo") //指定哪一個方法來處理這個請求
}
func (uc *UserController) UserInfo() mvc.Result {
//todo
iris.New().Logger().Info(" user info query ")
return mvc.Response{}
}
