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