diff --git a/zh/13.3.md b/zh/13.3.md index 8a8e7aed..0ddb06c4 100644 --- a/zh/13.3.md +++ b/zh/13.3.md @@ -8,6 +8,7 @@ MVC设计模式是目前Web应用开发中最常见的架构模式,通过分 ## beego的REST设计 前面小节介绍了路由实现了注册struct的功能,而struct中实现了REST方式,因此我们需要设计一个用于逻辑处理controller的基类,这里主要设计了两个类型,一个struct、一个interface +```Go type Controller struct { Ct *Context @@ -32,8 +33,9 @@ MVC设计模式是目前Web应用开发中最常见的架构模式,通过分 Finish() //执行完成之后的处理 Render() error //执行完method对应的方法之后渲染页面 } - +``` 那么前面介绍的路由add函数的时候是定义了ControllerInterface类型,因此,只要我们实现这个接口就可以,所以我们的基类Controller实现如下的方法: +```Go func (c *Controller) Init(ct *Context, cn string) { c.Data = make(map[interface{}]interface{}) @@ -113,17 +115,19 @@ MVC设计模式是目前Web应用开发中最常见的架构模式,通过分 func (c *Controller) Redirect(url string, code int) { c.Ct.Redirect(code, url) } - +``` 上面的controller基类已经实现了接口定义的函数,通过路由根据url执行相应的controller的原则,会依次执行如下: +```Go Init() 初始化 Prepare() 执行之前的初始化,每个继承的子类可以来实现该函数 method() 根据不同的method执行不同的函数:GET、POST、PUT、HEAD等,子类来实现这些函数,如果没实现,那么默认都是403 Render() 可选,根据全局变量AutoRender来判断是否执行 Finish() 执行完之后执行的操作,每个继承的子类可以来实现该函数 - +``` ## 应用指南 上面beego框架中完成了controller基类的设计,那么我们在我们的应用中可以这样来设计我们的方法: +```Go package controllers @@ -140,12 +144,13 @@ MVC设计模式是目前Web应用开发中最常见的架构模式,通过分 this.Data["Email"] = "astaxie@gmail.com" this.TplNames = "index.tpl" } - +``` 上面的方式我们实现了子类MainController,实现了Get方法,那么如果用户通过其他的方式(POST/HEAD等)来访问该资源都将返回403,而如果是Get来访问,因为我们设置了AutoRender=true,那么在执行完Get方法之后会自动执行Render函数,就会显示如下界面: ![](images/13.4.beego.png?raw=true) index.tpl的代码如下所示,我们可以看到数据的设置和显示都是相当的简单方便: +```html @@ -156,7 +161,8 @@ index.tpl的代码如下所示,我们可以看到数据的设置和显示都

Hello, world!{{.Username}},{{.Email}}

- + +``` ## links * [目录]()