인프런 커뮤니티 질문&답변
memberList (NullPointerException) 오류 질문 드립니다
작성
·
496
1
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? 예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? 예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? 예
[질문 내용]
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님....ㅠㅠ 정말 감사합니다 코드 작성 할 때에 더 유의하며 작성해야 겠네요
정말 감사합니다!!