我希望这是一个简单的问题:
我正在尝试在ReactJS动作创建者的try和catch语句中实现错误处理。
export const getUserKitchens = () => async dispatch => {
try{
const response = await axios.get(
`${baseURL}customer/get-user-kitchens/`,
)
dispatch({type:LOAD_USER_KITCHENS, payload: response.data})
} catch(e) {
const msg = "something"
dispatch(displayStatus(msg, true))
}
}如果请求失败,HTTP状态为401,我想注销用户。因此,我需要从catch语句访问Http响应头,并从那里检索HTTP状态。
,这有可能吗?
发布于 2019-03-05 06:36:17
e语句中的catch对象是一个错误对象。您可以使用error.response.status访问状态代码,使用error.response.headers访问标头。这样的东西应该是有用的:
export const getUserKitchens = () => async dispatch => {
try{
const response = await axios.get(
`${baseURL}customer/get-user-kitchens/`,
)
dispatch({type:LOAD_USER_KITCHENS, payload: response.data})
} catch(e) {
const status = e.response.status;
if (status === 401) {
dispatch({type:LOG_USER_OUT}) //LOG_USER_OUT is a logout action
} else {
dispatch(displayStatus(status, true))
}
}
}发布于 2019-03-05 06:31:18
等待表达式将导致异步函数执行暂停,直到承诺得到解决,即履行或拒绝,并在实现后恢复异步函数的执行。当恢复时,等待表达的价值就是履行承诺的价值。 如果承诺被拒绝,等待表达式将抛出被拒绝的值。
因此,如果存在API错误,错误对象将被抛出,您将在catch块中获得该对象,并可以使用error.response.status和error.response.headers从它访问状态和标头。
export const getUserKitchens = () => async dispatch => {
try{
const response = await axios.get(
`${baseURL}customer/get-user-kitchens/`,
)
dispatch({type:LOAD_USER_KITCHENS, payload: response.data})
} catch(e) {
const status = e.response.status;
dispatch(displayStatus(status, true))
}
}https://stackoverflow.com/questions/54996456
复制相似问题