3. beego项目逻辑
3.1. 路由设置
3.1.1. beego.Router
入口文件main.go
package main import ( _ "quickstart/routers" "github.com/astaxie/beego" ) func main() { beego.Run() }
go中导入包中init函数的执行逻辑
_ "quickstart/routers"
,包只引入执行了里面的init函数
package routers import ( "quickstart/controllers" "github.com/astaxie/beego" ) func init() { beego.Router("/", &controllers.MainController{}) }
路由包里执行了路由注册beego.Router
, 这个函数的功能是映射URL到controller,第一个参数是URL(用户请求的地址),这里是 /
,也就是访问的不带任何参数的URL,第二个参数是对应的 Controller,就是把请求分发到那个控制器来执行相应的逻辑。
3.1.2. beego.Run
- 解析配置文件
beego 会自动解析在 conf 目录下面的配置文件 app.conf
,通过修改配置文件相关的属性,我们可以定义:开启的端口,是否开启 session,应用名称等信息。
- 执行用户的hookfunc
beego会执行用户注册的hookfunc,默认的已经存在了注册mime,用户可以通过函数AddAPPStartHook注册自己的启动函数。
- 是否开启 session
会根据上面配置文件的分析之后判断是否开启 session,如果开启的话就初始化全局的 session。
- 是否编译模板
beego 会在启动的时候根据配置把 views 目录下的所有模板进行预编译,然后存在 map 里面,这样可以有效的提高模板运行的效率,无需进行多次编译。
- 是否开启文档功能
根据EnableDocs配置判断是否开启内置的文档路由功能
- 是否启动管理模块
beego 目前做了一个很酷的模块,应用内监控模块,会在 8088 端口做一个内部监听,我们可以通过这个端口查询到 QPS、CPU、内存、GC、goroutine、thread 等统计信息。
- 监听服务端口
这是最后一步也就是我们看到的访问 8080 看到的网页端口,内部其实调用了 ListenAndServe,充分利用了 goroutine 的优势,一旦 run 起来之后,我们的服务就监听在两个端口了,一个服务端口 8080 作为对外服务,另一个 8088 端口实行对内监控。
3.2. controller 逻辑
package controllers import ( "github.com/astaxie/beego" ) type MainController struct { beego.Controller } func (this *MainController) Get() { this.Data["Website"] = "beego.me" this.Data["Email"] = "[email protected]" this.TplName = "index.tpl" }
1、声明了一个控制器 MainController,这个控制器里面内嵌了 beego.Controller,即Go 的嵌入方式,也就是 MainController 自动拥有了所有 beego.Controller 的方法。而beego.Controller 拥有很多方法,其中包括 Init、Prepare、Post、Get、Delete、Head等方法。可以通过重写的方式来实现这些方法,以上例子重写了 Get 方法。
2、beego 是一个 RESTful 的框架,请求默认是执行对应 req.Method
的方法。例如浏览器的是 GET
请求,那么默认就会执行 MainController
下的 Get
方法。(用户可以改变这个行为,通过注册自定义的函数名)。
3、获取数据,赋值到 this.Data
中,这是一个用来存储输出数据的 map。
4、渲染模板,this.TplName 就是需要渲染的模板,这里指定了 index.tpl,如果用户不设置该参数,那么默认会去到模板目录的 Controller/<方法名>.tpl 查找,例如上面的方法会去 maincontroller/get.tpl(文件、文件夹必须小写)。用户设置了模板之后系统会自动的调用 Render 函数(这个函数是在 beego.Controller 中实现的),所以无需用户自己来调用渲染。
5、如果不使用模板可以直接输出:
func (this *MainController) Get() { this.Ctx.WriteString("hello") }
3.3. model逻辑
model一般用来处理数据库操作,如果逻辑中存在可以复用的部分就可以抽象成一个model。
package models import ( "loggo/utils" "path/filepath" "strconv" "strings" ) var ( NotPV []string = []string{"css", "js", "class", "gif", "jpg", "jpeg", "png", "bmp", "ico", "rss", "xml", "swf"} ) const big = 0xFFFFFF func LogPV(urls string) bool { ext := filepath.Ext(urls) if ext == "" { return true } for _, v := range NotPV { if v == strings.ToLower(ext) { return false } } return true }
3.4. view逻辑
Controller中的this.TplName = "index.tpl",设置显示的模板文件,默认支持 tpl 和 html 的后缀名,如果想设置其他后缀你可以调用 beego.AddTemplateExt 接口设置。beego 采用了 Go 语言默认的模板引擎,和 Go 的模板语法一样。
1 2 3 4 5Beego 6 "Content-Type" content="text/html; charset=utf-8"> 7 8 9 10class="hero-unit" style="background-color:#A9F16C"> 11 26 27class="container"> 1225class="row"> 1324class="hero-text"> 1423Welcome to Beego!
15class="description"> 16 Beego is a simple & powerful Go web framework which is inspired by tornado and sinatra. 17
22
18 Official website: ""http://%7B%7B.website%7D%7D/" "="" style="color: rgb(53, 114, 176); text-decoration: none; border-radius: 0px !important; border: 0px !important; bottom: auto !important; float: none !important; height: auto !important; left: auto !important; margin: 0px !important; outline: 0px !important; overflow: visible !important; padding: 0px !important; position: static !important; right: auto !important; top: auto !important; vertical-align: baseline !important; width: auto !important; box-sizing: content-box !important; min-height: auto !important; background: none !important;">http://{{.Website}}">{{.Website}} 19
20 Contact me: {{.Email}} 21
Controller 里面把数据赋值给了 data(map 类型),然后在模板中就直接通过 key 访问 .Website
和 .Email
。这样就做到了数据的输出。
3.5. 静态文件
网页往往包含了很多的静态文件,包括图片、JS、CSS 等
├── static
│ ├── css
│ ├── img
│ └── js
beego 默认注册了 static 目录为静态处理的目录,注册样式:URL 前缀和映射的目录(在/main.go文件中beego.Run()之前加入):
StaticDir["/static"] = "static"
用户可以设置多个静态文件处理目录,例如你有多个文件下载目录 download1、download2,你可以这样映射(在/main.go文件中beego.Run()之前加入):
beego.SetStaticPath("/down1", "download1") beego.SetStaticPath("/down2", "download2")
这样用户访问 URL http://localhost:8080/down1/123.txt
则会请求 download1 目录下的 123.txt 文件。