SpringMVC——數據校驗

来源:http://www.cnblogs.com/thErving/archive/2017/05/31/6926264.html
-Advertisement-
Play Games

數據校驗在web應用里是非常重要的功能,尤其是在表單輸入中。在這裡採用Hibernate-Validator進行校驗,該方法實現了JSR-303驗證框架支持註解風格的驗證。 一、導入jar包 若要實現數據校驗功能,需要導入必要的jar包,主要包括以下幾個: classmate-1.3.1.jar h ...


數據校驗在web應用里是非常重要的功能,尤其是在表單輸入中。在這裡採用Hibernate-Validator進行校驗,該方法實現了JSR-303驗證框架支持註解風格的驗證。

一、導入jar包

若要實現數據校驗功能,需要導入必要的jar包,主要包括以下幾個:

  • classmate-1.3.1.jar
  • hibernate-validator-5.4.1.Final.jar
  • hibernate-validator-annotation-processor-5.4.1.Final.jar
  • hibernate-validator-cdi-5.4.1.Final.jar
  • jboss-logging-3.3.0.Final.jar
  • validation-api-1.1.0.Final.jar

二、常用的校驗註解

註解功能
@Null 驗證對象是否為 null
@NotNull 驗證對象是否不為 null
@AssertTrue 驗證 Boolean 對象是否為 true
@AssertTrue 驗證 Boolean 對象是否為 false
@Max(value) 驗證 Number 和 String 對象是否小於等於指定值
@Min(value) 驗證 Number 和 String 對象是否大於等於指定值
@DecimalMax(value) 驗證註解的元素值小於等於 @DecimalMax 指定的 value 值
@DecimalMin(value) 驗證註解的元素值大於等於 @DecimalMin 指定的 value 值
@Digits(integer,fraction) 驗證字元串是否符合指定格式的數字,integer 指定整數精度,fraction 指定小數精度
@Size(min,max) 驗證對象長度是否在給定的範圍內
@Past 驗證 Date 和 Calendar 對象是否在當前時間之前
@Future 驗證 Date 和 Calendar 對象是否在當前時間之後
@Pattern 驗證 String 對象是否符合正則表達式的規則
@NotBlank 檢查字元串是不是 Null,被 Trim 的長度是否大於0,只對字元串,且會去掉前後空格
@URL 驗證是否是合法的 url
@Email 驗證是否是合法的郵箱
@CreditCardNumber 驗證是否是合法的信用卡號
@Length(min,max) 驗證字元串的長度必須在指定範圍內
@NotEmpty 檢查元素是否為 Null 或 Empty
@Range(min,max,message) 驗證屬性值必須在合適的範圍內

三、修改實體類

在類的屬性上進行標註,如:

public class User {
    @NotBlank(message = "Username can not be empty")
    private String username;
    @NotBlank(message = "password can not be blank")
    @Length(min = 6, max = 16, message = "The length of the password must be between 6 and 16 bits")
    private String password;
    @Range(min = 18, max = 60, message = "Age must be between 18 and 60 years old")
    private Integer age;
    @Pattern(regexp = "^1[3|4|5|7|8][0-9]{9}$", message = "Please enter the correct format of the phone number")
    private String phone;
    @Email(message = "Please enter a valid email address")
    private String email;

    // other...   
}

四、修改相應的處理方法

@RequestMapping(value = "/register")
public String register(@Valid  @ModelAttribute("user") User user, Errors errors,Model model) {
    if(errors.hasErrors()){
        return "register";
    }
    model.addAttribute("user", user);
    return "success";
}

五、視圖輸出

校驗之後,我們通常需要在表單的輸入框後進行文字反饋:

<form:form modelAttribute="user" method="post" action="register">
    <fieldset>
        <legend>register</legend>
        <p>
            <label>name:</label>
            <form:input path="username" />
            <form:errors path="username" cssStyle="color:red"/>
        </p>
         ...
    </fieldset>
</form:form>

然而,有些時候並不推薦直接將錯誤信息寫在註解的message屬性里,這樣不方便國際化。因此可以做以下幾處修改:

1. 新建validatemessages.properties

username.not.blank = "username cannot be empty..."
password.not.blank = "password cannot be empty"
password.not.length = "password should be in 6-10"
age.not.range = "age should be in 10-70"
phone.not.pattern = "phone should be in format"
email.not.format = "email should be in format"

2. 實體類中的註解使用相對引用

public class User {
    
    @NotBlank(message = "{username.not.blank}")
    private String username;
    
    @NotBlank(message = "{password.not.blank}")
    @Length(min = 6, max = 10, message = "{password.not.length}")
    private String password;
    
    @Range(min = 10, max = 70, message = "{age.not.range}")
    private Integer age;
    
    @Pattern(regexp = "^1[3|4|5|7|8][0-9]{9}$", message = "{phone.not.pattern}")
    private String phone;
    
    @Email(message = "{email.not.format}")
    private String email;
    
//
other... }

3. 修改配置文件

    <!-- 預設的註解映射的支持 -->  
    <mvc:annotation-driven validator="validator" conversion-service="conversion-service" />
    
    <bean id="validator" class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean">
        <property name="providerClass"  value="org.hibernate.validator.HibernateValidator"/>
        <!--不設置則預設為classpath下的 ValidationMessages.properties -->
        <property name="validationMessageSource" ref="validatemessageSource"/>
    </bean>
    <bean id="conversion-service" class="org.springframework.format.support.FormattingConversionServiceFactoryBean" />
    <bean id="validatemessageSource" class="org.springframework.context.support.ReloadableResourceBundleMessageSource">  
        <property name="basename" value="classpath:validatemessages"/>  
        <property name="fileEncodings" value="utf-8"/>  
        <property name="cacheSeconds" value="120"/>  
    </bean>

特別註意:value="classpath:validatemessages",文件名不加尾碼!

至此,數據校驗的整個過程就結束了。

最後還要特別強調的重點是:

  • 視圖中<form:form modelAttribute="contentModel" method="post">的modelAttribute="xxx"後面的名稱xxx必須與對應的@Valid @ModelAttribute("xxx") 中的xxx名稱一致,否則模型數據和錯誤信息都綁定不到。
  • <form:errors path="name"></form:errors>即會顯示模型對應屬性的錯誤信息,當path="*"時則顯示模型全部屬性的錯誤信息。

參考地址:

http://www.cnblogs.com/liukemng/p/3738055.html


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1,這是因為用線程式控制制子窗體,刷新數據的時候會影響主窗體,因為主次窗體是以 Main man = new Main(); man.ShowDialog();形式存在 2,解決辦法: 新建公共類,Bool屬性並賦值,在需要調用刷新數據方法地方通過給刷新數據的方法套一個事件,在通過Timer 控制項結束當 ...
  • 接上一篇,眾所周知一個網站的用戶登錄是非常重要,一站式的登錄(SSO)也成了大家討論的熱點。微軟在這個Demo中,把登錄單獨拉了出來,形成了一個Service,用戶的註冊、登錄、找回密碼等都在其中進行。這套service是基於IdentityServer4開發的, 它是一套基於 .Net Core的... ...
  • 一、需求 我們在開發中經常會遇到一些枚舉,而且這些枚舉類型可能會在表單中的下拉中,或者單選按鈕中會用到等。 這樣用是沒問題的,但是用過的人都知道一個問題,就是枚舉的命名問題,當然有很多人枚舉直接中文命名,我是不推薦這種命名規則,因為實在不夠友好。 那有沒有可以不用中文命名,而且可以顯示中文的方法呢。 ...
  • 本文是利用PrintDocument定製列印單據的小例子。 涉及知識點: PrintDocument :從 Windows 窗體應用程式列印時,定義一種可重用的可發送到印表機上的對象。 PrintPreviewControl :表示 Windows 窗體應用程式列印預覽的原始預覽部分,沒有任何對話框 ...
  • Java基礎十一--多態 一、多態定義 簡單說:就是一個對象對應著不同類型. 多態在代碼中的體現: 父類或者介面的引用指向其子類的對象。 向上轉型:父類引用指向子類對象。子類的特有功能無法訪問。 向下轉型:子類引用指向父類對象。 在實際應用中,向上轉型便於代碼擴展(之前寫的代碼以後能用,只有繼承或者 ...
  • 面向對象高級語法部分 通過@staticmethod裝飾器即可把其裝飾的方法變為一個靜態方法,什麼是靜態方法呢?其實不難理解,普通的方法,可以在實例化後直接調用,並且在方法里可以通過self.調用實例變數或類變數,但靜態方法是不可以訪問實例變數或類變數的,一個不能訪問實例變數和類變數的方法,其實相當 ...
  • 一、先新建 empty project, 再新建 module 首先,新建一個 empty project 填寫 project 名字及存放位置 project 新建完後會打開 idea 編輯器視窗,選擇 File/New/Module 新建 module 左側選擇 Java Enterprise, ...
  • 分析網站 首先來到目標數據的網頁 http://www.weather.com.cn/weather40d/101280701.shtml 中國天氣網 中國天氣網 我們可以看到,我們需要的天氣數據都是放在圖表上的,在切換月份的時候,發現只有部分頁面刷新了,就是天氣數據的那塊,而URL沒有變化。 這是 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...