主頁 > 資料庫 > 如何在golang中使用ozzo驗證進行時間最大驗證

如何在golang中使用ozzo驗證進行時間最大驗證

2022-05-24 21:29:37 資料庫

我想以格式時間(23:30:00)為時間的最大輸入,最大時間為(09:30:00),我嘗試使用 ozzo 驗證進行驗證,我找到了函式及其呼叫“日期(布局字串)"

這是檔案https://github.com/go-ozzo/ozzo-validation

從檔案中我看到函式 Date 有 Min 和 Max 來檢查指定的范圍,但問題是我不知道如何填充引數。資料型別是時間.時間。

這是我的代碼

if err := validation.Validate(c.ReleasedTime, validation.Date("15:04:05").Max(????)); err != nil {
    logger.E(err)
    return shared.NewMultiStringValidationError(shared.HTTPErrorBadRequest, map[string]string{
        "en": "Format date",
        "id": "format tanggal",
    })
}

從那里我填寫最大引數“???” 因為我仍然困惑如何填充它。也許你們都可以幫助我找到這個解決方案或使用另一個包進行驗證,我將不勝感激。謝謝

uj5u.com熱心網友回復:

測驗代碼中有一個示例。

你可以在這里看到它:https ://github.com/go-ozzo/ozzo-validation/blob/master/date_test.go#L71

但是當我們只需要比較小時時,這里會有點小技巧。

import (
    "fmt"
    "time"

    validation "github.com/go-ozzo/ozzo-validation/v4"
)

func main() {
    layout := "2006-01-02T15:04:05"
    // this add a base date to hour, so we have a valid time.Time object.
    base := "2020-01-01"
    max, _ := time.Parse(layout, base "T" "23:30:00")
    fmt.Println(max)
    r := validation.Date(layout).Max(max)
    fmt.Println(r.Validate(base   "T"   "09:00:00")) // ok
    fmt.Println(r.Validate(base   "T"   "23:40:00")) // this should raise error
}

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/480981.html

標籤:验证 后端

上一篇:鏈接filter_input()和filter_var()會導致問題嗎?

下一篇:返回列表

標籤雲
其他(140643) Python(33603) JavaScript(21352) Java(15659) C(13898) 區塊鏈(8222) AI(7469) C#(6633) 基礎類(6313) 爪哇(6273) MySQL(6178) html(5728) 熊猫(5293) sql(5249) PHP(5165) 腳本語言(PerlPython)(5129) 非技術區(4971) Linux(4840) 数组(4764) R(4619) Android(4340) 反应(4284) 数据框(3703) css(3651) 节点.js(3370) C語言(3288) C++語言(3117) json(2807) Java相關(2746) 列表(2700) 疑難問題(2699) 扑(2600) 安卓(2589) VBA(2513) 單片機工控(2479) 打字稿(2478) 细绳(2180) ASP.NET(2129) iOS(2100) MongoDB(1985) Web開發(1951) 字典(1929) 麻木的(1902) 循环(1899) 正则表达式(1891) 擅长(1830) 镖(1819) 迅速(1794) 網絡通信(1793) 蟒蛇-3.x(1774) 數據庫相關(1767) VB基礎類(1755) .NETCore(1740) Unity3D(1689) 功能(1676) C++(1660) 開發(1646) .NET技术(1638) 系統維護與使用區(1617) HtmlCss(1594)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布