beego請求數(shù)據(jù)處理

2023-11-20 18:05 更新

獲取參數(shù)

我們經(jīng)常需要獲取用戶傳遞的數(shù)據(jù),包括 Get、POST 等方式的請求,beego 里面會自動解析這些數(shù)據(jù),你可以通過如下方式獲取數(shù)據(jù):

  • GetString(key string) string
  • GetStrings(key string) []string
  • GetInt(key string) (int64, error)
  • GetBool(key string) (bool, error)
  • GetFloat(key string) (float64, error)

使用例子如下:

func (this *MainController) Post() {
    jsoninfo := this.GetString("jsoninfo")
    if jsoninfo == "" {
        this.Ctx.WriteString("jsoninfo is empty")
        return
    }
}

如果你需要的數(shù)據(jù)可能是其他類型的,例如是 int 類型而不是 int64,那么你需要這樣處理:

func (this *MainController) Post() {
    id := this.Input().Get("id")
    intid, err := strconv.Atoi(id)
}

更多其他的 request 的信息,用戶可以通過 this.Ctx.Request 獲取信息,關于該對象的屬性和方法參考手冊 Request。

直接解析到 struct

如果要把表單里的內(nèi)容賦值到一個 struct 里,除了用上面的方法一個一個獲取再賦值外,beego 提供了通過另外一個更便捷的方式,就是通過 struct 的字段名或 tag 與表單字段對應直接解析到 struct。

定義 struct:

type user struct {
    Id    int         `form:"-"`
    Name  interface{} `form:"username"`
    Age   int         `form:"age"`
    Email string
}

表單:

<form id="user">
    名字:<input name="username" type="text" />
    年齡:<input name="age" type="text" />
    郵箱:<input name="Email" type="text" />
    <input type="submit" value="提交" />
</form>

Controller 里解析:

func (this *MainController) Post() {
    u := user{}
    if err := this.ParseForm(&u); err != nil {
        //handle error
    }
}

注意:

  • StructTag form 的定義和renderform方法共用一個標簽
  • 定義 struct 時,字段名后如果有 form 這個 tag,則會以把 form 表單里的 name 和 tag 的名稱一樣的字段賦值給這個字段,否則就會把 form 表單里與字段名一樣的表單內(nèi)容賦值給這個字段。如上面例子中,會把表單中的 username 和 age 分別賦值給 user 里的 Name 和 Age 字段,而 Email 里的內(nèi)容則會賦給 Email 這個字段。
  • 調(diào)用 Controller ParseForm 這個方法的時候,傳入的參數(shù)必須為一個 struct 的指針,否則對 struct 的賦值不會成功并返回 xx must be a struct pointer 的錯誤。
  • 如果要忽略一個字段,有兩種辦法,一是:字段名小寫開頭,二是:form 標簽的值設置為 -

獲取 Request Body 里的內(nèi)容

在 API 的開發(fā)中,我們經(jīng)常會用到 JSON 或 XML 來作為數(shù)據(jù)交互的格式,如何在 beego 中獲取 Request Body 里的 JSON 或 XML 的數(shù)據(jù)呢?

  1. 在配置文件里設置 copyrequestbody = true
  2. 在 Controller 中
func (this *ObjectController) Post() {
    var ob models.Object
    var err error
    if err = json.Unmarshal(this.Ctx.Input.RequestBody, &ob); err == nil {
        objectid := models.AddOne(ob)
        this.Data["json"] = "{\"ObjectId\":\"" + objectid + "\"}"
    } else {
        this.Data["json"] = err.Error()
    }
    this.ServeJSON()
}

文件上傳

在 beego 中你可以很容易的處理文件上傳,就是別忘記在你的 form 表單中增加這個屬性 enctype="multipart/form-data",否則你的瀏覽器不會傳輸你的上傳文件。

文件上傳之后一般是放在系統(tǒng)的內(nèi)存里面,如果文件的 size 大于設置的緩存內(nèi)存大小,那么就放在臨時文件中,默認的緩存內(nèi)存是 64M,你可以通過如下來調(diào)整這個緩存內(nèi)存大小:

beego.MaxMemory = 1<<22

或者在配置文件中通過如下設置:

maxmemory = 1<<22

Beego 提供了兩個很方便的方法來處理文件上傳:

  • GetFile(key string) (multipart.File, *multipart.FileHeader, error)該方法主要用于用戶讀取表單中的文件名 the_file,然后返回相應的信息,用戶根據(jù)這些變量來處理文件上傳:過濾、保存文件等。
  • SaveToFile(fromfile, tofile string) error該方法是在 GetFile 的基礎上實現(xiàn)了快速保存的功能 fromfile 是提交時候的 html 表單中的 name
<form enctype="multipart/form-data" method="post">
    <input type="file" name="uploadname" />
    <input type="submit">
</form>

保存的代碼例子如下:

func (c *FormController) Post() {
    f, h, err := c.GetFile("uploadname")
    if err != nil {
        log.Fatal("getfile err ", err)
    }
    defer f.Close()
    c.SaveToFile("uploadname", "static/upload/" + h.Filename) // 保存位置在 static/upload, 沒有文件夾要先創(chuàng)建

}

數(shù)據(jù)綁定

支持從用戶請求中直接數(shù)據(jù) bind 到指定的對象,例如請求地址如下

?id=123&isok=true&ft=1.2&ol[0]=1&ol[1]=2&ul[]=str&ul[]=array&user.Name=astaxie
var id int
this.Ctx.Input.Bind(&id, "id")  //id ==123

var isok bool
this.Ctx.Input.Bind(&isok, "isok")  //isok ==true

var ft float64
this.Ctx.Input.Bind(&ft, "ft")  //ft ==1.2

ol := make([]int, 0, 2)
this.Ctx.Input.Bind(&ol, "ol")  //ol ==[1 2]

ul := make([]string, 0, 2)
this.Ctx.Input.Bind(&ul, "ul")  //ul ==[str array]

user struct{Name}
this.Ctx.Input.Bind(&user, "user")  //user =={Name:"astaxie"}
以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號