찾다
Javajava지도 시간SpringMVC 학습 시리즈(6) 데이터 검증

시리즈 (SpringMVC 학습 시리즈(6) 데이터 검증)와 (SpringMVC 학습 시리즈(6) 데이터 검증)에서는 데이터를 바인딩하는 방법을 보여줬고, 얻은 데이터의 정확성을 어떻게 보장할 수 있나요? 이번 글에서 다룰 내용은 바로 이것이다 —> 데이터 검증입니다.

여기서는 검증을 위해 Hibernate-validator를 사용합니다. Hibernate-validator는 JSR-SpringMVC 학습 시리즈(6) 데이터 검증0SpringMVC 학습 시리즈(6) 데이터 검증 검증 프레임워크를 구현하고 주석 스타일 검증을 지원합니다. 먼저 http://www.php.cn/으로 이동하여 필요한 jar 패키지를 다운로드해야 합니다. 여기에서는 압축 해제 후 데모로 hibernate-validator-SpringMVC 학습 시리즈(6) 데이터 검증.SpringMVC 학습 시리즈(6) 데이터 검증.SpringMVC 학습 시리즈(6) 데이터 검증.Final.jar을 사용합니다. jboss-logging-SpringMVC 학습 시리즈(6) 데이터 검증.SpringMVC 학습 시리즈(6) 데이터 검증 SpringMVC 학습 시리즈(6) 데이터 검증개의 패키지 .0.jar 및 유효성 검사-api-SpringMVC 학습 시리즈(6) 데이터 검증.0.0.GA.jar이 프로젝트에 추가되었습니다.

이전 프로젝트에서 springservlet-config.xml 파일을 다음과 같이 구성합니다.

<!-- 默认的注解映射的支持 -->  
    <annotation-driven></annotation-driven>
    
    <bean>
        <property></property>
        <!--不设置则默认为classpath下的 ValidationMessages.properties -->
        <property></property>
    </bean>
    <bean></bean>
    <bean>  
        <property></property>  
        <property></property>  
        <property></property>  
    </bean>


여기서 속성 이름="basename"="classpath:validatemessages"/> 🎜>classpath:validatemessages는 주석 확인 메시지가 있는 파일이므로 리소스 폴더에 추가해야 합니다.

com.demo.web.controllers 패키지에 다음 콘텐츠가 포함된 ValidateController.java를 추가합니다.

package com.demo.web.controllers;import java.security.NoSuchAlgorithmException;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;import org.springframework.web.bind.annotation.RequestMethod;import com.demo.web.models.ValidateModel;

@Controller
@RequestMapping(value = "/validate")public class ValidateController {
    
    @RequestMapping(value="/test", method = {RequestMethod.GET})    public String test(Model model){        if(!model.containsAttribute("contentModel")){
            model.addAttribute("contentModel", new ValidateModel());
        }        return "validatetest";
    }
    
    @RequestMapping(value="/test", method = {RequestMethod.POST})    public String test(Model model, @Valid @ModelAttribute("contentModel") ValidateModel validateModel, BindingResult result) throws NoSuchAlgorithmException{        
        //如果有验证错误 返回到form页面
        if(result.hasErrors())            return test(model);        return "validatesuccess";     
    }
    
}


그 중 @Valid @ModelAttribute("contentModel") ValidateModel verifyModel의 @Valid는 @ModelAttribute("contentModel")에 데이터를 바인딩한 후 유효성을 검사한다는 의미입니다.

com.demo.web.models 패키지에 다음 콘텐츠가 포함된 ValidateModel.java를 추가합니다.

package com.demo.web.models;import org.hibernate.validator.constraints.Email;import org.hibernate.validator.constraints.NotEmpty;import org.hibernate.validator.constraints.Range;public class ValidateModel{
    
    @NotEmpty(message="{name.not.empty}")    private String name;
    @Range(min=0, max=SpringMVC 학습 시리즈(6) 데이터 검증SpringMVC 학습 시리즈(6) 데이터 검증0,message="{age.not.inrange}")    private String age;
    @NotEmpty(message="{email.not.empty}")
    @Email(message="{email.not.correct}")    private String email;    
    public void setName(String name){        this.name=name;
    }    public void setAge(String age){        this.age=age;
    }    public void setEmail(String email){        this.email=email;
    }    
    public String getName(){        return this.name;
    }    public String getAge(){        return this.age;
    }    public String getEmail(){        return this.email;
    }
    
}


확인 메시지가 있는 파일에 주석을 답니다. 속성 파일에 다음 내용을 추가합니다:

name.not.empty=\uSpringMVC 학습 시리즈(6) 데이터 검증SpringMVC 학습 시리즈(6) 데이터 검증0D\u79F0\uSpringMVC 학습 시리즈(6) 데이터 검증E0D\u80FD\uSpringMVC 학습 시리즈(6) 데이터 검증ESpringMVC 학습 시리즈(6) 데이터 검증A\u7A7A\uSpringMVC 학습 시리즈(6) 데이터 검증00SpringMVC 학습 시리즈(6) 데이터 검증
age.not.inrange=\uSpringMVC 학습 시리즈(6) 데이터 검증E7SpringMVC 학습 시리즈(6) 데이터 검증\u9F8SpringMVC 학습 시리즈(6) 데이터 검증\u8D8SpringMVC 학습 시리즈(6) 데이터 검증\uSpringMVC 학습 시리즈(6) 데이터 검증SpringMVC 학습 시리즈(6) 데이터 검증FA\u8SpringMVC 학습 시리즈(6) 데이터 검증0SpringMVC 학습 시리즈(6) 데이터 검증\uSpringMVC 학습 시리즈(6) 데이터 검증6FSpringMVC 학습 시리즈(6) 데이터 검증\uSpringMVC 학습 시리즈(6) 데이터 검증00SpringMVC 학습 시리즈(6) 데이터 검증
email.not.correct=\u90AE\u7BBSpringMVC 학습 시리즈(6) 데이터 검증\uSpringMVC 학습 시리즈(6) 데이터 검증7SpringMVC 학습 시리즈(6) 데이터 검증0\uSpringMVC 학습 시리즈(6) 데이터 검증7SpringMVC 학습 시리즈(6) 데이터 검증0\uSpringMVC 학습 시리즈(6) 데이터 검증E0D\u6B6SpringMVC 학습 시리즈(6) 데이터 검증\u786E\uSpringMVC 학습 시리즈(6) 데이터 검증00SpringMVC 학습 시리즈(6) 데이터 검증
email.not.empty=\u7SpringMVC 학습 시리즈(6) 데이터 검증SpringMVC 학습 시리즈(6) 데이터 검증SpringMVC 학습 시리즈(6) 데이터 검증\uSpringMVC 학습 시리즈(6) 데이터 검증BSpringMVC 학습 시리즈(6) 데이터 검증0\u90AE\uSpringMVC 학습 시리즈(6) 데이터 검증EF6\uSpringMVC 학습 시리즈(6) 데이터 검증E0D\u80FD\u60DF\u60SpringMVC 학습 시리즈(6) 데이터 검증0\uSpringMVC 학습 시리즈(6) 데이터 검증00SpringMVC 학습 시리즈(6) 데이터 검증


그 중 name.not.empty 등은 각각 메시지의 xxx 이름에 해당합니다. ValidateModel.java 파일에 ="xxx"이고 다음 내용은 중국어 입력시 자동으로 변환되는 ASCII 코드입니다. 물론, 별도의 verifymessages.properties 파일을 생성하고 추가하지 않고도 프롬프트 내용으로 직접 xxx를 쓸 수도 있습니다. 그러나 이는 하드 코딩된 경우 메소드가 국제화되었기 때문에 올바르지 않습니다.

views 폴더에 두 개의 뷰(validatetest.jsp 및 verifysuccess.jsp)를 추가합니다. 내용은 다음과 같습니다.

nbsp;html PUBLIC "-//WSpringMVC 학습 시리즈(6) 데이터 검증C//DTD HTML SpringMVC 학습 시리즈(6) 데이터 검증.0SpringMVC 학습 시리즈(6) 데이터 검증 Transitional//EN" "http://www.wSpringMVC 학습 시리즈(6) 데이터 검증.org/TR/htmlSpringMVC 학습 시리즈(6) 데이터 검증/loose.dtd"><meta><title>Insert title here</title>
    <form>     
        
        <errors></errors><br><br>
            
        name:<input><br>
        <errors></errors><br>
        
        age:<input><br>
        <errors></errors><br>
        
        email:<input><br>
        <errors></errors><br>

        <input>
        
    </form>  


nbsp;html PUBLIC "-//WSpringMVC 학습 시리즈(6) 데이터 검증C//DTD HTML SpringMVC 학습 시리즈(6) 데이터 검증.0SpringMVC 학습 시리즈(6) 데이터 검증 Transitional//EN" "http://www.wSpringMVC 학습 시리즈(6) 데이터 검증.org/TR/htmlSpringMVC 학습 시리즈(6) 데이터 검증/loose.dtd"><meta><title>Insert title here</title>
    验证成功!


특히 주목할 점은

form:form modelAttribute="contentModel" 메소드="post">modelAttribute="xxx"해당 @Valid 뒤에 오는 이름 xxx @ModelAttribute("xxx") xxx 이름은 일관됩니다. 그렇지 않으면 모델 데이터와 오류 정보가 바인딩되지 않습니다.

양식:오류 경로="이름">form:errors>는 모델의 해당 속성에 대한 오류 정보를 표시합니다. path="*"인 경우 표시됩니다. 모델의 모든 속성.

테스트 실행:

SpringMVC 학습 시리즈(6) 데이터 검증

제출을 직접 클릭하세요:

SpringMVC 학습 시리즈(6) 데이터 검증

확인하려면 설정에 대한 오류 메시지가 올바르게 표시됩니다.

잘못된 데이터 제출:

SpringMVC 학습 시리즈(6) 데이터 검증

설정된 오류 메시지가 여전히 올바르게 표시되는 것을 확인할 수 있습니다.

올바른 데이터를 입력하고 제출하세요.

SpringMVC 학습 시리즈(6) 데이터 검증

SpringMVC 학습 시리즈(6) 데이터 검증

인증이 성공한 것을 확인할 수 있습니다.

다음은 주요 확인 참고 사항 및 지침입니다.

@Digits(정수=정수, 분수=소수)주석의 요소 값을 확인하세요. 정수 및 소수 자릿수@Future주석의 요소 값(날짜 유형)이 현재 시간보다 이후인지 확인@Max(value=x)주석이 추가된 요소 값이 @Max@Min(값=x)

참고 사항

해당 데이터 유형

설명

@AssertFalse

부울, 부울

확인 주석의 요소 값이 false입니다

@AssertTrue

Boolean, boolean

주석의 요소 값이 true인지 확인

@DecimalMax(값=x)

BigDecimal, BigInteger, String, byte, short, int , long 및 기본 유형의 해당 래퍼. HV에서 추가로 지원: Number 및 CharSequence의 모든 하위 유형

@DecimalMin(value=x)

BigDecimal, BigInteger, String, byte,short, int, long 및 기본 유형의 해당 래퍼: Number 및 CharSequence의 모든 하위 유형이 추가로 지원됩니다. 🎜>

BigDecimal, BigInteger, 문자열, 바이트, short, int, long 및 기본 유형의 해당 래퍼. HV에서 추가로 지원: Number 및 CharSequence의 모든 하위 유형

java.util .Date , java.util.Calendar; Joda Time 날짜/시간 API가 다음과 같은 경우 HV에서 추가로 지원됩니다. 클래스 경로: ReadablePartial 및ReadableInstant의 모든 구현

BigDecimal, BigInteger, byte, short,int, long 및 기본 유형의 해당 래퍼 . HV에서 추가로 지원됨: 모든 하위 유형 ofCharSequence(문자 시퀀스로 표시되는 숫자 값) 평가됨), Number의 모든 하위 유형.

에서 지정한 값보다 작거나 같은지 확인하세요.

BigDecimal, BigInteger, byte, short,int, long 및 기본 유형의 해당 래퍼. HV에서 추가로 지원: CharSequence의 모든 하위 유형(char 시퀀스로 표시되는 숫자 값은 다음과 같습니다. 평가됨), Number의 모든 하위 유형.

주석의 요소 값이 @Min

@NotNull

모든 유형

다음 요소 값이 주석이 null이 아닙니다

@Null

모든 유형

주석이 달린 요소 유효성 검사 값이 null입니다

@Past

java.util.Date, java.util .Calendar; Joda Time 날짜/시간 API가 다음과 같은 경우 HV에서 추가로 지원됩니다. 클래스 경로: ReadablePartial 및ReadableInstant의 모든 구현.

주석의 요소 값(날짜 유형)이 현재 시간보다 이전인지 확인

@Pattern(regex=regular 표현식, 플래그=)

문자열. HV에서 추가로 지원: CharSequence의 모든 하위 유형.

주석이 달린 요소 값이 지정된 정규 표현식과 일치하는지 확인

@Size(min=최소값 , max=최대값)

문자열, 컬렉션, 맵 및 배열. HV에서 추가로 지원: CharSequence의 모든 하위 유형.

주석의 요소 값이 문자 길이, 모음 크기 등 지정된 최소 및 최대 범위(포함) 내에 있는지 확인

@Valid

모든 비원시 유형(참조 유형)

주문 객체와 같은 관련 객체 확인 계정 개체에서 주문 확인 개체

@NotEmpty

를 지정합니다. ,CharSequence, CollectionMap and Arrays

주석의 요소 값이 null이 아니고 비어 있지 않은지 확인하세요(문자열 길이가 0이 아니고 컬렉션 크기가 0이 아님).

@Range(최소=최소값, 최대=최대값)

CharSequence, Collection, Map and Arrays,BigDecimal, BigInteger, CharSequence, byte, short, int, long and the respective wrappers of the primitive types

확인 주석이 달린 요소 값이 최소값과 최대값 사이에 있습니다. ​​

@NotBlank

CharSequence

주석의 요소 값이 비어 있지 않은지 확인합니다(null이 아니고 선행 공백을 제거한 후 길이가 0임). @NotBlank는 문자열에만 적용되며 비교 시 문자열의 공백이 제거됩니다.

@Length(최소=하한, 최대=상한) 제한)

CharSequence

주석의 요소 값 길이가 최소 및 최대 간격 내에 있는지 확인

@이메일

CharSequence

주석의 요소 값이 이메일인지 확인하거나 정규식 및 플래그를 사용하여 사용자 정의 이메일 형식을 지정할 수 있습니다.

자세한 내용은 공식 문서를 참조하세요: http://docs.jboss.org/hibernate/validator/SpringMVC 학습 시리즈(6) 데이터 검증.SpringMVC 학습 시리즈(6) 데이터 검증/reference/en-US/html/validator-usingvalidator.html

참고: 이전에는 처음 SpringMVC 학습 시리즈(6) 데이터 검증SpringMVC 학습 시리즈(6) 데이터 검증개의 기사에서 샘플 코드에 주의를 기울이지 않았습니다. 당시에 업로드한 패키지와 업로드된 항목에는 왜 코드가 없었는지 모르겠습니다. .project 프로젝트 파일을 다운받은 후 eclipse로 직접 import해서 실행하거나 가상머신으로 옮기지 못해서 다시 삭제했는데, 이 샘플코드들은 백업이 안되어 있어서 그대로 남아있습니다. 새로운 동적 웹 프로젝트를 생성하고 해당 구성 파일, 컨트롤러 및 뷰를 가져옵니다. 모든 분들께 불편을 끼쳐드려 죄송합니다.

위 내용은 SpringMVC 학습 시리즈(6)의 데이터 검증 내용입니다. PHP 중국어 홈페이지(www.php.cn)!


성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
고급 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 또는 Gradle을 어떻게 사용합니까?고급 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 또는 Gradle을 어떻게 사용합니까?Mar 17, 2025 pm 05:46 PM

이 기사에서는 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 및 Gradle을 사용하여 접근 방식과 최적화 전략을 비교합니다.

적절한 버전 및 종속성 관리로 Custom Java 라이브러리 (JAR Files)를 작성하고 사용하려면 어떻게해야합니까?적절한 버전 및 종속성 관리로 Custom Java 라이브러리 (JAR Files)를 작성하고 사용하려면 어떻게해야합니까?Mar 17, 2025 pm 05:45 PM

이 기사에서는 Maven 및 Gradle과 같은 도구를 사용하여 적절한 버전 및 종속성 관리로 사용자 정의 Java 라이브러리 (JAR Files)를 작성하고 사용하는 것에 대해 설명합니다.

카페인 또는 구아바 캐시와 같은 라이브러리를 사용하여 자바 애플리케이션에서 다단계 캐싱을 구현하려면 어떻게해야합니까?카페인 또는 구아바 캐시와 같은 라이브러리를 사용하여 자바 애플리케이션에서 다단계 캐싱을 구현하려면 어떻게해야합니까?Mar 17, 2025 pm 05:44 PM

이 기사는 카페인 및 구아바 캐시를 사용하여 자바에서 다단계 캐싱을 구현하여 응용 프로그램 성능을 향상시키는 것에 대해 설명합니다. 구성 및 퇴거 정책 관리 Best Pra와 함께 설정, 통합 및 성능 이점을 다룹니다.

캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA (Java Persistence API)를 어떻게 사용하려면 어떻게해야합니까?캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA (Java Persistence API)를 어떻게 사용하려면 어떻게해야합니까?Mar 17, 2025 pm 05:43 PM

이 기사는 캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA를 사용하는 것에 대해 설명합니다. 잠재적 인 함정을 강조하면서 성능을 최적화하기위한 설정, 엔티티 매핑 및 모범 사례를 다룹니다. [159 문자]

Java의 클래스로드 메커니즘은 다른 클래스 로더 및 대표 모델을 포함하여 어떻게 작동합니까?Java의 클래스로드 메커니즘은 다른 클래스 로더 및 대표 모델을 포함하여 어떻게 작동합니까?Mar 17, 2025 pm 05:35 PM

Java의 클래스 로딩에는 부트 스트랩, 확장 및 응용 프로그램 클래스 로더가있는 계층 적 시스템을 사용하여 클래스로드, 링크 및 초기화 클래스가 포함됩니다. 학부모 위임 모델은 핵심 클래스가 먼저로드되어 사용자 정의 클래스 LOA에 영향을 미치도록합니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
1 몇 달 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구