시리즈 (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) 데이터 검증
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="*"인 경우 표시됩니다. 모델의 모든 속성. 테스트 실행: 제출을 직접 클릭하세요: 확인하려면 설정에 대한 오류 메시지가 올바르게 표시됩니다. 잘못된 데이터 제출: 설정된 오류 메시지가 여전히 올바르게 표시되는 것을 확인할 수 있습니다. 올바른 데이터를 입력하고 제출하세요. 인증이 성공한 것을 확인할 수 있습니다. 다음은 주요 확인 참고 사항 및 지침입니다. 참고 사항 해당 데이터 유형 설명 @AssertFalse 부울, 부울 확인 주석의 요소 값이 false입니다 @AssertTrue Boolean, boolean 주석의 요소 값이 true인지 확인 @DecimalMax(값=x) BigDecimal, BigInteger, String, byte, short, int , long 및 기본 유형의 해당 래퍼. HV에서 추가로 지원: Number 및 CharSequence의 모든 하위 유형 BigDecimal, BigInteger, String, byte,short, int, long 및 기본 유형의 해당 래퍼: Number 및 CharSequence의 모든 하위 유형이 추가로 지원됩니다. 🎜> 에서 지정한 값보다 작거나 같은지 확인하세요. BigDecimal, BigInteger, byte, short,int, long 및 기본 유형의 해당 래퍼. HV에서 추가로 지원: CharSequence의 모든 하위 유형(char 시퀀스로 표시되는 숫자 값은 다음과 같습니다.
평가됨), Number의 모든 하위 유형. 주석의 요소 값이 @Min @NotNull @Null @Past @Pattern(regex=regular 표현식, 플래그=) @Size(min=최소값 , max=최대값) @Valid @NotEmpty 를 지정합니다. , 주석의 요소 값이 null이 아니고 비어 있지 않은지 확인하세요(문자열 길이가 0이 아니고 컬렉션 크기가 0이 아님). @Range(최소=최소값, 최대=최대값) 확인 주석이 달린 요소 값이 최소값과 최대값 사이에 있습니다. @NotBlank 주석의 요소 값이 비어 있지 않은지 확인합니다(null이 아니고 선행 공백을 제거한 후 길이가 0임). @NotBlank는 문자열에만 적용되며 비교 시 문자열의 공백이 제거됩니다. @Length(최소=하한, 최대=상한) 제한) 주석의 요소 값 길이가 최소 및 최대 간격 내에 있는지 확인 @이메일 주석의 요소 값이 이메일인지 확인하거나 정규식 및 플래그를 사용하여 사용자 정의 이메일 형식을 지정할 수 있습니다. 자세한 내용은 공식 문서를 참조하세요: 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)!
@DecimalMin(value=x)
주석의 요소 값을 확인하세요. 정수 및 소수 자릿수 @Digits(정수=정수, 분수=소수)
BigDecimal, BigInteger, 문자열, 바이트, short, int, long 및 기본 유형의 해당 래퍼. HV에서 추가로 지원: Number 및 CharSequence의 모든 하위 유형
주석의 요소 값(날짜 유형)이 현재 시간보다 이후인지 확인 @Future
java.util .Date , java.util.Calendar; Joda Time 날짜/시간 API가 다음과 같은 경우 HV에서 추가로 지원됩니다.
클래스 경로: ReadablePartial 및ReadableInstant의 모든 구현
주석이 추가된 요소 값이 @Max @Max(value=x)
BigDecimal, BigInteger, byte, short,int, long 및 기본 유형의 해당 래퍼 . HV에서 추가로 지원됨: 모든 하위 유형 ofCharSequence(문자 시퀀스로 표시되는 숫자 값)
평가됨), Number의 모든 하위 유형.
@Min(값=x)
모든 유형
다음 요소 값이 주석이 null이 아닙니다
모든 유형
주석이 달린 요소 유효성 검사 값이 null입니다
java.util.Date, java.util .Calendar; Joda Time 날짜/시간 API가 다음과 같은 경우 HV에서 추가로 지원됩니다.
클래스 경로: ReadablePartial 및ReadableInstant의 모든 구현.
주석의 요소 값(날짜 유형)이 현재 시간보다 이전인지 확인
문자열. HV에서 추가로 지원: CharSequence의 모든 하위 유형.
주석이 달린 요소 값이 지정된 정규 표현식과 일치하는지 확인
문자열, 컬렉션, 맵 및 배열. HV에서 추가로 지원: CharSequence의 모든 하위 유형.
주석의 요소 값이 문자 길이, 모음 크기 등 지정된 최소 및 최대 범위(포함) 내에 있는지 확인
모든 비원시 유형(참조 유형)
주문 객체와 같은 관련 객체 확인 계정 개체에서 주문 확인 개체
CharSequence
, Collection
Map and Arrays
CharSequence, Collection, Map and Arrays,BigDecimal, BigInteger, CharSequence, byte, short, int, long and the respective wrappers of the primitive types
CharSequence
CharSequence
CharSequence

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

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

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

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

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


핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

드림위버 CS6
시각적 웹 개발 도구

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

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

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

WebStorm Mac 버전
유용한 JavaScript 개발 도구
