Iris_MVC

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特性

iris框架封装的mvc包,支持所有的http方法。比如,如果想要提供GET,那么控制器应该有一个名为Get()的函数,开发者可以定义多个方法函数在同一个Controller中提供。这里的Get、Post方法是指的直接和八种请求类型同名的方法,mvc模块会自动执行到Get()、Post()等八种对应的方法。如下所示:

 //自定义的控制器
 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{}
}

 

posted @ 2020-02-05 09:12  1769987233  阅读(744)  评论(0编辑  收藏  举报