我正在使用React Router专用路由系统。我正在通过从本地存储中获取 jwt 并在 axios承诺中针对服务器进行交叉检查来检查身份验证。
但是,专用路由似乎并不等待回调返回。 我的身份验证有误吗?还是有办法解决这个问题?
我的axios承诺会检查身份验证。
const checkAuth = (cb) => {
let token = localStorage.getItem("jwtToken");
// console.log(token);
if (token) {
axios.defaults.headers.common["Authorization"] = token;
axios
.get("api/admin/auth/profile")
.then(res => {
localStorage.setItem("admin", res.data.admin);
cb(null, res.data);
})
.catch(err => {
showErr(err, cb);
});
} else {
cb("Not authenticated", null);
}
}
设置专用路线。
const PrivateRoute = ({ component: Component, ...rest, checkAuth }) =>
(
<Route {...rest} render={(props) => (
checkAuth((isAuthenticated) => (
isAuthenticated === true
? <Component {...props} />
: <Redirect to={{
pathname: '/login',
state: { from: props.location }
}} />
))
)} />
)
答案 0 :(得分:1)
checkAuth
方法不返回任何内容。渲染函数应返回一个组件。我建议创建这样的有状态CheckAuth组件。
class CheckAuth extends React.Component {
state = {}
componentDidMount () {
this.props.checkAuth(isAuthenticated => {
this.setState({isAuthenticated})
})
}
render () {
return this.props.children({loading, isAuthenticated})
}
}
const PrivateRoute = ({ component: Component, ...rest, checkAuth }) =>
(
<Route {...rest} render={(props) =>
<CheckAuth {...props} checkAuth={checkAuth}>
{({isAuthenticated}) => (
isAuthenticated === true
? <Component {...props} />
: <Redirect to={{
pathname: '/login',
state: { from: props.location }
)}
</CheckAuth>
)}</Route>
}