Ce code, qui utilise le DOM du routeur React et stocke les réponses dans localStorage, devrait créer un itinéraire protégé qui permet aux utilisateurs de continuer à afficher leurs informations une fois de retour sur la page. Une fois connectés, ils doivent être redirigés vers la page du tableau de bord, mais la mise en œuvre ne parvient pas à y parvenir.
Page d'itinéraire
import React, { useContext } from "react"; import { globalC } from "./context"; import { Route, Switch,BrowserRouter } from "react-router-dom"; import About from "./About"; import Dashboard from "./Dashboard"; import Login from "./Login"; import PageNotFound from "./PageNotFound"; function Routes() { const { authLogin } = useContext(globalC); console.log("authLogin", authLogin); return ( <BrowserRouter> <Switch> {authLogin ? ( <> <Route path="/dashboard" component={Dashboard} exact /> <Route exact path="/About" component={About} /> </> ) : ( <Route path="/" component={Login} exact /> )} <Route component={PageNotFound} /> </Switch> </BrowserRouter> ); } export default Routes;
Page de contexte
import React, { Component, createContext } from "react"; import axios from "axios"; export const globalC = createContext(); export class Gprov extends Component { state = { authLogin: null, authLoginerror: null, }; componentDidMount() { var localData = JSON.parse(localStorage.getItem("loginDetail")); if (localData) { this.setState({ authLogin: localData, }); } } loginData = async () => { let payload = { token: "ctz43XoULrgv_0p1pvq7tA", data: { name: "nameFirst", email: "internetEmail", phone: "phoneHome", _repeat: 300, }, }; await axios .post(`https://app.fakejson.com/q`, payload) .then((res) => { if (res.status === 200) { this.setState({ authLogin: res.data, }); localStorage.setItem("loginDetail", JSON.stringify(res.data)); } }) .catch((err) => this.setState({ authLoginerror: err, }) ); }; render() { // console.log(localStorage.getItem("loginDetail")); } }
1. React Router DOM v6
Dans la version 6, utilisez un composant de mise en page d'authentification au lieu de composants de route personnalisés :
import { Navigate, Outlet } from 'react-router-dom'; const PrivateRoutes = () => { const { authLogin } = useContext(globalC); if (authLogin === undefined) { return null; // or loading indicator/spinner/etc } return authLogin ? <Outlet /> : <Navigate to='/login' replace state={{ from: location }} />; }
Mettez à jour vos routes :
<BrowserRouter> <Routes> <Route path='/' element={<PrivateRoutes />} > <Route path='dashboard' element={<Dashboard />} /> <Route path='about' element={<About />} /> </Route> <Route path='/login' element={<Login />} /> <Route path='*' element={<PageNotFound />} /> </Routes> </BrowserRouter>
2. React Router DOM v5
En version 5, créez un composant PrivateRoute :
const PrivateRoute = (props) => { const { authLogin } = useContext(globalC); if (authLogin === undefined) { return null; // or loading indicator/spinner/etc } return authLogin ? ( <Route {...props} /> ) : ( <Redirect to={{ pathname: '/login', state: { from: location } }} /> ); };
Mettez à jour votre composant de connexion :
export default function Login() { const { authLogin, loginData } = useContext(globalC); const location = useLocation(); const history = useHistory(); useEffect(() => { if (authLogin) { const { from } = location.state || { from: { pathname: '/' } }; history.replace(from); } }, [authLogin, history, location]); return ( ... ); }
Mettez à jour vos routes :
function Routes() { return ( <BrowserRouter> <Switch> <PrivateRoute path='/dashboard' component={Dashboard} /> <PrivateRoute path='/About' component={About} /> <Route path='/login' component={Login} /> <Route component={PageNotFound} /> </Switch> </BrowserRouter> ); }
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!