Daily development often encounter background management system projects.
These projects have some commonality, the most common being access control.
Role-based Access Control: role-based Access Control
The most common is to use the RBAC scheme, which defines access by role.
Classification of permissions
Permissions can be divided into page permissions and function permissions. Page permissions are essentially front-end routing. In the project I was responsible for, I developed the function of authority control. Two main functions are implemented: 1) Maintain the mapping between users and roles; 2) Mapping between roles and page access permissions or page specific function permissions
In addition, in some special cases, individual users need to access some special pages, so the form of user id corresponding to special pages + role corresponding to general pages is used to maintain page permission information.
Webpack dynamic import
When maintaining role page permissions, a path field is set, which is the path of page components. Typically, lazy-loading component files are used. At this point, you can use webPack’s dynamic import feature to load components corresponding to the specified path. This allows us to translate roles and page access into a mapping between roles and component files. Just store the mapping in the database.
When you log in, the backend returns the user’s page permissions (file paths) and generates a system menu. When the user clicks the menu, the route jumps and the asynchronous component is resolved.
Routing meta information
VueRouter has meta information, and the corresponding function permissions of roles are stored in meta information. The meta information is then read in the component Created or route guard and the corresponding function button is displayed/disabled.
Empty the routing
In VueRouter, there is no way to clear every pathList, pathMap, nameMap. We can reset the Router instance’s matcher properties without breaking the source code. This property contains the match and addRouters methods and initializes the pathList, pathMap, and nameMap values.
Reference link: blog.csdn.net/baidu_28647…