golang中web框架

您所在的位置:网站首页 9527端口连接失败 golang中web框架

golang中web框架

2023-10-04 08:17| 来源: 网络整理| 查看: 265

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

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这个函数根据自己需求来更改路由规则了。



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3