inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

Slack 클론 코딩[실시간 채팅 with React]

socket.io 전용 훅스 만들기

로그아웃 시 useSocket 에러발생

258

Joy Lee

작성한 질문수 13

0

기존 에는 로그아웃을 하면 로그인 페이지로 바로 이동을 했는데 useSocket 훅스를 추가하고 나서 로그아웃을 하면 위처럼 useSocket에러가 생기네요 ㅠㅠ 뭐가 잘못된건지 잘 모르겠어서 질문남깁니다!

아래는 useSocket 코드랑 로그아웃 코드입니다..

 
import { io, Socket } from 'socket.io-client';

const backUrl = 'http://localhost:3095';
const sockets: { [key: string]: Socket } = {};

function useSocket(workspace?: string): [Socket | undefined, () => void] {
  const disconnect = () => {
    if (workspace) {
      sockets[workspace].disconnect();
      delete sockets[workspace];
    }
};
  if (!workspace) return [undefined, disconnect];
  if (!sockets[workspace]) {
    sockets[workspace] = io(`${backUrl}/ws-${workspace}`, {
      transports: ['websocket'], // without polling http
    });
}
  return [sockets[workspace], disconnect];
}
export default useSocket;
 
  const handleLogout = () => {
    axios
      .post('/api/users/logout', null, {
        withCredentials: true,
      })
      .then(() => {
        mutate(false, false);
        navigate('/login');
      });
};
 

+)

 
  // useEffect(() => {
  //   return () => {
  //     disconnect();
  //   };
  // }, [workspace, disconnect]);
 

워크스페이스 컴포넌트에 useEffect로 disconnect() 했던것을 주석처리하니 로그아웃 에러는 사라졌습니다!

그외에도 로그인 시 접속중인 유저를 바로 못 불러오고 여러번 새로고침을 해야 겨우 접송중 유저 불러오기에 성공하곤 했었는데 저 useEffect를 주석처리하니 그 에러 역시 고쳐졌습니다.

disconnect() 코드가 왜 그런 에러들을 발생시킨건지,, 코드 주석처리 없이 에러 해결을 하려면 어떻게 해야할지 아이디어 주시면 감사드리겠습니다 😭

https://github.com/devjoylee/slack

Socket.io babel 웹팩 typescript react 클론코딩

답변 1

0

제로초(조현영)

if (workspace && sockets[workspace]) 

로 수정하면 되긴 할텐데 원래는 없어도 되야 하는만큼 코드상에 문제가 있는것 같긴 합니다.

기본 셋팅과 관련하여

0

109

1

초기 셋팅 back과 front만 남겨두고 다 지운 후 진행 방법

0

110

2

focus 시에만 화면 업데이트 되는 이유 + 해결방법

0

167

2

useEffect 개수 관리

0

123

2

라이브러리 서치 방법

0

118

2

함수 정의 패턴

0

81

1

npm run dev 에러

0

157

3

npx webpack 후 에러

0

190

2

'void' 형식 식의 truthiness를 테스트할 수 없습니다.ts(1345)

0

154

2

사용자 가입시 에러발생 (TypeError: Cannot read properties of null (reading 'addMembers')

1

193

2

초기세팅중 packge.json 에러떠요

0

163

2

CORS - Access-Control-Allow-Origin 누락 문제

0

440

3

로그인 페이지 무한 새로고침 현상

0

610

2

Module not found: Error: Can't resolve './App' 에러

0

971

1

배포 방법

0

307

2

npm run dev 시 빌드가 매우 느려졌습니다

0

1017

2

alias 경로 설정 오류

0

463

2

fetcher 함수의 data 값이 두번 찍히는 이유

0

284

1

제네릭 질문

0

227

2

ts-node 대신 tsx 사용여부

0

380

1

배포 관련 질문

0

249

1

[nginx + https] 서비스를 실행하면 niginx가 아닌 서비스 화면을 보여주게 하고 싶습니다.

0

396

2

[배포하기] webpack에 aws 퍼블릭 IPv4 주소 와 포트 주소를 작성하고 나서 빌드후 실행하면 오류가 발생합니다.

0

343

1

users 호출 시 쿠키가 담기지 않는 이슈 질문드립니다.

0

255

2