iris web框架支持请求数据、模型、持久数据和以最快的速度执行的绑定。
mvc 包使用
在 iris 框架中,封装了 mvc 包作为对 mvc 架构的支持,方便开发者遵循 mvc 的开发原则进行开发。 iris框架支持请求数据、模型、持久数据分层处理,并支持各层级模块代码绑定执行。 MVC即:model、view、controller 三个部分,分别代表数据层、视图层、控制层。控制器层负责完成页面逻辑、实体层负责完成数据准备与数据操作、视图层负责展现 UI 效果。 在 iris 框架中,用一张图表示前端请求、服务端处理请求、服务端返回数据到前端的请求过程图,描述如下:
mvc.Application
iris 框架中的 mvc 包中提供了 Application 结构体定义。开发者可以通过注册自定义的controller 来使用对应提供的 API,其中包含路由组 router.Party, 以此用来注册 layout、middleware 以及相应的 handlers 等。
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{}
}
根据请求类型和请求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 请求的八种类型中的其他请求类型,也支持自动匹配。
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
}
使用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包中控制器极其处理方法的基本用法,在实战项目中,我们会在本节课学习内容的基础上,继续深入学习更详细的操作。
代码
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{}
}
文章来源
https://www.cnblogs.com/yzg-14/p/12262501.html