Write the Code. Change the World.

11月 18

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

相关

http://lsdcloud.com/go/web/iris-go/mvc.html#_4-2-routers-go

https://studyiris.com/article?id=56&uid=74

发表评论

电子邮件地址不会被公开。 必填项已用*标注