golang中web框架-beego参数配置和路由控制

1,059 阅读3分钟

小知识,大挑战!本文正在参与“程序员必备小知识”创作活动。

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了。

image-20210727142256792

那么浏览器要访问9527端口才可以:

image-20210727142157366

读取不同模式下配置参数的方法是“模式::配置参数名”,比如:

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 的执行过程是如下图所示的方式:

image-20210727142122010

这里我们就看到了我们引入了一个包 _ "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这个函数根据自己需求来更改路由规则了。