inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

useMutation 으로 onError 서버에서 받은 403 message 출력

1714

minsu

작성한 질문수 27

0

안녕하세요 제로초님 제가 react-query 를 사용하고 있습니다.
Slack 에서 받은 403 메시지 (이미 사용 중인 이메일, 이미 사용 중인 아이디 입니다.)
이것을 프론트 단에서 출력 해 주고 싶습니다.
 

const { mutate } = useMutation(Sign, {
onSuccess: (data, context) => {
console.log(data);
},
onError: (data, context, error) => {
// LoginErrorMessage(err);
console.log(error);
},
});
react-query useMutation Hook 를 사용했습니다.
 
onError 으로 요청 실패하면 - Network Preview 에 왜 실패 했는 지 (사용 중인 아이디 입니다.) 문구가 나오고.
문제는 에러 메시지를 받은 error 부분에 console.log(error)로 콘솔에 출력 해 보았는데,
 
콘솔에 빈 값으로 출력됩니다.
어떻게 해야 할까요.
error 가 error.message 가 아닌가? 해서 data 도 넣어봤는 데 - onError 가 작동하면 콘솔에 빈 값으로 나옵니다.
 

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

답변 1

1

제로초(조현영)

useMutation에서 Sign 부분이 어떻게 구성되어있는 것인가요? console.dir(error) 해도 똑같이 빈칸인가요?

0

minsu

undefined 로 출력 됩니다. 

export function Sign(data: User) {
return axios.post<User>("http://localhost:3065/api/user", data, {
withCredentials: true,
});
}
 
// node 회원가입 router 입니다.
router.post("/", async (req, res, next) => {
try {
const exUser = await User.findOne({
where: {
userId: req.body.userId,
},
});
if (exUser) {
return res.status(403).send("이미 사용 중인 아이디입니다.");
}

const exNickName = await User.findOne({
where: {
nickname: req.body.nickname,
},
});

if (exNickName) {
return res.status(403).send("이미 사용 중인 닉네임 입니다.");
}

const hashedPassword = await bcrypt.hash(req.body.password, 12);

const newUser = await User.create({
nickname: req.body.nickname,
userId: req.body.userId,
password: hashedPassword,
});
return res.status(200).json(newUser);
} catch (error) {
console.log(error);
return next(error);
}
});

0

제로초(조현영)

https://stackoverflow.com/questions/64875809/react-js-react-querys-usemutation-unable-to-retrieve-the-response-from-the-ser

이것 참고하시고 toJSON한 다음에 response 접근해보세요.

기본 셋팅과 관련하여

0

106

1

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

0

109

2

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

0

165

2

useEffect 개수 관리

0

122

2

라이브러리 서치 방법

0

118

2

함수 정의 패턴

0

80

1

npm run dev 에러

0

156

3

npx webpack 후 에러

0

187

2

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

0

151

2

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

1

192

2

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

0

162

2

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

0

439

3

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

0

608

2

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

0

970

1

배포 방법

0

306

2

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

0

1010

2

alias 경로 설정 오류

0

461

2

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

0

282

1

제네릭 질문

0

225

2

ts-node 대신 tsx 사용여부

0

377

1

배포 관련 질문

0

249

1

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

0

395

2

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

0

341

1

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

0

252

2