작성
·
73
0
학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.
1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)
질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? 예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? 예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? 예
[질문 내용]
service에 한해서만 apo를등록해보았는데요, 서비스뿐만아니라 모든 메서드에서 2번호출이 일어나는데 이건 웹에서 2번호출을 한거라고 보면될까요?
조회 페이지 버튼을 눌렀을때 디버깅을 찍어봤는데 MemberService의 findMember메서드에 2번 들어오더라고요
답변 2
0
안녕하세요, 인프런 AI 인턴입니다. company CHOI님.
질문해주신 내용과 관련된 정보를 찾아보았고, 서비스 메서드가 2번 호출되는 현상에 대해 두 개의 원인과 해결 방법을 추천드립니다.
먼저, 로그에 나온 내용을 보면 MemberService
의 findMember()
메서드가 두 번 호출된 것을 알 수 있습니다. 이는 다음과 같은 이유로 인해서 발생할 수 있습니다.
아래의 유사한 질문과 답변을 참고하여 문제를 해결해 보세요.
전체 회원 다 뜨는거 말고 원하는 아이디만 찾을때 어떻게 해야 할까요?
해당 질문에서는 메서드 호출과 관련된 여러 사례와 문제 해결을 다루고 있습니다. 중복 호출 문제도 비슷한 맥락에서 다룰 수 있습니다.
여러가지 오류를 만나다, 해결을 하였지만 소스 중에서 이해가 되지 않는 부분이 있어 작성하게 되었습니다.
메서드 호출과 예외 처리는 다양한 원인에 의해 발생할 수 있으며, 이를 통해 디버깅하는 팁을 얻을 수 있습니다.
ProxyCreator
가 잘못 설정된 경우 메서드가 중첩 호출될 수 있습니다.@Aspect
@Component
public class LoggingAspect {
@Before("execution(* com.example.hellospring.service.*.*(..))")
public void logBefore(JoinPoint joinPoint) {
// AOP 설정 코드
}
}
추가적인 디버깅이 필요하다면, 서비스 메서드뿐 아니라 해당 API를 호출하는 부분도 함께 체크해 보시는 것이 좋습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.