美文网首页
菜单与权限设计思路

菜单与权限设计思路

作者: 爱米的罗杰 | 来源:发表于2016-10-08 16:06 被阅读0次

菜单与权限设计思路

一.设计思路

·面向开发人员友好

在长期以来的开发过程中,我们面临的主要问题就出现在开发友好的点上,开发人员使用框架无法进行流畅的开发,经常需要打断思路解决权限问题,有时也经常面临DEBUG过程中大量出现无权限问题,不仅拖延了开发效率,也降低了代码质量,因此面对开发人员的权限设计友好程度直接绝定了整体的开发效率与质量,解决该问题刻不容缓。

·面向使用用户友好

最好的工具永远是无须学习的,作为一个PHP程序员我们尤其对此收益匪浅。在以往的B/S应用开发成果中,对于权限管理这种学习成本较高且使用频率较低的功能用户往往选择不学习使用,但由此引发的误操作对于程序流程往往是致命的。因此我们积极应对方式是提供学习成本低廉且稳定系数高的权限管理界面。

二.需求分析

1.菜单部分

菜单部分根据需求共分为三级,层级关系为分别为:

子系统--模块--功能

其中子系统为自定义部分,可以由用户自定义定制,用户可以自定义子系统中的功能,但不能对模块中的功能进行操作。

模块中的功能由开发人进行设定,设定后不可更改,但在权限部份可以对模块中得功能进行操作。

2.权限部份

权限部份根据用户属性需求,用户层级关系为:

组织机构--岗位--用户

组织机构与岗位为无限子父级划分其中岗位与权限设置对应关系。

权限分为四级,前三级分别对应菜单部分的子系统--模块--功能三级。第四季功能中具体的操作权限(例如增加、删除、修改等)。

三.实现思路


在实现上,权限部份作为全局注册的中间件形式出现,任何用户请求都会经过权限中间件。

整体流程

在权限控制的方式上,整体流程如下图

权限控制流程

特殊方法检测:用户请求接入后,首先执行特殊方法检测。特殊方法检测是针对部分无须经过验证权限的特殊情况过滤。例如登录方法,注册方法等。如果特殊方法认证为真,则无须进行验证,直接允许访问。

IP检测:IP检测是通过限制客户端IP的方式进行的权限认证,该认证是可选的。如果不通过直接进行拒绝访问处理。

动态检测:动态检测是为开发人员提供的特殊检测方式,该方法内可以根据特殊需求进行验证的定制。当动态检测返回NULL时,正常进入下一步验证,当动态检测为False时,直接拒绝访问,当动态检测为True时直接允许访问。

权限验证:权限验证将根据当前URL和当前用户的用户组进行匹配,如果匹配成功则允许访问,匹配失败将拒绝访问。

相关文章

  • 菜单与权限设计思路

    菜单与权限设计思路 一.设计思路 ·面向开发人员友好 在长期以来的开发过程中,我们面临的主要问题就出现在开发友好的...

  • 权限方面数据库的设计

    权限设计 管理员表_admin 角色表_admin_role 菜单表_menu 菜单权限表_admin_role_...

  • 智能销售系统(八)菜单/POI入门

    一、菜单 要求一:获取数据库的数据(菜单)要求二:相应的权限看到相应的(菜单)  1.1 思路    1.1.1 ...

  • 前后端分离 springboot+springSecurity+

    对于权限的设计可以分为菜单权限和数据权限两个部分菜单权限 关于这个表,我说如下几点: 1.hr表是用户表,存放了用...

  • 2018-05-03

    工作中遇到的一些问题: 将原先静态的菜单权限改为数据库保存,根据用户权限来显示菜单。 简单思路:通过用户id将其权...

  • 数据权限设计实现

    设计一款后台产品时,用户角色权限控制是最常遇到的问题,之前已经在《菜单权限设计实现》一文中讲述过最简单最基本菜单权...

  • vue 动态路由/路由权限 解决方案

    路由权限思路: 1.菜单栏/导航栏(一级权限)在登录成功后,获取后端的权限数据, 根据权限数据,展示对应的路由导航...

  • Vue添加动态路由

    需求 后台管理需要根据登陆的用户权限做菜单控制 思路 后台返回用户权限,保存到vuex中,判断权限是否有惨淡导航,...

  • 权限设计合集

    1.《数据权限设计思路_权限设计数据权限》摘要:方案一:按照岗位体系建立数据权限方案二:针对角色设置数据权限方案三...

  • springboot通用分支处理---还在硬编码特殊处理逻辑?超

    前言 当引入登录模块后我们需要做菜单。而菜单自然需要权限的参与,我们在springboot中设计的权限细粒度还算是...

网友评论

      本文标题:菜单与权限设计思路

      本文链接:https://www.haomeiwen.com/subject/rmjuyttx.html