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{} }