完善数据类型转换
This commit is contained in:
@@ -5,6 +5,7 @@ import (
|
||||
"fmt"
|
||||
"reflect"
|
||||
"strings"
|
||||
"time"
|
||||
)
|
||||
|
||||
// 工具函数
|
||||
@@ -39,9 +40,21 @@ func hasUnmarshalText(t reflect.Type) bool {
|
||||
|
||||
// 设置json.Unmarshaler接口的值
|
||||
func setUnmarshalJSONValue(field reflect.Value, value interface{}) error {
|
||||
jsonBytes, err := json.Marshal(value)
|
||||
if err != nil {
|
||||
return err
|
||||
var jsonBytes []byte
|
||||
if str, ok := value.(string); ok {
|
||||
// 尝试直接将字符串作为JSON解析;如果是合法JSON则直接使用
|
||||
if json.Valid([]byte(str)) {
|
||||
jsonBytes = []byte(str)
|
||||
} else {
|
||||
// 不是合法JSON,作为JSON字符串值处理(加引号)
|
||||
jsonBytes = []byte(`"` + str + `"`)
|
||||
}
|
||||
} else {
|
||||
var err error
|
||||
jsonBytes, err = json.Marshal(value)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
|
||||
var fieldAddr reflect.Value
|
||||
@@ -91,6 +104,16 @@ func setBasicStructValue(field reflect.Value, value string) error {
|
||||
if hasUnmarshalText(field.Type()) {
|
||||
return setUnmarshalTextValue(field, value)
|
||||
}
|
||||
|
||||
if field.Type().String() == "time.Duration" {
|
||||
d, err := time.ParseDuration(value)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
field.SetInt(int64(d))
|
||||
return nil
|
||||
}
|
||||
|
||||
return json.Unmarshal([]byte(value), field.Addr().Interface())
|
||||
}
|
||||
|
||||
@@ -111,6 +134,9 @@ func isTypeAlias(t reflect.Type) bool {
|
||||
if t.Kind() == reflect.Ptr {
|
||||
t = t.Elem()
|
||||
}
|
||||
if basicStructTypes[t.String()] {
|
||||
return false
|
||||
}
|
||||
return t.PkgPath() != "" && basicKinds[t.Kind()]
|
||||
}
|
||||
|
||||
@@ -158,17 +184,7 @@ func setCustomTypeValue(field reflect.Value, value string) (interface{}, error)
|
||||
return field.Interface(), nil
|
||||
}
|
||||
|
||||
var jsonData interface{}
|
||||
if err := json.Unmarshal([]byte(value), &jsonData); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
jsonBytes, err := json.Marshal(jsonData)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if err := json.Unmarshal(jsonBytes, field.Addr().Interface()); err != nil {
|
||||
if err := json.Unmarshal([]byte(value), field.Addr().Interface()); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user