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

심우민님의 프로필 이미지

작성한 질문수

실전! 스프링 부트와 JPA 활용2 - API 개발과 성능 최적화

회원 등록 API

MemberService 관련 질문드립니다.

해결된 질문

작성

·

72

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

안녕하세요! 항상 좋은 강의 감사드립니다.

image.png

v2 버전의 경우 Controller에서 request를 받아서 Member 로 변환 후 service에 넘겨주셨는데 memberService.join(member)

memberService.join(request) 처럼 request를 바로 넘기기고 서비스에서 엔티티로 변환시켜도 상관 없을까요?

보통 실무에서는 어떤식으로 진행되는지 질문드립니다!

답변 1

0

안녕하세요. 심우민님, 공식 서포터즈 y2gcoder입니다.

정답이 있는 것은 아니나, 레이어드 아키텍처에서는 보통 의존성이 단방향으로 흐르게 하는 것을 중요시합니다 🙂

예를 들어 서비스에 넘겨주려는 객체가 비즈니스 혹은 애플리케이션 레이어에 있는 객체라면 괜찮습니다. 왜냐하면 이미 컨트롤러 단에서 서비스에 의존하고 있는 상태이기 때문입니다. 그러나 서비스에 넘겨주려는 객체가 프레젠테이션 레이어에 있는 객체라면 좋지 않다 생각합니다. 그러면 서비스 에서는 프레젠테이션 레이어에 있는 객체에 대해서 의존하게 되고, 결과적으로 프레젠테이션 <-> 비즈니스(애플리케이션) 간에 양방향 의존성이 생기기 때문입니다.

실무에서는 다양한 상황이 있을 수 있으나 최소한 위의 규칙은 지켜서 컨트롤러와 같은 레이어 에 있는 객체를 넘겨주는게 아니라 서비스 레이어에 있는 DTO를 만들어 넘겨주거나 하는 식으로 푸는 것 같습니다 🙂
아니면 간단한 프로젝트라면 request에 있는 객체를 서비스 레이어에서 만들기도 하는 것 같습니다.

 

감사합니다.