小知识,大挑战!本文正在参与“程序员必备小知识”创作活动。
beego参数配置和路由控制
beego 目前支持 INI、XML、JSON、YAML 格式的配置文件解析,但是默认采用了 INI 格式解析,用户可以通过简单的配置就可以获得很大的灵活性。
参数配置
默认的参数配置
beego默认会解析当前应用下的conf/app.conf文件,通过这个文件你可以初始化很多 beego 的默认参数:
appname = beegoDemo
httpport = 8080
runmode = dev
你也可以在配置文件中配置应用需要用的一些配置信息,例如下面所示的数据库信息:
mysqluser = "root"
mysqlpass = "rootpass"
mysqlurls = "127.0.0.1"
mysqldb = "beego"
那么你就可以通过如下的方式获取设置的配置信息:
beego.AppConfig.String("mysqluser")
beego.AppConfig.String("mysqlpass")
beego.AppConfig.String("mysqlurls")
beego.AppConfig.String("mysqldb")
不同级别的配置
根据不同的运行环境,不同的配置,如开发环境,正式生产线上,配置不同。
在配置文件里面支持 section,可以有不同的 Runmode 的配置,默认优先读取 runmode 下的配置信息,例如下面的配置文件,我们可以把配置分成三份,比如dev,prod,test,在什么环境那么runmode就配置成什么,其他配置文件同理。解析的时候优先解析 runmode 下的配置,然后解析默认的配置。如下所示:
appname = beegoDemo
runmode = dev
[dev]
httpport = 9527
[test]
httpport = 5566
[prod]
httpport = 8082
runmode 配置为dev那么监听的端口就是9527了。
那么浏览器要访问9527端口才可以:
读取不同模式下配置参数的方法是“模式::配置参数名”,比如:
beego.AppConfig.String("dev::mysqluser")
对于自定义的参数,需使用 beego.GetConfig(tpy, key string, defaultVal interface{}) 来获取指定 runmode 下的配置(需 1.4.0 以上版本),typ 为参数类型,key 为参数名, defaultVal 为默认值。
多个配置文件
INI 格式配置支持 include 方式,引用多个配置文件,例如下面的两个配置文件效果同上:
beegoDemo.conf
appname = beegoDemo
httpaddr = "127.0.0.1"
httpport = 9527
include "beegoDemo2.conff"
beegoDemo2.conf
unmode ="dev"
autorender = false
recoverpanic = false
viewspath = "myview"
[dev]
httpport = 8080
[prod]
httpport = 8081
[test]
httpport = 8082
扩展
AppConfig 的方法如下:
Set(key, val string) error
String(key string) string
Strings(key string) []string
Int(key string) (int, error)
Int64(key string) (int64, error)
Bool(key string) (bool, error)
Float(key string) (float64, error)
DefaultString(key string, defaultVal string) string
DefaultStrings(key string, defaultVal []string)
DefaultInt(key string, defaultVal int) int
DefaultInt64(key string, defaultVal int64) int64
DefaultBool(key string, defaultVal bool) bool
DefaultFloat(key string, defaultVal float64) float64
DIY(key string) (interface{}, error)
GetSection(section string) (map[string]string, error)
SaveConfigFile(filename string) error
路由控制
web框架中,路由是重要的一环,对于beego的路由配置如何?
默认路由
让我们从入口文件main.go先分析起来吧:
package main
import (
_ "beegoDemo/routers"
"github.com/astaxie/beego"
)
func main() {
beego.Run()
}
我们看到 main 函数是入口函数,但是我们知道 Go 的执行过程是如下图所示的方式:
这里我们就看到了我们引入了一个包 _ "beegoDemo/routers",这个包只引入执行了里面的 init 函数,那么让我们看看这个里面做了什么事情:
package routers
import (
"beegoDemo/controllers"
"github.com/astaxie/beego"
)
func init() {
beego.Router("/", &controllers.MainController{})
}
路由包里面我们看到执行了路由注册 beego.Router, 这个函数的功能是映射 URL 到 controller,第一个参数是 URL (用户请求的地址),这里我们注册的是 /,也就是我们访问的不带任何参数的 URL,第二个参数是对应的 Controller,也就是我们即将把请求分发到那个控制器来执行相应的逻辑,我们可以执行类似的方式注册如下路由:
beego.Router("/user", &controllers.UserController{})
看一下这个Router 的源码:
func Router(rootpath string, c ControllerInterface, mappingMethods ...string) *App { BeeApp.Handlers.Add(rootpath, c, mappingMethods...) return BeeApp}
我们beego的路由控制在router/router.go这个代码文件控制的,我们在init这个函数根据自己需求来更改路由规则了。