inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

findMembers() NullPointerException

752

christinekang0123

작성한 질문수 1

0

AOP까지 학습 마친 상태인데 갑자기 member 목록을 보려고 하면 NullPointerException이 뜹니다. 

MemberController에 있는 this.memberService가 null이라고 하는데 왜 그런지 잘 모르겠습니다. 

java.lang.NullPointerException: Cannot invoke "hello.hellospring.service.MemberService.findMembers()" because "this.memberService" is null

at hello.hellospring.controller.MemberController.list(MemberController.java:40) ~[classes/:na]

@Controller
public class MemberController {

    private final MemberService memberService;

    @Autowired   //Dependency Injection
    public MemberController(MemberService memberService) {
        this.memberService = memberService;
    }

    @GetMapping("/members/new")
    public String createForm() {
        return "members/createMemberForm";
    }

    @PostMapping("/members/new")
    public String create(MemberForm form) {
        Member member = new Member();
        member.setName(form.getName());

        memberService.join(member);

        return "redirect:/";
    }

    @GetMapping("/members")
    private String list(Model model) {
        List<Member> members = memberService.findMembers();
        model.addAttribute("members", members);
        return "members/memberList";
    }
}

spring spring-boot java MVC

답변 2

1

christinekang0123

https://drive.google.com/file/d/1-56z2OwhgOWWX6GUn3tW-d0MZkFC0OGR/view?usp=sharing

Configuration에는 MemberService가 추가되어있고 

MemberService에 @Service를 달면 APPLICATION FAILED TO START가 뜹니다. 

Description:

The bean 'memberService', defined in class path resource [hello/hellospring/SpringConfig.class], could not be registered. A bean with that name has already been defined in file [C:\Users\강수아\Downloads\hello-spring\hello-spring\out\production\classes\hello\hellospring\service\MemberService.class] and overriding is disabled.

Action:

Consider renaming one of the beans or enabling overriding by setting spring.main.allow-bean-definition-overriding=true

0

나무늘보

안녕하세요 christinekang0123님!

전체 코드를 다운받아 확인하고 있으나 명확한 문제점을 찾지 못하고 있습니다.

TimeTraceAop 를 제거하고 실행하면 정상적으로 실행되나,

이 AOP 클래스를 적용하면 문제가 발생하고 있네요.

우선 이 부분은 지속적으로 확인해보겠사오니

다음 강의를 진행해주시기 바랍니다.

답변이 늦어져 죄송합니다.

0

나무늘보

안녕하세요 christinekang0123님!

원인을 찾았습니다.

해당 프로젝트의 list() 메서드의 접근제어자를 private에서 public으로 변경해주시기 바랍니다.

감사합니다. :)

0

나무늘보

안녕하세요, christinekang0123 님. 공식 서포터즈 codesweaver 입니다.
.
MemberService에 @Service 애노테이션이 붙어있는지 확인해주시기 바랍니다.

혹은 @Configuration에서 MemberService가 등록되어있는지 확인해주시기 바랍니다.

문제가 해결되지 않으시면 프로젝트 전체를 압축해서 구글 드라이브에 올리신 후 링크를 남겨주시면 전체 코드를 확인해보도록 하겠습니다.

.
감사합니다.

0

christinekang0123

코드 확인하신 후 답변은 언제 받을 수 있을까요...??

0

나무늘보

안녕하세요 christinekang0123님 답변이 늦어져 죄송합니다.

조속히 확인하여 답변 드리도록 하겠습니다.

인텔리제이 오류

0

50

1

..

0

113

2

Unused property.....

0

121

2

project JDK is misconfigured

0

165

2

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

0

102

2

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

0

103

2

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

0

256

1

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

0

125

2

윈도우 build test오류 질문

1

123

2

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

0

112

2

테스트 실행 시 에러 질문

0

315

1

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

0

82

1

빌드 후 libs 없음

1

149

1

윈도우 gradlew.bat 에러

0

186

1

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

0

98

1

java static class와 kotlin class

0

89

1

스프링 DB연결

0

145

1

소요 시간

0

96

2

ddl.sql에 빨간 밑줄

1

118

2

welcome page 에러

0

201

3

잘 모르겠습니다.

0

173

2

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

0

173

2

index.html Welcome page

0

137

1

프로젝트 gradle-groovy ?

0

403

1