빈 검증 - 비밀번호 변경

비밀번호 검증에 '빈 검증'을 사용하려면 비밀번호를 위한 클래스를 만들어야 한다.

Password.java
package net.java_school.user;

import javax.validation.constraints.Size;

public class Password {

  @Size(min=4, message="패스워드는 4자 이상이어야 합니다.")
  private String currentPasswd;
    
  @Size(min=4, message="패스워드는 4자 이상이어야 합니다.")
  private String newPasswd;

  public String getCurrentPasswd() {
    return currentPasswd;
  }
  public void setCurrentPasswd(String currentPasswd) {
    this.currentPasswd = currentPasswd;
  }
  public String getNewPasswd() {
    return newPasswd;
  }
  public void setNewPasswd(String newPasswd) {
    this.newPasswd = newPasswd;
  }
}

비밀번호 페이지로 포워딩하는 요청 핸들러 메소드(아래 첫 번째 changePasswd() 메소드)에 내용이 없는 빈 객체(Password 객체)를 생성해 뷰에 전달해야 한다. 이건 스펙이니 따라야 한다. 비밀번호 변경을 처리하는 요청 핸들러 메소드(아래 두 번재 changePasswd() 메소드)에 빈 검증 로직을 추가한다. 두 번째 changePasswd() 메소드의 매개 변수 리스트에서 @Valid 어노테이션이 적용된 매개 변수 다음에는 반드시 BindingResult 타입의 매개 변수를 선언해야 한다. 그렇지 않으면 HTTP 400 에러가 발생한다.

UsersController.java
@RequestMapping(value="/changePasswd", method=RequestMethod.GET)
public String changePasswd(Principal principal, Model model) {
  User user = userService.getUser(principal.getName());
  model.addAttribute("user", user);//아래 테스트 화면처럼 홍길동 11111111을 출력하기 위해 필요
  model.addAttribute("password", new Password());
   
  return "users/changePasswd";
}

@RequestMapping(value="/changePasswd", method=RequestMethod.POST)
public String changePasswd(@Valid Password password,
      BindingResult bindingResult,
      Model model,
      Principal principal) {

  if (bindingResult.hasErrors()) {
    User user = userService.getUser(principal.getName());
    model.addAttribute("user", user);//아래 테스트 화면처럼 홍길동 11111111을 출력하기 위해 필요
    return "users/changePasswd";
  }
    
  int check = userService.changePasswd(password.getCurrentPasswd(),
      password.getNewPasswd(), principal.getName());
    
  if (check < 1) {
    throw new RuntimeException(WebContants.CHANGE_PASSWORD_FAIL);
  }

  return "redirect:/users/changePasswd_confirm";
}

아래를 참고하여 JSP를 수정한다. <sf:errors> 태그는 사용자에게 검증 에러를 표시하는 스프링 폼 태그이다.

changePasswd.jsp
<%@ taglib uri="http://www.springframework.org/tags/form" prefix="sf" %>

<sf:form id="changePasswordForm" action="changePasswd" method="post"
      modelAttribute="password" onsubmit="return check();">
<table>
<tr>
  <td>현재 비밀번호</td>
  <td>
    <sf:password path="currentPasswd" /><br />
    <sf:errors path="currentPasswd" cssClass="error" />
  </td>
</tr>
<tr>
  <td>변경 비밀번호</td>
  <td>
    <sf:password path="newPasswd" /><br />
    <sf:errors path="newPasswd" cssClass="error" />
  </td>
</tr>
<tr>
  <td>변경 비밀번호 확인</td>
  <td>
    <input type="password" name="confirm" />
  </td>
</tr>
<tr>
  <td colspan="2"><input type="submit" value="전송" /></td>
</tr>
</table>
</sf:form>

아래는 비밀번호 변경 화면에서 아무것도 입력하지 않고 전송 버튼을 눌렀을 때의 화면이다. (스타일시트에 .error { color: red; }가 추가되어 있어야 한다.) 비밀번호 변경 화면
빈 검증 실패

참고