網(wǎng)站首頁 編程語言 正文
正文
在 react 中做路由權(quán)限管理,一直是比較麻煩的事,不像 vue 中有進入路由前攔截的功能。在摸魚時間擼了一個傻瓜式配置的路由權(quán)限 library (基于 react-router v6)。
react-router v6 文檔地址
react-router-auth-plus github 地址
如何使用
1. 配置路由
import { AuthRouterObject } from "react-router-auth-plus"; const routers: AuthRouterObject[] = [ { path: "/", element: <Navigate to="/home" replace /> }, { path: "/login", element: <Login /> }, { element: <Layout />, children: [ { path: "/home", element: <Home />, auth: ["admin"] }, { path: "/setting", element: <Setting /> }, { path: "/application", element: <Application />, auth: ["application"], }, ], }, { path: "*", element: <NotFound /> }, ];
2. 在應(yīng)用的最外層渲染路由
這里我使用 swr 來模擬獲取當前用戶的權(quán)限,兩秒后返回。
// App.tsx import { useAuthRouters } from "react-router-auth-plus"; const fetcher = async (url: string): Promise<string[]> => await new Promise((resolve) => { setTimeout(() => { resolve(["admin"]); }, 2000); }); function App() { const { data: auth, isValidating } = useSWR("/api/user", fetcher, { revalidateOnFocus: false, }); return useAuthRouters({ // 當前用戶的權(quán)限,string[] auth: auth || [], routers, // 跳轉(zhuǎn)到?jīng)]權(quán)限的路由時,用戶自定義顯示。這里我顯示 403 頁面。 noAuthElement: (router) => <NotAuth />, // 用戶權(quán)限還沒請求到時,渲染 loading render: (element) => (isValidating ? element : <Loading />), }); }
或你可以使用 jsx 的方式來配置
import { AuthRoute, createAuthRoutesFromChildren } from "react-router-auth-plus"; useAuthRouters({ auth: auth || [], noAuthElement: (router) => <NotAuth />, render: (element) => (isValidating ? element : <Loading />), routers: createAuthRoutesFromChildren( <Routes> <AuthRoute path="/" element={<Navigate to="/home" replace />} /> <AuthRoute path="/login" element={<Login />} /> <AuthRoute element={<Layout />}> <AuthRoute path="/home" element={<Home />} auth={["admin"]} /> <AuthRoute path="/setting" element={<Setting />} /> <AuthRoute path="/application" element={<Application />} auth={["application"]} /> </AuthRoute> <AuthRoute path="*" element={<NotFound />} /> </Routes> ), });
這樣就完成了,是不是很傻瓜式呢?
權(quán)限說明
若當前 home 的權(quán)限被設(shè)置為 ["auth1", "auth2", "auth3"]
,當前用戶的權(quán)限只要滿足一個就會判斷為擁有此路由的權(quán)限。
動態(tài)菜單
react-router-auth-plus
會自動將 children 傳給 Layout,你不必在路由配置里傳給 Layout。如果你是 ts,將 routers 類型設(shè)置為可選即可。
useAuthMenus
會過濾掉沒有權(quán)限的路由,接下來你可以自行處理一下成你想要的數(shù)據(jù)再渲染成 antd 的 Menu 組件。
import { useAuthMenus, AuthRouterObject } from "react-router-auth-plus"; interface LayoutProps { routers?: AuthRouterObject; } const Layout:FC<LayoutProps> = ({ routers }) => { const menus = useAuthMenus(routers); ... }
原文鏈接:https://juejin.cn/post/7122662408149008414
相關(guān)推薦
- 2022-05-29 Python實現(xiàn)灰色關(guān)聯(lián)分析與結(jié)果可視化的詳細代碼_python
- 2022-04-09 windows一鍵啟動多個bat批處理文件或者啟動多個cmd窗口執(zhí)行命令
- 2021-12-19 Redis中緩存穿透/擊穿/雪崩問題和解決方法_Redis
- 2022-05-13 C++ 使用Poco庫實現(xiàn)XML的讀取和寫入
- 2022-01-18 正則——16進制顏色
- 2021-12-28 Android中實現(xiàn)視差滾動示例介紹_Android
- 2022-08-13 Redis 性能影響 - 異步機制和響應(yīng)延遲
- 2022-07-21 C#?PDF轉(zhuǎn)圖片(JPG,Png)的項目實踐_C#教程
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學(xué)習環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支