English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

Spring MVC 검증

Spring MVC 검증은 사용자가 제공한 입력을 제한하는 데 사용됩니다. 사용자 입력을 검증하기 위해 Spring 4또는 더 높은 버전이 Bean Validation API를 지원하고 사용합니다. 서버와 클라이언트 애플리케이션을 동시에 검증할 수 있습니다.

Bean Validation API

Bean Validation API는 Java 규격으로, 객체 모델의 제약 조건을 주석을 통해 적용할 수 있습니다. 여기서는 길이, 숫자, 정규 표현식 등을 검증할 수 있습니다. 그리고 추가로 사용자 정의 검증을 제공할 수 있습니다.

Bean Validation API는 규격에 불과하기 때문에 구현이 필요합니다. 따라서 이를 위해 Hibernate Validator를 사용합니다. Hibernate Validator는 완벽히 JSR-303/309표현하고 검증할 수 있는 애플리케이션 제약 조건을 구현합니다.

검증 주석

일반적인 검증 주석 몇 가지를 보겠습니다.

주석설명
@NotNull이 값이 비어서는 안 됩니다.
@Min해당 숫자는 지정된 값과 같거나 크어야 합니다.
@Max해당 숫자는 지정된 값과 같거나 작아야 합니다.
@Size@Size
确定大小必须等于指定的值。@Pattern

它确定序列遵循指定的正则表达式。

Spring MVC验证示例*在此示例中,我们创建了一个包含输入字段的简单表单。在此,(

1)表示必须输入相应的字段。否则,表格会产生错误。

、将依赖项添加到pom.xml文件。

<!-- .//https:/mvnrepository.com/pom.xml/spring-org.springframework -->
validator
    webmvc/<groupId>org.hibernate.validator<
    <groupId>org.springframework<-<artifactId>spring/<artifactId>validator<
    <version>5<artifactId>jstl<1<artifactId>jstl<1webmvc</version>
</dependency>
<!-- .//https:/mvnrepository.com/.RELEASE</org.apache.tomcat-tomcat -->
validator
    jasper/<groupId>org.hibernate.validator<
    <groupId>org.apache.tomcat<-<artifactId>tomcat/<artifactId>validator<
    <version>9.0.12</version>
</dependency>
    <!-- .//https:/mvnrepository.com/alpha/alpha-jasper< -->
validator  
    jstl/<groupId>org.hibernate.validator<  
    api-<artifactId>servlet/<artifactId>validator<  
    <version>3api<-.0-1</version>  
</dependency>
<!-- .//https:/mvnrepository.com/alpha/javax.servlet -->
validator
    jstl/<groupId>org.hibernate.validator<
    <groupId>javax.servlet</<artifactId>validator<
    <version>1<artifactId>jstl<2</version>
</dependency>
 <!-- .//https:/mvnrepository.com/artifact/org.hibernate.validator-hibernate -->
validator
    <dependency>/<groupId>org.hibernate.validator<
    <artifactId>hibernate-validator</<artifactId>validator<
    <version>6.0.13.Final</version>
</dependency>

2、创建bean类

Employee.java

package com.w3codebox;
import javax.validation.constraints.Size;
public class Employee {
  private String name;
  @Size(min=1,message="required")
  private String pass;
  
  public String getName() {
    return name;
  }
  public void setName(String name) {
    this.name = name;
  }
  public String getPass() {
    return pass;
  }
  public void setPass(String pass) {
    this.pass = pass;
  } 
}

3、컨트롤러 클래스 생성

컨트롤러 클래스에서:

@유효주석은 제공된 객체에 검증 규칙을 적용합니다. BindingResult 인터페이스는 검증 결과를 포함합니다.

package com.w3codebox;
import javax.validation.Valid;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.validation.BindingResult;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class EmployeeController {
  @RequestMapping("/hello")
  public String display(Model m)
  {
    m.addAttribute("emp", new Employee());
    return "viewpage";
  }
  @RequestMapping("/helloagain")
  public String submitForm(@Valid @ModelAttribute("emp") Employee e, BindingResult br)
  {
    if(br.hasErrors())
    {
      return "viewpage";
    }
    else
    {
    return "final";
    }
  }
}

4、在web.xml文件中提供控制器的条目

web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
  <display-name>SpringMVC</display-name>
   <servlet>  
    <servlet-name>spring</servlet-name>  
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>  
    <load-on-startup>1</load-on-startup>    
</servlet>  
<servlet-mapping>  
    <servlet-name>spring</servlet-name>  
    <url-pattern>/</url-pattern>  
</servlet-mapping>  
</web-app>

5、在xml文件中定义Bean

spring-servlet.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
  xmlns:context="http://www.springframework.org/schema/context"
  xmlns:mvc="http://www.springframework.org/schema/mvc"
  xsi:schemaLocation="
    http://www.springframework.org/schema/beans
      http://www.springframework.org/schema/beans/spring-beans.xsd
      http://www.springframework.org/schema/context
      http://www.springframework.org/schema/context/spring-context.xsd
      http://www.springframework.org/schema/mvc
        http://www.springframework.org/schema/mvc/spring-mvc.xsd">
  <!-- Provide support for component scanning -->
  <context:component-scan base-package="com.w3codebox" />
  <!--Provide support for conversion, formatting and validation -->
  <mvc:annotation-driven/>
  <!-- Define Spring MVC view resolver -->
     <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/WEB-INF/jsp/></property>
        <property name="suffix" value=".jsp"></property>     
     </bean>
</beans>

6、요청 페이지 생성

index.jsp

<%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %>
<html>
<body>
<a href="hello">Click here...</a>
</body>
</html>

7、기타 뷰 컴포넌트 생성

viewpage.jsp

<%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %>
<html>
<head>
<style>
.error{color:red}
</style>
</head>
<body>
<form:form action="helloagain" modelAttribute="emp">
Username: <form:input path="name"/> <br><br>
Password(*): <form:password path="pass"/>  
<form:errors path="pass" cssClass="error"/><br><br>
<input type="submit" value="submit">
</form:form>
</body>
</html>

final.jsp

<html>
<body>
Username: ${emp.name} <br><br>
Password: ${emp.pass}
</body>
</html>

출력:


비밀번호를 입력하지 않고 양식을 제출해 보겠습니다.


지금, 우리는 비밀번호를 입력한 후 양식을 제출합니다.