개인공부/TIL(Today I Learned)
TIL 91일차_axios에서의 오류처리
soon327
2021. 4. 19. 20:53
axios를 사용하여 httml통신을 했을 때,
catch로 잡아낸 에러에 접근하는 방법은 아래와 같다.
axios.get('/user/12345')
.catch(function (error) {
if (error.response) {
// 요청이 이루어졌으며 서버가 2xx의 범위를 벗어나는 상태 코드로 응답했습니다.
console.log(error.response.data);
console.log(error.response.status);
console.log(error.response.headers);
}
else if (error.request) {
// 요청이 이루어 졌으나 응답을 받지 못했습니다.
// `error.request`는 브라우저의 XMLHttpRequest 인스턴스 또는
// Node.js의 http.ClientRequest 인스턴스입니다.
console.log(error.request);
}
else {
// 오류를 발생시킨 요청을 설정하는 중에 문제가 발생했습니다.
console.log('Error', error.message);
}
console.log(error.config);
});
config 옵션validateStatus
을 사용하여 사용자 정의 HTTP 상태 코드 오류 범위를 정의 할 수도 있다.
axios.get('/user/12345', {
validateStatus: function (status) {
// 상태 코드가 500 이상일 경우 거부. 나머지(500보다 작은)는 허용.
return status < 500;
}
})