How to Create Protected Routes with React and React Router DOM
Jan 24, 2025 am 02:29 AMWhen building web applications using React, we often need to restrict access to certain routes and only allow access to authenticated users. This article will explain how to create a protected route using React, react-router-dom and the Outlet component, and demonstrate how to verify whether the user is an administrator based on the value stored in localStorage.
What is protected routing?
Protected routes refer to pages that can only be accessed by users who meet specific conditions (such as being authenticated or having specific permissions, such as administrator permissions). If these conditions are not met, the user will be redirected to another page, such as a login page.
Prerequisites
Before you begin, please make sure:
- React has been configured in the project.
- React-router-dom installed:
npm install react-router-dom
Example: Protected routing with admin verification
This example will verify that the user is authenticated as an administrator by checking the value in localStorage. If not an administrator, redirect them to the login page.
- Routing configuration
First, configure the application’s main route.
import React from "react"; import { BrowserRouter as Router, Routes, Route } from "react-router-dom"; import Login from "./Login"; import Dashboard from "./Dashboard"; import ProtectedRoute from "./ProtectedRoute"; function App() { return ( <Router> <Routes> <Route path="/" element={<Login />} /> <Route element={<ProtectedRoute />} path="/dashboard/*"> <Route index element={<Dashboard />} /> {/* 添加index路由處理/dashboard */} </Route> </Routes> </Router> ); } export default App;
- Create ProtectedRoute component
This component verifies that the user is authenticated as an administrator before rendering the protected route. If not, redirect it to the login page.
import React from "react"; import { Navigate, Outlet } from "react-router-dom"; const ProtectedRoute = () => { // 從localStorage中檢查用戶是否為管理員 const isAdmin = localStorage.getItem("role") === "admin"; return isAdmin ? <Outlet /> : <Navigate to="/" />; }; export default ProtectedRoute;
Code explanation:
localStorage.getItem("role")
: Get the user role stored in localStorage.
If the role is "admin", the Outlet component is rendered, which represents the content of the protected route.
If not, use the Navigate component to redirect the user to the root path (/).
- Create a login page (Login) This page simulates the basic login process and stores the user role in localStorage.
import React from "react"; import { useNavigate } from "react-router-dom"; function Login() { const navigate = useNavigate(); const handleLogin = () => { // 模擬登錄并保存用戶角色 localStorage.setItem("role", "admin"); navigate("/dashboard"); }; return ( <div> {/* 登錄表單 */} <button onClick={handleLogin}>登錄</button> </div> ); } export default Login;
- Create Dashboard page
Dashboard page is a protected route and can only be accessed by users with administrator role.
import React from "react"; function Dashboard() { return ( <div> <h1>儀表盤</h1> <p>這是受保護(hù)的頁(yè)面內(nèi)容。</p> </div> ); } export default Dashboard;
Example process
User access application:
If you are not logged in, you will see the login page (/). After logging in as an administrator, the role will be stored in localStorage and redirected to Dashboard (/dashboard). In the Dashboard, protected content (statistics and configuration) is displayed.
If a user attempts to access the Dashboard directly without admin rights, they will automatically be redirected to the login page.
Summary
Protected routing is critical for applications that handle users and permissions. Using the React Router DOM, Outlet component, and browser storage (such as localStorage), we can implement a basic access restriction system. This approach is great for small applications or learning projects, but in larger projects, a stronger authentication solution is recommended.
If you have any questions, please leave a message in the comment area! ?
The above is the detailed content of How to Create Protected Routes with React and React Router DOM. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Java and JavaScript are different programming languages, each suitable for different application scenarios. Java is used for large enterprise and mobile application development, while JavaScript is mainly used for web page development.

JavaScriptcommentsareessentialformaintaining,reading,andguidingcodeexecution.1)Single-linecommentsareusedforquickexplanations.2)Multi-linecommentsexplaincomplexlogicorprovidedetaileddocumentation.3)Inlinecommentsclarifyspecificpartsofcode.Bestpractic

The following points should be noted when processing dates and time in JavaScript: 1. There are many ways to create Date objects. It is recommended to use ISO format strings to ensure compatibility; 2. Get and set time information can be obtained and set methods, and note that the month starts from 0; 3. Manually formatting dates requires strings, and third-party libraries can also be used; 4. It is recommended to use libraries that support time zones, such as Luxon. Mastering these key points can effectively avoid common mistakes.

PlacingtagsatthebottomofablogpostorwebpageservespracticalpurposesforSEO,userexperience,anddesign.1.IthelpswithSEObyallowingsearchenginestoaccesskeyword-relevanttagswithoutclutteringthemaincontent.2.Itimprovesuserexperiencebykeepingthefocusonthearticl

JavaScriptispreferredforwebdevelopment,whileJavaisbetterforlarge-scalebackendsystemsandAndroidapps.1)JavaScriptexcelsincreatinginteractivewebexperienceswithitsdynamicnatureandDOMmanipulation.2)Javaoffersstrongtypingandobject-orientedfeatures,idealfor

JavaScripthassevenfundamentaldatatypes:number,string,boolean,undefined,null,object,andsymbol.1)Numbersuseadouble-precisionformat,usefulforwidevaluerangesbutbecautiouswithfloating-pointarithmetic.2)Stringsareimmutable,useefficientconcatenationmethodsf

Event capture and bubble are two stages of event propagation in DOM. Capture is from the top layer to the target element, and bubble is from the target element to the top layer. 1. Event capture is implemented by setting the useCapture parameter of addEventListener to true; 2. Event bubble is the default behavior, useCapture is set to false or omitted; 3. Event propagation can be used to prevent event propagation; 4. Event bubbling supports event delegation to improve dynamic content processing efficiency; 5. Capture can be used to intercept events in advance, such as logging or error processing. Understanding these two phases helps to accurately control the timing and how JavaScript responds to user operations.

Java and JavaScript are different programming languages. 1.Java is a statically typed and compiled language, suitable for enterprise applications and large systems. 2. JavaScript is a dynamic type and interpreted language, mainly used for web interaction and front-end development.
