인프런 커뮤니티 질문&답변

인아님의 프로필 이미지

작성한 질문수

스프링 입문 - 코드로 배우는 스프링 부트, 웹 MVC, DB 접근 기술

회원 웹 기능 - 조회

memberList (NullPointerException) 오류 질문 드립니다

작성

·

381

1

[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? 예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? 예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? 예

[질문 내용]
안녕하세요!
선생님 강의로 Java Spring Boot 기초를 다지고 있는
신입 개발자입니다.
먼저, 이런 고퀄리티 강의를 인프런을 통해 접하게 된 것에
큰 기쁨을 느낍니다! 선생님 강의를 보며 Spring 길을
따라가고 있는데요.
 
[회원 웹 기능 - 조회 부분]에서
`java.lang.NullPointerException: null` 에러가 발생했습니다.
로그를 따라가 보면
`MemoryMemberRepository`, `MemberService`, `MemberController` 순으로 로그가 찍힙니다.
 
[에러가 발생하는 지점]은,
1. "home"에서 회원 등록 후 "home"으로 리다이렉트
2. 리다이렉트 후 다시 회원 등록시 입니다.
- home.html ["This application has no explicit mapping for /error, so you are seeing this as a fallback."]
- Terminal ["java.lang.NullPointerException: null"]
 
[시도해본 방법]
java.lang.NullPointerException: null 에러를 구글링 하여
문제가 무엇인지 파악하려고 노력했습니다.
1. `MemberService.java` 회원가입 부분
findByName.ifPresent => validateDuplicateMember
{findByName} 으로 변경하여 시도하였습니다.
 
2. try ~ catch 추가하여 NPE가 발생하지 않도록 수정하여 시도하였습니다.
 
하지만 문제를 파악하지 못했습니다.
제 얕은 자바 지식 때문입니다 :( ...
 
제 소스의 링크입니다.
살펴봐 주시면 정말 감사할 것 같습니다 ㅠㅠ

프로젝트압축링크

 

답변 1

4

안녕하세요. Inah님, 공식 서포터즈 OMG입니다.

프로젝트 코드 확인해보았습니다.

말씀하신대로 NPE가 발생하더라구요, NPE가 발생할 때 보통 어디서 NPE가 발생하는지 에러메시지에 포함되어 있습니다.

지금 보시면 findByName 쪽에서 문제가 발생한 것 같네요.

디버깅 모드 실행하여 해당 코드 구현부까지 가봤습니다.

 

 

파라미터 name 옆에 null이라고 출력된 것이 보일꺼에요, 해당 findByName을 호출하는 코드를 찾아보았습니다.

 

 

memberRepository.findByName(member.getName())

member의 getter 코드는 문제 없어 보여서 findByName을 호출 하는 memberService 전 코드는 Controller 코드를 확인해보았습니다.

 

 

form 객체의 name 11은 잘 들어온 것 같아

Member member = new Member();
member.setName(form.getName());

Member의 setter를 보니 setter의 구현코드가 비어있는 것을 확인하였습니다.

 

setter의 내용을 아래와 같이 채워주세요.

코드를 추가하면 정상작동하는 것 까지 확인하였습니다.

public void setName(String spring) {
this.name = spring;
}

감사합니다.

 

 

인아님의 프로필 이미지
인아
질문자

아 ㅠㅠㅠㅜㅜ 주말 내내 찾아봤는데도 못 찾았어요.. 사람을 살리셨네요 OMG님....ㅠㅠ 정말 감사합니다 코드 작성 할 때에 더 유의하며 작성해야 겠네요

정말 감사합니다!!

인아님의 프로필 이미지

작성한 질문수

질문하기