스프링 websocket handler presend 질문 있습니다.
171
작성한 질문수 8
public Message<?> preSend(Message<?> message, MessageChannel channel) {
log.info("presend 실행은 되는지");
StompHeaderAccessor accessor = StompHeaderAccessor.wrap(message);
log.info("테스트{}",accessor.getCommand());
// // 메시지의 구독 명령이 CONNECT인 경우에만 실행
if (StompCommand.CONNECT.equals(accessor.getCommand())) {
StompHeaderAccessor headerAccessor = StompHeaderAccessor.wrap(message);
log.info("구독 명령이 떨어졌어{}",headerAccessor.getNativeHeader("test"));
}
return message;
}위 코드처럼 실행했을 시 accessor.getCommand()가 connect거나 disconnect면
log.info("presend 실행은 되는지");
StompHeaderAccessor accessor = StompHeaderAccessor.wrap(message);
log.info("테스트{}",accessor.getCommand());이것이 2번 씩 출력되는데 원래 이런건지 아니면 제가 코딩을 잘못했는지 질문있습니다.
답변 1
0
안녕하세요, 인프런 AI 인턴입니다.
Spring에서 WebSocket을 사용할 때 preSend 메소드가 예상치 못하게 두 번 호출되는 경우가 있을 수 있습니다. 이는 Spring의 내부 동작 방식에 따라 결정되는 부분이기도 하고, 코드나 구성에 따라 발생할 수도 있습니다. preSend 메소드는 메시지가 실제로 전송되기 전에 호출되며, 메시지를 수정하거나 다른 작업을 수행할 수 있는 후크 포인트를 제공합니다.
이중으로 로그가 출력된다면, 일단 두 가지 가능성을 살펴볼 수 있습니다.
클라이언트 쪽에서 CONNECT 및 DISCONNECT 프레임이 의도치 않게 두 번 전송되고 있을 수 있습니다. 이 경우에는 네트워크 트래픽을 캡쳐하거나 클라이언트 측 로직을 검토하여 확인할 수 있습니다.
서버 측에서 어떠한 이유로 같은 메시지에 대해
preSend를 두 번 호출하는 것일 수도 있습니다. 이 경우에는 서버의 코드 또는 구성을 재검토하여 문제가 되는 부분을 찾아야 합니다.
preSend가 두 번 호출되는 것이 의도된 행동인지 혹은 버그인지를 확인하려면 디버깅을 통해 추가적인 정보를 수집하고 분석해야 할 것입니다. preSend에서 같은 메시지에 대해 두 번의 호출이 일어나는 상황을 디버그해서 어떤 경로로 메소드가 실행되는지, 그리고 그 원인이 무엇인지를 확인해 보세요. Spring Framework의 rich WebSocket support 문서를 참고하면 preSend와 관련된 더 자세한 정보를 확인할 수 있습니다.
추가적으로, ‘spring-boot-starter-websocket’ 모듈의 자동 구성과 관련된 자세한 내용은 Spring Boot Reference Documentation의 WebSockets 절에서 찾아볼 수 있습니다. 이 문서에서는 Spring Boot가 제공하는 WebSocket 관련 자동 구성 및 설정에 대한 정보를 제공하고 있으니 이를 참고하시면 좋을 것 같습니다.
만약 문제가 지속된다면 더 자세한 로그 정보, 사용된 구성, 클라이언트 및 서버 측 코드의 나머지 부분 등을 함께 제공해주시면 문제 해결에 더 도움이 될 것입니다.
실무 내용 문의드려요
0
21
2
SingletonService가 JVM이 뜰 때 생성되는게 맞나요?
0
31
2
시큐리티 필터 설정 질문입니다!
2
43
1
강의가 싱크가 안맞는것 같아요..
0
29
1
임포트 오류
0
33
2
답을언제쯤받아볼수있나요
0
49
2
형 책 어떻게 받아?
1
59
1
@JsonIgnore 이후 Internal Server Error가 발생하지 않습니다.
0
33
2
mvc 패턴 - 적용 강의에서 회원가입할 때 redirect가 아닌 forward인 이유가 궁금합니다.
0
29
1
프로젝트가 없어요..
0
56
2
JpaCursorItemReader의 정렬 조건 부재의 영향
1
46
2
changeTeam 메서드 질문
0
35
1
"컴파일 시점에 없는 값을 어떻게 참조할 것인가?" 섹션
1
53
2
테스트 관련 질문!
0
53
2
handleBindException 의 기대의도가 방향이 맞는지 궁금합니다.
0
42
2
SpringBoot 4.0.6 버전에서 PackageLogTracePostProcessor exception
0
87
3
인텔리제이 오류
0
51
1
프로젝트 의존 관계
0
53
2
application.properties가 적용되지 않아요
1
69
3
새 프로젝트 속 제너레이터에 SpringBoot가 없습니다.
0
54
2
섹션3. 11 회원객체 다이어그램
0
37
1
OCP, DIP과 @Qualifier 어노테이션에 대해서 질문합니다.
0
36
1
강의 연장 요청
0
44
2
설정 정보 없이 임베디드 데이터베이스 생성
0
40
1





