inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

회원 웹 기능 - 조회

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

517

인아

작성한 질문수 1

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가 발생하지 않도록 수정하여 시도하였습니다.
 
하지만 문제를 파악하지 못했습니다.
제 얕은 자바 지식 때문입니다 :( ...
 
제 소스의 링크입니다.
살펴봐 주시면 정말 감사할 것 같습니다 ㅠㅠ

프로젝트압축링크

 

nullpointerexception spring java spring-boot MVC

답변 1

4

OMG

안녕하세요. 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;
}

감사합니다.

 

 

1

인아

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

정말 감사합니다!!

..

0

87

2

Unused property.....

0

106

2

project JDK is misconfigured

0

142

2

외부 API의 ID 타입(String/UUID)과 내부 도메인의 ID 타입(Long)이 불일치할 때의 설계 정석

0

89

2

단위/통합 테스트 버전충돌 문제

0

92

2

❗️springboot 4.0.2 버전 aspectj dependency 설정❗️

0

238

1

왜 컨트롤러는 변한게 없는데 새로 만든 html 파일이 뜨나요?

0

109

2

윈도우 build test오류 질문

1

106

2

테스트 관련 공부에 대한 조언을 얻고 싶습니다

0

103

2

테스트 실행 시 에러 질문

0

302

1

name을 통한 비교와 객체를 통한 비교

0

77

1

빌드 후 libs 없음

1

134

1

윈도우 gradlew.bat 에러

0

171

1

@PostMapping("/members/new")가 동작하지 않습니다

0

93

1

java static class와 kotlin class

0

83

1

스프링 DB연결

0

129

1

소요 시간

0

89

2

ddl.sql에 빨간 밑줄

1

104

2

welcome page 에러

0

187

3

잘 모르겠습니다.

0

167

2

fail을 똑같이 쳤는데 오류가 발생해요

0

163

2

index.html Welcome page

0

129

1

프로젝트 gradle-groovy ?

0

386

1

테스트코드 메서드명 한글

0

207

2