视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
React-Router如何进行页面权限管理的方法
2020-11-27 22:24:10 责编:小采
文档

前言

在一个复杂的SAP应用中,我们可能需要根据用户的角色控制用户进行页面的权限,甚至在用户进入系统之前就进行权限的控制。本文就此一权限控制进行讨论。本文假设读者了解React和React-Router的相关使用。

从传统的Router开始

一个传统的路由大概长下边这个样式,这是没有添加任何权限的。

export default (store) => {
 const history = syncHistoryWithStore(hashHistory, store);
 return (
 <Router history={history}>
 <Route path="/" component={AppRoot} >
 <IndexRoute component={IndexPage} />
 <Route path="photo" component={PhotoPage} />
 <Route path="info" component={InfoPage} />
 </Route>
 {/* <Redirect path="*" to="/error" /> */}
 </Router>
 )
}

这里一共有3个页面 IndexPage, PhotoPage,InfoPage。

添加第一个权限

假设我们需要在用户进入PhotoPage之前需要验证用户是否有权限,根据store的的一个状态去判断。

先添加如下一个函数

const authRequired = (nextState, replace) => {
 // Now you can access the store object here.
 const state = store.getState(); 
 if (state.admin != 1) {
 replace('/');
 }
 };

函数里我们判断了state的admin是否等于1,否则跳转到首页。

然后在Route添加 onEnter={authRequired} 属性

<Route path="photo" component={PhotoPage} onEnter={authRequired} />

通过以上,就完成了第一个权限的添加

进入系统之前就进行权限控制

如果需要在进入系统之前就进行权限控制,那么就需要改变一下策略。

比如上边的例子,加入state的admin并未加载,那么就需要在上一层的route进行数据加载

首先添加一个加载数据的函数

function loadData(nextState, replace, callback) {
 let unsubscribe;
 function onStateChanged() {
 const state = store.getState();
 if (state.admin) {
 unsubscribe();
 callback();
 }
 }
 unsubscribe = store.subscribe(onStateChanged);
 store.dispatch(actions.queryAdmin());
 }

接着再修改一下Router

<Router history={history}>
 <Route path="/" component={AppRoot} onEnter={loadData}>
 <IndexRoute component={IndexPage} />
 <Route path="photo" component={PhotoPage} onEnter={authRequired} />
 <Route path="info" component={InfoPage} />
 </Route> 
 </Router>

这样在进入下边之前,就会先进行数据加载。

通过以上简单几步,一个完整的权限控制链就完成了.

下载本文
显示全文
专题