第十三節(jié) 控制器

1控制器

服務(wù)的配置信息放在conf/app.conf文件中
如果需要從環(huán)境變量中獲取配置信息,可以使用如下方法。獲取字符串時(shí),使用一個(gè)變量就可以接收,而獲取其他類型,需要使用兩個(gè)變量接收

httpport,err = beego.AppConfig.Int("httpport")
host = beego.AppConfig.String("host")

app.conf中配置信息如下,當(dāng)runmode為dev時(shí),則讀取dev下的數(shù)據(jù),當(dāng)為test時(shí),則讀取test下的數(shù)據(jù).
還可以在app.conf配置文件中引入其他文件的配置信息,使用include進(jìn)行引入

appname = tea
httpport = 5000
runmode = dev
include "thirth.conf"

[dev]
username = root
pwd = 123456

[test]
username = test
pwd = test

2路由

路由分為固定路由,正則路由和自動(dòng)路由以及自定義路由。固定路由用戶訪問固定的鏈接,根據(jù)請求的類型不同訪問不同方法。
下面主要介紹正則路由和自動(dòng)路由

2.1正則路由

路由中加問號表示該參數(shù)非必須加,訪問/param或者/param/56都能正常訪問。而不加問號則必須加參數(shù)/param就會報(bào)404
還可以自定義匹配類型,例如"/param/:id([0-9]+)",則參數(shù)id0-9至少需出現(xiàn)一次
\d匹配數(shù)字,\w匹配大小寫字母加數(shù)字和下劃線

beego.Router("/param/?:id", &controllers.ParamController{})
beego.Router("/param/:id", &controllers.ParamController{})
beego.Router("/param/?:id:int", &controllers.ParamController{})
beego.Router("/param/:id([0-9]+)", &controllers.ParamController{})

后端通過如下兩種方式之一獲取參數(shù)

id := p.GetString(":id")
id2 := p.Ctx.Input.Param(":id")

2.2自動(dòng)路由

通過控制器/方法名/參數(shù)進(jìn)行訪問。如下則訪問路徑是/param/get訪問get方法,系統(tǒng)會自動(dòng)將ParamController這個(gè)控制器去掉Controller部分用剩下的Param轉(zhuǎn)為小寫進(jìn)行匹配方法

beego.AutoRouter(&controllers.ParamController{})

2.3自定義路由

自定義路由即為給路由自定義映射方法,在普通路由后面增加了一個(gè)映射字符串,如下get的param/56則會被映射到自定義的MyGet方法進(jìn)行處理而不是默認(rèn)的Get

beego.Router("/param/:id", &controllers.ParamController{},"get:MyGet")
# 將get和post都映射到MyGet方法進(jìn)行處理
beego.Router("/param/:id", &controllers.ParamController{},"get,post:MyGet")
# get映射到MyGet1,post映射到MyGet
beego.Router("/param/:id", &controllers.ParamController{},"get:MyGet1;post:MyGet")

3 獲取請求方式

StopRun用于終止該請求執(zhí)行到一定位置后的運(yùn)行,如用戶信息未校驗(yàn)通過,則可以使用StopRun終止運(yùn)行后面的代碼

method := p.Ctx.Request.Method
    # 終止運(yùn)行函數(shù)
    p.StopRun()

4XSRF跨站防御配置

4.1 配置

在conf/app.conf中配置如下代碼

enablexsrf = true
xsrfkey = aeafae123afdafd
xsrfexpire = 3600

在main.go文件的run前面添加

beego.BConfig.WebConfig.EnableXSRF = true
beego.BConfig.WebConfig.XSRFKey = aeafae123afdafd
beego.BConfig.WebConfig.XSRFExpire = 3600

4.2控制器中使用

func (t *TestXSRFController) Get() {
    t.Data["xsrfdata"] = template.HTML(t.XSRFFormHTML())
    t.TplName = "test_xsrf.html"
}

4.3前端form表單中使用

在form表單中使用后端提交過來的xsrfdata,然后提交就可

<form action="/test_xsrf", method="post">
    {{.xsrfdata}}
    <input type="submit" value="提交">
</form>

4.4關(guān)閉某個(gè)控制器下的xsrf驗(yàn)證

如下就能關(guān)閉TestXSRFController下控制器所有方法的xsrf驗(yàn)證

func (t *TestXSRFController) Prepare() {
    t.EnableXSRF = false
}

5文件上傳

map[string]interface{}定義的map類型可以起到類似結(jié)構(gòu)體的作用,value可以不只是局限于一種。如map[string]interface{}{"code": 200, "msg":"上傳成功"}value既有整型又有字符串類型。

func (u *UploadController) Post() {
    f,h,err := u.GetFile("upload_file")
    defer func(){
        f.Close()
    }()
    if err != nil {
        return
    }
    filename = h.Filename
    fmt.Println(filename)
    # 獲取時(shí)間戳
    time_unix_int = time.Now().Unix()
    # 將數(shù)字轉(zhuǎn)換為字符串,傳入數(shù)字和進(jìn)制
    time_unix_str = strconv.FormatInt(time_unix_int, 10)
    # 文件保存?zhèn)魅胛募淖侄魏捅4娴穆窂?    u.SaveToFile("upload_file", "static/upload" + (time_unix_str+"-"+filename))
    u.Data["json"] = map[string]interface{}{"code": 200, "msg":"上傳成功"}
    u.ServeJSON()
}

5.1 設(shè)置文件上傳大小限制

在main.go文件的run前面添加
單位是byte,1<<22即2的22次方byte大小

beego.BConfig.MaxMemory = 1<<22
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容