mirror of
https://gitee.com/johng/gf.git
synced 2024-12-02 12:17:53 +08:00
204 lines
5.9 KiB
Go
204 lines
5.9 KiB
Go
// Copyright GoFrame Author(https://goframe.org). All Rights Reserved.
|
|
//
|
|
// This Source Code Form is subject to the terms of the MIT License.
|
|
// If a copy of the MIT was not distributed with this file,
|
|
// You can obtain one at https://github.com/gogf/gf.
|
|
|
|
package ghttp
|
|
|
|
import (
|
|
"github.com/gogf/gf/v2/container/gvar"
|
|
"github.com/gogf/gf/v2/internal/empty"
|
|
"github.com/gogf/gf/v2/os/gstructs"
|
|
"github.com/gogf/gf/v2/util/gconv"
|
|
"github.com/gogf/gf/v2/util/gutil"
|
|
)
|
|
|
|
// GetRequest retrieves and returns the parameter named `key` passed from client and
|
|
// custom params as interface{}, no matter what HTTP method the client is using. The
|
|
// parameter `def` specifies the default value if the `key` does not exist.
|
|
//
|
|
// GetRequest is one of the most commonly used functions for retrieving parameters.
|
|
//
|
|
// Note that if there are multiple parameters with the same name, the parameters are
|
|
// retrieved and overwrote in order of priority: router < query < body < form < custom.
|
|
func (r *Request) GetRequest(key string, def ...interface{}) *gvar.Var {
|
|
value := r.GetParam(key)
|
|
if value == nil {
|
|
value = r.GetForm(key)
|
|
}
|
|
if value == nil {
|
|
r.parseBody()
|
|
if len(r.bodyMap) > 0 {
|
|
if v := r.bodyMap[key]; v != nil {
|
|
value = gvar.New(v)
|
|
}
|
|
}
|
|
}
|
|
if value == nil {
|
|
value = r.GetQuery(key)
|
|
}
|
|
if value == nil {
|
|
value = r.GetRouter(key)
|
|
}
|
|
if value != nil {
|
|
return value
|
|
}
|
|
if len(def) > 0 {
|
|
return gvar.New(def[0])
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// GetRequestMap retrieves and returns all parameters passed from client and custom params
|
|
// as map, no matter what HTTP method the client is using. The parameter `kvMap` specifies
|
|
// the keys retrieving from client parameters, the associated values are the default values
|
|
// if the client does not pass the according keys.
|
|
//
|
|
// GetRequestMap is one of the most commonly used functions for retrieving parameters.
|
|
//
|
|
// Note that if there are multiple parameters with the same name, the parameters are retrieved
|
|
// and overwrote in order of priority: router < query < body < form < custom.
|
|
func (r *Request) GetRequestMap(kvMap ...map[string]interface{}) map[string]interface{} {
|
|
r.parseQuery()
|
|
r.parseForm()
|
|
r.parseBody()
|
|
var (
|
|
ok, filter bool
|
|
)
|
|
var length int
|
|
if len(kvMap) > 0 && kvMap[0] != nil {
|
|
length = len(kvMap[0])
|
|
filter = true
|
|
} else {
|
|
length = len(r.routerMap) + len(r.queryMap) + len(r.formMap) + len(r.bodyMap) + len(r.paramsMap)
|
|
}
|
|
m := make(map[string]interface{}, length)
|
|
for k, v := range r.routerMap {
|
|
if filter {
|
|
if _, ok = kvMap[0][k]; !ok {
|
|
continue
|
|
}
|
|
}
|
|
m[k] = v
|
|
}
|
|
for k, v := range r.queryMap {
|
|
if filter {
|
|
if _, ok = kvMap[0][k]; !ok {
|
|
continue
|
|
}
|
|
}
|
|
m[k] = v
|
|
}
|
|
for k, v := range r.formMap {
|
|
if filter {
|
|
if _, ok = kvMap[0][k]; !ok {
|
|
continue
|
|
}
|
|
}
|
|
m[k] = v
|
|
}
|
|
for k, v := range r.bodyMap {
|
|
if filter {
|
|
if _, ok = kvMap[0][k]; !ok {
|
|
continue
|
|
}
|
|
}
|
|
m[k] = v
|
|
}
|
|
for k, v := range r.paramsMap {
|
|
if filter {
|
|
if _, ok = kvMap[0][k]; !ok {
|
|
continue
|
|
}
|
|
}
|
|
m[k] = v
|
|
}
|
|
// Check none exist parameters and assign it with default value.
|
|
if filter {
|
|
for k, v := range kvMap[0] {
|
|
if _, ok = m[k]; !ok {
|
|
m[k] = v
|
|
}
|
|
}
|
|
}
|
|
return m
|
|
}
|
|
|
|
// GetRequestMapStrStr retrieves and returns all parameters passed from client and custom
|
|
// params as map[string]string, no matter what HTTP method the client is using. The parameter
|
|
// `kvMap` specifies the keys retrieving from client parameters, the associated values are the
|
|
// default values if the client does not pass.
|
|
func (r *Request) GetRequestMapStrStr(kvMap ...map[string]interface{}) map[string]string {
|
|
requestMap := r.GetRequestMap(kvMap...)
|
|
if len(requestMap) > 0 {
|
|
m := make(map[string]string, len(requestMap))
|
|
for k, v := range requestMap {
|
|
m[k] = gconv.String(v)
|
|
}
|
|
return m
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// GetRequestMapStrVar retrieves and returns all parameters passed from client and custom
|
|
// params as map[string]*gvar.Var, no matter what HTTP method the client is using. The parameter
|
|
// `kvMap` specifies the keys retrieving from client parameters, the associated values are the
|
|
// default values if the client does not pass.
|
|
func (r *Request) GetRequestMapStrVar(kvMap ...map[string]interface{}) map[string]*gvar.Var {
|
|
requestMap := r.GetRequestMap(kvMap...)
|
|
if len(requestMap) > 0 {
|
|
m := make(map[string]*gvar.Var, len(requestMap))
|
|
for k, v := range requestMap {
|
|
m[k] = gvar.New(v)
|
|
}
|
|
return m
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// GetRequestStruct retrieves all parameters passed from client and custom params no matter
|
|
// what HTTP method the client is using, and converts them to given struct object. Note that
|
|
// the parameter `pointer` is a pointer to the struct object.
|
|
// The optional parameter `mapping` is used to specify the key to attribute mapping.
|
|
func (r *Request) GetRequestStruct(pointer interface{}, mapping ...map[string]string) error {
|
|
_, err := r.doGetRequestStruct(pointer, mapping...)
|
|
return err
|
|
}
|
|
|
|
func (r *Request) doGetRequestStruct(pointer interface{}, mapping ...map[string]string) (data map[string]interface{}, err error) {
|
|
data = r.GetRequestMap()
|
|
if data == nil {
|
|
data = map[string]interface{}{}
|
|
}
|
|
if err = r.mergeDefaultStructValue(data, pointer); err != nil {
|
|
return data, nil
|
|
}
|
|
return data, gconv.Struct(data, pointer, mapping...)
|
|
}
|
|
|
|
// mergeDefaultStructValue merges the request parameters with default values from struct tag definition.
|
|
func (r *Request) mergeDefaultStructValue(data map[string]interface{}, pointer interface{}) error {
|
|
tagFields, err := gstructs.TagFields(pointer, defaultValueTags)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if len(tagFields) > 0 {
|
|
var (
|
|
foundKey string
|
|
foundValue interface{}
|
|
)
|
|
for _, field := range tagFields {
|
|
foundKey, foundValue = gutil.MapPossibleItemByKey(data, field.Name())
|
|
if foundKey == "" {
|
|
data[field.Name()] = field.TagValue
|
|
} else {
|
|
if empty.IsEmpty(foundValue) {
|
|
data[foundKey] = field.TagValue
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return nil
|
|
}
|