security 없이 암호화 하기(단방향은 다 HASH) → 복호화 불가능
라이브러리 설치
// https://mvnrepository.com/artifact/org.mindrot/jbcrypt implementation group: 'org.mindrot', name: 'jbcrypt', version: '0.4'
회원가입
코드 작성
data:image/s3,"s3://crabby-images/ce95e/ce95e63ecc1e0f5153f4757aa716fd7c3422d9c2" alt="notion image"
테스트 코드 작성
data:image/s3,"s3://crabby-images/59d8f/59d8f8489b7172832cd7f0b464da3a59bbe516d1" alt="notion image"
salt 오류 발생 다시 테스트
data:image/s3,"s3://crabby-images/28639/28639f13e97081a06d0be191f514921e55a275c4" alt="notion image"
data:image/s3,"s3://crabby-images/e27c6/e27c66b3b17e481545adee358a0866f764f7b99c" alt="notion image"
코드 수정
@PostMapping("/join") public String join(UserRequest.JoinDTO requestDTO) { // @ResponseBody를 적으면 파일을 반환하는것이 아니라 메시지를 반환한다. System.out.println(requestDTO); String rawPassword = requestDTO.getPassword(); String encPassword = BCrypt.hashpw(rawPassword,BCrypt.gensalt()); requestDTO.setPassword(encPassword); // 1. 유효성 검사 if (requestDTO.getUsername().length() < 3) { return "error/400"; } // 2.동일 username 체크 (나중에 하나의 트랜잭션으로 묶는게 좋다.) User user = userRepository.findByUsername(requestDTO.getUsername()); try{ userRepository.save(requestDTO); }catch (Exception e){ throw new RuntimeException("아이디가 중복되었어요"); } return "redirect:/loginForm"; }
더미 데이터 수정
insert into user_tb(username, password, email, created_at) values('ssar', '$2a$10$NU03go6lJRh9RRUHvmrjwuAKOJsG6/Q/scvGtOwPOu7TDUbqnP2oK', 'ssar@nate.com', now()); insert into user_tb(username, password, email, created_at) values('cos', '$2a$10$NU03go6lJRh9RRUHvmrjwuAKOJsG6/Q/scvGtOwPOu7TDUbqnP2oK', 'cos@nate.com', now());
로그인시에는 암호화를 하지 않기 때문에 로그인은 아직 불가능
로그인
암호화 되기전 패스워드를 암호화하면 매번 다른 값이 나옴
BCrypt.checkpw(로그인패스워드, 데이터베이스에 있는 패스워드) → 비교해주는 메서드 제공
data:image/s3,"s3://crabby-images/b8ab8/b8ab8de7cfce418615b921b7467922861642e4e9" alt="notion image"
data:image/s3,"s3://crabby-images/50ec5/50ec59c2e4ecc1eb7ed928e43057e08ec6a321eb" alt="notion image"
코드 작성
암호화 돼었기 때문에 Password로 조회 불가능 하므로 코드 수정
data:image/s3,"s3://crabby-images/07ada/07ada92468775adaaefbcc9931908295b037955f" alt="notion image"
findByUsername
data:image/s3,"s3://crabby-images/c3122/c312242c41d50a8b3ce54593c048d18deb955cec" alt="notion image"
검증 실패시 코드 작성
data:image/s3,"s3://crabby-images/85cb3/85cb3f927bd459f8c8dd0ed602821bd63d75557b" alt="notion image"
정상 작동 확인하기
회원가입
data:image/s3,"s3://crabby-images/20227/20227709254edb926c1192902f2ed0367786de35" alt="notion image"
data:image/s3,"s3://crabby-images/6253a/6253a54465941eb2083a5ba8eff7ca728f560712" alt="notion image"
Share article