mirror of
https://github.com/gin-gonic/gin.git
synced 2025-04-24 18:37:24 +08:00
feat(binding): add support for unixMilli and unixMicro (#4190)
This commit is contained in:
parent
90cf460269
commit
4ccfa7c275
@ -73,11 +73,15 @@ type FooBarStructForTimeType struct {
|
|||||||
TimeBar time.Time `form:"time_bar" time_format:"2006-01-02" time_utc:"1"`
|
TimeBar time.Time `form:"time_bar" time_format:"2006-01-02" time_utc:"1"`
|
||||||
CreateTime time.Time `form:"createTime" time_format:"unixNano"`
|
CreateTime time.Time `form:"createTime" time_format:"unixNano"`
|
||||||
UnixTime time.Time `form:"unixTime" time_format:"unix"`
|
UnixTime time.Time `form:"unixTime" time_format:"unix"`
|
||||||
|
UnixMilliTime time.Time `form:"unixMilliTime" time_format:"unixmilli"`
|
||||||
|
UnixMicroTime time.Time `form:"unixMicroTime" time_format:"uNiXmiCrO"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type FooStructForTimeTypeNotUnixFormat struct {
|
type FooStructForTimeTypeNotUnixFormat struct {
|
||||||
CreateTime time.Time `form:"createTime" time_format:"unixNano"`
|
CreateTime time.Time `form:"createTime" time_format:"unixNano"`
|
||||||
UnixTime time.Time `form:"unixTime" time_format:"unix"`
|
UnixTime time.Time `form:"unixTime" time_format:"unix"`
|
||||||
|
UnixMilliTime time.Time `form:"unixMilliTime" time_format:"unixMilli"`
|
||||||
|
UnixMicroTime time.Time `form:"unixMicroTime" time_format:"unixMicro"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type FooStructForTimeTypeNotFormat struct {
|
type FooStructForTimeTypeNotFormat struct {
|
||||||
@ -265,10 +269,10 @@ func TestBindingFormDefaultValue2(t *testing.T) {
|
|||||||
func TestBindingFormForTime(t *testing.T) {
|
func TestBindingFormForTime(t *testing.T) {
|
||||||
testFormBindingForTime(t, http.MethodPost,
|
testFormBindingForTime(t, http.MethodPost,
|
||||||
"/", "/",
|
"/", "/",
|
||||||
"time_foo=2017-11-15&time_bar=&createTime=1562400033000000123&unixTime=1562400033", "bar2=foo")
|
"time_foo=2017-11-15&time_bar=&createTime=1562400033000000123&unixTime=1562400033&unixMilliTime=1562400033001&unixMicroTime=1562400033000012", "bar2=foo")
|
||||||
testFormBindingForTimeNotUnixFormat(t, http.MethodPost,
|
testFormBindingForTimeNotUnixFormat(t, http.MethodPost,
|
||||||
"/", "/",
|
"/", "/",
|
||||||
"time_foo=2017-11-15&createTime=bad&unixTime=bad", "bar2=foo")
|
"time_foo=2017-11-15&createTime=bad&unixTime=bad&unixMilliTime=bad&unixMicroTime=bad", "bar2=foo")
|
||||||
testFormBindingForTimeNotFormat(t, http.MethodPost,
|
testFormBindingForTimeNotFormat(t, http.MethodPost,
|
||||||
"/", "/",
|
"/", "/",
|
||||||
"time_foo=2017-11-15", "bar2=foo")
|
"time_foo=2017-11-15", "bar2=foo")
|
||||||
@ -282,11 +286,11 @@ func TestBindingFormForTime(t *testing.T) {
|
|||||||
|
|
||||||
func TestBindingFormForTime2(t *testing.T) {
|
func TestBindingFormForTime2(t *testing.T) {
|
||||||
testFormBindingForTime(t, http.MethodGet,
|
testFormBindingForTime(t, http.MethodGet,
|
||||||
"/?time_foo=2017-11-15&time_bar=&createTime=1562400033000000123&unixTime=1562400033", "/?bar2=foo",
|
"/?time_foo=2017-11-15&time_bar=&createTime=1562400033000000123&unixTime=1562400033&unixMilliTime=1562400033001&unixMicroTime=1562400033000012", "/?bar2=foo",
|
||||||
"", "")
|
"", "")
|
||||||
testFormBindingForTimeNotUnixFormat(t, http.MethodPost,
|
testFormBindingForTimeNotUnixFormat(t, http.MethodPost,
|
||||||
"/", "/",
|
"/", "/",
|
||||||
"time_foo=2017-11-15&createTime=bad&unixTime=bad", "bar2=foo")
|
"time_foo=2017-11-15&createTime=bad&unixTime=bad&unixMilliTime=bad&unixMicroTime=bad", "bar2=foo")
|
||||||
testFormBindingForTimeNotFormat(t, http.MethodGet,
|
testFormBindingForTimeNotFormat(t, http.MethodGet,
|
||||||
"/?time_foo=2017-11-15", "/?bar2=foo",
|
"/?time_foo=2017-11-15", "/?bar2=foo",
|
||||||
"", "")
|
"", "")
|
||||||
@ -952,6 +956,8 @@ func testFormBindingForTime(t *testing.T, method, path, badPath, body, badBody s
|
|||||||
assert.Equal(t, "UTC", obj.TimeBar.Location().String())
|
assert.Equal(t, "UTC", obj.TimeBar.Location().String())
|
||||||
assert.Equal(t, int64(1562400033000000123), obj.CreateTime.UnixNano())
|
assert.Equal(t, int64(1562400033000000123), obj.CreateTime.UnixNano())
|
||||||
assert.Equal(t, int64(1562400033), obj.UnixTime.Unix())
|
assert.Equal(t, int64(1562400033), obj.UnixTime.Unix())
|
||||||
|
assert.Equal(t, int64(1562400033001), obj.UnixMilliTime.UnixMilli())
|
||||||
|
assert.Equal(t, int64(1562400033000012), obj.UnixMicroTime.UnixMicro())
|
||||||
|
|
||||||
obj = FooBarStructForTimeType{}
|
obj = FooBarStructForTimeType{}
|
||||||
req = requestWithBody(method, badPath, badBody)
|
req = requestWithBody(method, badPath, badBody)
|
||||||
|
@ -398,18 +398,24 @@ func setTimeField(val string, structField reflect.StructField, value reflect.Val
|
|||||||
}
|
}
|
||||||
|
|
||||||
switch tf := strings.ToLower(timeFormat); tf {
|
switch tf := strings.ToLower(timeFormat); tf {
|
||||||
case "unix", "unixnano":
|
case "unix", "unixmilli", "unixmicro", "unixnano":
|
||||||
tv, err := strconv.ParseInt(val, 10, 64)
|
tv, err := strconv.ParseInt(val, 10, 64)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
d := time.Duration(1)
|
var t time.Time
|
||||||
if tf == "unixnano" {
|
switch tf {
|
||||||
d = time.Second
|
case "unix":
|
||||||
|
t = time.Unix(tv, 0)
|
||||||
|
case "unixmilli":
|
||||||
|
t = time.UnixMilli(tv)
|
||||||
|
case "unixmicro":
|
||||||
|
t = time.UnixMicro(tv)
|
||||||
|
default:
|
||||||
|
t = time.Unix(0, tv)
|
||||||
}
|
}
|
||||||
|
|
||||||
t := time.Unix(tv/int64(d), tv%int64(d))
|
|
||||||
value.Set(reflect.ValueOf(t))
|
value.Set(reflect.ValueOf(t))
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -832,6 +832,8 @@ type Person struct {
|
|||||||
Birthday time.Time `form:"birthday" time_format:"2006-01-02" time_utc:"1"`
|
Birthday time.Time `form:"birthday" time_format:"2006-01-02" time_utc:"1"`
|
||||||
CreateTime time.Time `form:"createTime" time_format:"unixNano"`
|
CreateTime time.Time `form:"createTime" time_format:"unixNano"`
|
||||||
UnixTime time.Time `form:"unixTime" time_format:"unix"`
|
UnixTime time.Time `form:"unixTime" time_format:"unix"`
|
||||||
|
UnixMilliTime time.Time `form:"unixMilliTime" time_format:"unixmilli"`
|
||||||
|
UnixMicroTime time.Time `form:"unixMicroTime" time_format:"uNiXmIcRo"` // case does not matter for "unix*" time formats
|
||||||
}
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
@ -851,6 +853,8 @@ func startPage(c *gin.Context) {
|
|||||||
log.Println(person.Birthday)
|
log.Println(person.Birthday)
|
||||||
log.Println(person.CreateTime)
|
log.Println(person.CreateTime)
|
||||||
log.Println(person.UnixTime)
|
log.Println(person.UnixTime)
|
||||||
|
log.Println(person.UnixMilliTime)
|
||||||
|
log.Println(person.UnixMicroTime)
|
||||||
}
|
}
|
||||||
|
|
||||||
c.String(http.StatusOK, "Success")
|
c.String(http.StatusOK, "Success")
|
||||||
@ -860,7 +864,7 @@ func startPage(c *gin.Context) {
|
|||||||
Test it with:
|
Test it with:
|
||||||
|
|
||||||
```sh
|
```sh
|
||||||
curl -X GET "localhost:8085/testing?name=appleboy&address=xyz&birthday=1992-03-15&createTime=1562400033000000123&unixTime=1562400033"
|
curl -X GET "localhost:8085/testing?name=appleboy&address=xyz&birthday=1992-03-15&createTime=1562400033000000123&unixTime=1562400033&unixMilliTime=1562400033001&unixMicroTime=1562400033000012"
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user