Spring 3では、 “http://static.springsource.org/spring/docs/3.0.x/spring-framework-reference/html/mvc.html#mvc-annotation-driven[mvc:annotation-driven]を有効にできます。 “クラスパス上のJSR 303バリデーターフレームワークがあれば、` @ Valid`アノテーションを使用してhttp://jcp.org/ja/jsr/detail?id=303[JSR303 bean validation]をサポートします。

このチュートリアルでは、HTMLフォームでBeanの検証を実行するために、HibernateバリデーターとSpring MVCを `@ Valid`アノテーションを使って統合する方法を説明します。

使用される技術:

  1. Spring 3.0.5.RELEASE

  2. Hibernate Validator 4.2.0.Final

  3. JDK 1.6

  4. Eclipse 3.6

  5. Maven 3

プロジェクトの依存関係

HibernateバリデータはJBossの公開リポジトリから入手できます。

    <repositories>
        <repository>
            <id>JBoss repository</id>
            <url>http://repository.jboss.org/nexus/content/groups/public/</url>
        </repository>
    </repositories>

    <properties>
        <spring.version>3.0.5.RELEASE</spring.version>
    </properties>

    <dependencies>

        <!-- Spring 3 dependencies -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-core</artifactId>
            <version>${spring.version}</version>
        </dependency>

        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-web</artifactId>
            <version>${spring.version}</version>
        </dependency>

        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>${spring.version}</version>
        </dependency>

        <!-- Hibernate Validator -->
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-validator</artifactId>
            <version>4.2.0.Final</version>
        </dependency>

    </dependencies>

2. JSR303 Bean検証

単純なPOJOで、Hibernateバリデータアノテーションでアノテーションされています。

  • 注意** +詳細な説明については、http://docs.jboss.org/hibernate/validator/4.2/reference/en-US/html/[Hibernate validator documentation]を参照してください。

package com.mkyong.common.model;

import org.hibernate.validator.constraints.NotEmpty;
import org.hibernate.validator.constraints.Range;

public class Customer {

    @NotEmpty//make sure name is not empty
    String name;

    @Range(min = 1, max = 150)//age need between 1 and 150
    int age;

   //getter and setter methods

}

3.コントローラ@Valid

バリデーションを有効にするには、「@ Valid」を介して「JSR注釈付きモデルオブジェクト」に注釈を付けるだけです。つまり、他のものは通常のSpring MVCのフォーム処理です。

package com.mkyong.common.controller;

import javax.validation.Valid;
import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.validation.BindingResult;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import com.mkyong.common.model.Customer;

@Controller
@RequestMapping("/customer")
public class SignUpController {

    @RequestMapping(value = "/signup", method = RequestMethod.POST)
    public String addCustomer(@Valid Customer customer, BindingResult result) {

        if (result.hasErrors()) {
            return "SignUpForm";
        } else {
            return "Done";
        }

    }

    @RequestMapping(method = RequestMethod.GET)
    public String displayCustomerForm(ModelMap model) {

        model.addAttribute("customer", new Customer());
        return "SignUpForm";

    }

}

4.エラーメッセージ

デフォルトでは、検証に失敗した場合。

  1. `@ NotEmpty`は”空ではないかもしれません “と表示します

  2. `@ Range`は” 1と150の間でなければならない “と表示する

簡単に上書きし、「キー」とメッセージでプロパティを作成することができます。

どんな@nonotationがどのキーにバインドされているかを知るには、単に `BindingResult result`の中でデバッグして値を見るだけです。通常、キーは ”

@ Annotation Name.object.fieldname

“です。


ファイル:messages.properties

NotEmpty.customer.name = Name is required!
Range.customer.age = Age value must be between 1 and 150

5. mvc:アノテーション駆動型

Spring MVCが

@ Valid`を介してJSR303バリデータをサポートするように

`mvc:annotation-driven`を有効にし、プロパティファイルもバインドします。

<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:mvc="http://www.springframework.org/schema/mvc"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="
        http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context-3.0.xsd
        http://www.springframework.org/schema/mvc
        http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd">

    <context:component-scan base-package="com.mkyong.common.controller"/>

         <!-- support JSR303 annotation if JSR 303 validation present on classpath -->
    <mvc:annotation-driven/>

    <bean id="viewResolver"
        class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix">
            <value>/WEB-INF/pages/</value>
        </property>
        <property name="suffix">
            <value>.jsp</value>
        </property>
    </bean>

        <!-- bind your messages.properties -->
    <bean class="org.springframework.context.support.ResourceBundleMessageSource"
        id="messageSource">
        <property name="basename" value="messages"/>
    </bean>

</beans>

6. JSPページ

最後の1つは、Springフォームのタグライブラリを持つ通常のJSPページです。


File:SignUpForm.jsp

<%@ taglib prefix="form" uri="http://www.springframework.org/tags/form"%>
<html>
<head>
<style>
.error {
    color: #ff0000;
}

.errorblock {
    color: #000;
    background-color: #ffEEEE;
    border: 3px solid #ff0000;
    padding: 8px;
    margin: 16px;
}
</style>
</head>

<body>
    <h2>Customer SignUp Form - JSR303 @Valid example</h2>

    <form:form method="POST" commandName="customer" action="customer/signup">
        <form:errors path="** " cssClass="errorblock" element="div"/>
        <table>
            <tr>
                <td>Customer Name :</td>
                <td><form:input path="name"/></td>
                <td><form:errors path="name" cssClass="error"/></td>
            </tr>
            <tr>
                <td>Customer Age :</td>
                <td><form:input path="age"/></td>
                <td><form:errors path="age" cssClass="error"/></td>
            </tr>
            <tr>
                <td colspan="3"><input type="submit"/></td>
            </tr>
        </table>
    </form:form>

</body>
</html>


File:Done.jsp

<html>
<body>
    <h2>Done</h2>
</body>
</html>

6.デモ


URL:http://localhost:8080/SpringMVC/customer

– 顧客フォームページ。名前と年齢の2つのテキストボックス。


Spring MVC JSR303デモページ、title = "spring-mvc-bean-validation"、width = 598、height = 321


URL:http://localhost:8080/SpringMVC/customer/signup

– フォームに記入せずに「送信」ボタンをクリックすると、カスタマイズされた検証エラーメッセージが表示されます。


Spring MVC JSR303デモページ - エラーメッセージ、title = "spring-mvc-bean-validation-error"、width = 613、高さ= 381

ソースコードをダウンロードする

ダウンロードする –

SpringMVC-Bean-Validation-JSR303-Example2.zip

(9 KB)