inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

코드로 배우는 React 19 with 스프링부트 API서버

로그인 성공과 실패처리 강의 중에 궁금한점이 있어 질문드립니다.(추가질문)

105

zzzzz

작성한 질문수 192

0

db

 

포스트맨:

 

에러상황: 포스트맨으로 db에 있는 email과 패스워드 입력해도 로그인이 안됩니다. 참고로 db에 있는 이메일 : user9@aaa.com 직접 db에서 수정하고 저장했습니다. 그리고 user8@aaa.com로 해도 안됩니다.

 

 

react spring-boot jpa jwt redux-toolkit

답변 2

0

구멍가게코딩단

DB에는 인코딩된 패스워드가 있어야만 합니다.

 

BCrypt는 복호화는 안되기 때문에 사용자가 넘긴 패스워드로 DB상에 있는 값이 나올 수 있는지를 확인합니다. 때문에 작성하신 것 같이 평문(1111)으로 DB에 기록되면 안됩니다.

 

인증에 실패하기 때문에 BadCredentialsException 이 발생하고 있습니다.

 

user8@aaa.com은 정상적으로 로그인이 되어야 합니다..

올려주신 코드(DB는 아님)는 정상적을 인증이 이루어지고 있습니다.

0

zzzzz

선생님 이미 db에서 pw가 긴 특수문자가 포함되어서 저장되어있는데 포스트맨에서 pw를 1111로 해도 왜 토큰이 발생되는건가요?

0

구멍가게코딩단

BCrypt로 패스워드 자체를 비교하는게 아닙니다. 1111이라는 패스워드로 DB에 있는 문자열이 생성될 수 있는지 확인하는 방식입니다.

 

이런 방식으로 API 서버 쪽에서도 사용자의 진짜 패스워드는 알 수 없게 하고 사용자는 자신의 패스워드가 어떻게 암호화되었는지 알 수 없게 하는 방식입니다.

 

예를 들어 user8@aaa.com 이고 1111이라고 전달되어도 DB의 문자열이 가능하다고 판단하면 인증이 성공하는 것이죠

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. zzzzz님.

현재 겪고 계신 문제는 스프링 시큐리티의 BCryptPasswordEncoder로 암호가 제대로 매칭되지 않는 것과 관련이 있습니다. 이 문제는 대부분 데이터베이스에 저장된 비밀번호가 올바르게 저장되지 않았거나, 암호화된 형태로 저장되지 않았기 때문에 발생할 수 있습니다.

문제의 원인과 해결책:

  1. 패스워드 저장 형식 확인:

    • 데이터베이스에 저장된 비밀번호가 BCrypt 형태로 암호화되어 있는지 확인해야 합니다. 일반 텍스트로 저장된 비밀번호는 BCryptPasswordEncoder로 매칭되지 않습니다.
  2. 암호화 과정:

    • 패스워드를 데이터베이스에 저장할 때, 반드시 BCryptPasswordEncoder를 사용하여 암호화하세요. 예를 들어, passwordEncoder.encode("1111")와 같은 방식으로 암호화된 문자열을 데이터베이스에 저장해야 합니다.
  3. 비밀번호 매칭:

    • BCryptPasswordEncoder는 내부적으로 matches(rawPassword, encodedPassword) 메서드를 사용하여 입력한 비밀번호와 저장된 비밀번호를 비교합니다. 이 과정을 올바르게 설정했는지 확인하세요.

관련된 질문과 유사한 해결법

아래의 링크는 비슷한 문제를 겪었던 다른 사용자의 질문에 대한 답변입니다. 이 답변이 문제 해결에 도움이 될 수 있습니다:
- DTO와 인증 서비스 강의 중 혼란스러움
- BCryptPasswordEncoder 사용시 발생 가능한 문제들

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

동일하게 실습하는데 이상하게 페이지를 찾지 못하네요..

0

72

2

22. REST 방식 컨트롤러 만들기(2), 29. 등록처리 부분 질문이 있습니다.

0

74

2

37강. 강의수업듣다 질문드립니다.

0

56

2

TodoDTO test 함수

0

80

3

강사님 오타 있음요

0

77

2

No 1. 교제(ppt) soruce 복붙 문제 의 건

0

94

4

No 1. 교제(ppt) soruce 복붙 문제 의 건

0

70

3

17강 문의드립니다.

0

44

1

카카오 연동설정이 이제 안되는거 같아요

0

187

2

8장 마지막 강의 시 오류

0

98

4

혹시 뭐가 문제인지 알 수 있나요?

0

87

2

챕터: React-Router 설정

0

58

2

백)TODO관련

0

56

2

마리아 db 설치중 포트를 이미 사용중이라고 합니다

0

109

2

이강의 듣고 소화시켰다면 몇년차 정도 개발자라고 할수 있을까요?

0

105

1

CSR , SSR 의 수요 궁금증 질문

0

81

2

섹션5부터...

0

71

1

간단한 코드 질문!!

0

59

2

tbl_todo 질문입니다

0

64

2

수업 외 질문인데 'tbl'이 무슨 의미인가요???

0

288

2

엔티티클래스에서 질문입니다

0

77

2

수정시 writer값이 삭제되는 오류

0

41

2

교안 31 오타 수정해주세요

0

62

2

쿠키에 accessToken, refreshToken을 담고, 조회 시에 undefined

0

78

1