`
rongxh2010
  • 浏览: 48207 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

扩展RBAC用户角色权限设计方案

阅读更多

RBAC(Role-Based Access Control,基于角色的访问控制),就是用户通过角色与权限进行关联。简单地说,一个用户拥有若干角色,每一个角色拥有若干权限。这样,就构造成“用户-角色-权限”的授权模型。在这种模型中,用户与角色之间,角色与权限之间,一般者是多对多的关系。(如下图)



角色是什么?可以理解为一定数量的权限的集合,权限的载体。例如:一个论坛系统,“超级管理员”、“版主”都是角色。版主可管理版内的帖子、可管理版内的用户等,这些是权限。要给某个用户授予这些权限,不需要直接将权限授予用户,可将“版主”这个角色赋予该用户。 

 

当用户的数量非常大时,要给系统每个用户逐一授权(授角色),是件非常烦琐的事情。这时,就需要给用户分组,每个用户组内有多个用户。除了可给用户授权外,还可以给用户组授权。这样一来,用户拥有的所有权限,就是用户个人拥有的权限与该用户所在用户组拥有的权限之和。(下图为用户组、用户与角色三者的关联关系)

在应用系统中,权限表现成什么?对功能模块的操作,对上传文件的删改,菜单的访问,甚至页面上某个按钮、某个图片的可见性控制,都可属于权限的范畴。有些权限设计,会把功能操作作为一类,而把文件、菜单、页面元素等作为另一类,这样构成“用户-角色-权限-资源”的授权模型。而在做数据表建模时,可把功能操作和资源统一管理,也就是都直接与权限表进行关联,这样可能更具便捷性和易扩展性。(见下图)



请留意权限表中有一列“权限类型”,我们根据它的取值来区分是哪一类权限,如“MENU”表示菜单的访问权限、“OPERATION”表示功能模块的操作权限、“FILE”表示文件的修改权限、“ELEMENT”表示页面元素的可见性控制等。

 

这样设计的好处有二。其一,不需要区分哪些是权限操作,哪些是资源,(实际上,有时候也不好区分,如菜单,把它理解为资源呢还是功能模块权限呢?)。其二,方便扩展,当系统要对新的东西进行权限控制时,我只需要建立一个新的关联表“权限XX关联表”,并确定这类权限的权限类型字符串。

 

这里要注意的是,权限表与权限菜单关联表、权限菜单关联表与菜单表都是一对一的关系。(文件、页面权限点、功能操作等同理)。也就是每添加一个菜单,就得同时往这三个表中各插入一条记录。这样,可以不需要权限菜单关联表,让权限表与菜单表直接关联,此时,须在权限表中新增一列用来保存菜单的ID,权限表通过“权限类型”和这个ID来区分是种类型下的哪条记录。

 

到这里,RBAC权限模型的扩展模型的完整设计图如下:



随着系统的日益庞大,为了方便管理,可引入角色组对角色进行分类管理,跟用户组不同,角色组不参与授权。例如:某电网系统的权限管理模块中,角色就是挂在区局下,而区局在这里可当作角色组,它不参于权限分配。另外,为方便上面各主表自身的管理与查找,可采用树型结构,如菜单树、功能树等,当然这些可不需要参于权限分配。

 

以上,是从基本的RBAC模型进行了扩展,具体的设计要根据项目业务的需要作调整。欢迎大家提出批评意见!

  • 大小: 42.1 KB
  • 大小: 52.3 KB
  • 大小: 85.5 KB
  • 大小: 144.2 KB
分享到:
评论
39 楼 hsluoyz 2018-09-21  
现在新推出了一个权限框架,叫jCasbin(https://github.com/casbin/jcasbin)。jCasbin采用了元模型的设计思想,支持多种经典的访问控制方案,如ACL、RBAC、ABAC,还支持对RESTful API的控制。现在已经支持Spring Boot、JFinal等Web框架了。需要中文文档的话,可以在百度搜索:jCasbin
38 楼 江川河 2015-05-20  
rongxh,您好

RBAC模型里面,User-Role-Permission都很好理解,也很清晰。

Permission通常也被分为Operation+Resource/Object,但是实际上同为Role,对应于不同的User,可供操作的Object的范围(Scope)是不同的。

比如同为老师(Role),A班老师(User1)和B班老师(User2)可操作的学生范围(Scope)是不同的,但是在RBAC模型下,都只能用用"Operation:Student"来表达Permission,请问您这边有实际的解决方法吗
37 楼 di1984HIT 2014-11-17  
写的很好啊~
36 楼 liyonghui160com 2014-05-07  
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道

ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
xu-zhx 写道
ltian 写道
RBAC这么简单吗,怀疑你是否看过ARBC或者是否理解其精髓,不要以为简单地引入了角色的概念就是RBAC了,恐怕连第二个级别的RBAC都没实现,勉强算是第一个级别的RBAC,恐怕也是最简单的功能,谈不上任何扩展

既然你这么厉害,何不拿出你的见解出来谈谈呢?



大规模枯
嘤嘤嘤嘤路由器



35 楼 ming_02 2012-12-12  
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道

ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
xu-zhx 写道
ltian 写道
RBAC这么简单吗,怀疑你是否看过ARBC或者是否理解其精髓,不要以为简单地引入了角色的概念就是RBAC了,恐怕连第二个级别的RBAC都没实现,勉强算是第一个级别的RBAC,恐怕也是最简单的功能,谈不上任何扩展

既然你这么厉害,何不拿出你的见解出来谈谈呢?



大规模枯
嘤嘤嘤嘤路由器


34 楼 ming_02 2012-12-12  
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ming_02 写道
ming_02 写道
xu-zhx 写道
ltian 写道
RBAC这么简单吗,怀疑你是否看过ARBC或者是否理解其精髓,不要以为简单地引入了角色的概念就是RBAC了,恐怕连第二个级别的RBAC都没实现,勉强算是第一个级别的RBAC,恐怕也是最简单的功能,谈不上任何扩展
既然你这么厉害,何不拿出你的见解出来谈谈呢?



大规模枯
嘤嘤嘤嘤路由器

33 楼 ming_02 2012-12-12  
ming_02 写道
xu-zhx 写道
ltian 写道
RBAC这么简单吗,怀疑你是否看过ARBC或者是否理解其精髓,不要以为简单地引入了角色的概念就是RBAC了,恐怕连第二个级别的RBAC都没实现,勉强算是第一个级别的RBAC,恐怕也是最简单的功能,谈不上任何扩展

既然你这么厉害,何不拿出你的见解出来谈谈呢?



大规模枯
嘤嘤嘤嘤路由器
32 楼 ming_02 2012-12-12  
xu-zhx 写道
ltian 写道
RBAC这么简单吗,怀疑你是否看过ARBC或者是否理解其精髓,不要以为简单地引入了角色的概念就是RBAC了,恐怕连第二个级别的RBAC都没实现,勉强算是第一个级别的RBAC,恐怕也是最简单的功能,谈不上任何扩展

既然你这么厉害,何不拿出你的见解出来谈谈呢?



大规模枯
31 楼 superchinaren 2012-10-23  
楼主的PDM图能提供一份吗。
30 楼 平淡-幕 2012-09-07  
权限表与权限菜单关联表、权限菜单关联表与菜单表都是一对一的关系。
(文件、页面权限点、功能操作等同理)。
也就是每添加一个菜单,就得同时往这三个表中各插入一条记录。


这样理解吗
例如菜单要添加一个 《员工管理》
就要添加
《员工管理查询》
《员工管理添加》
《员工管理修改》
《员工管理删除》 四个菜单吗?
29 楼 平淡-幕 2012-09-07  
权限表与权限菜单关联表、权限菜单关联表与菜单表都是一对一的关系。(文件、页面权限点、功能操作等同理)。也就是每添加一个菜单,就得同时往这三个表中各插入一条记录。

这样理解吗 
例如菜单要添加一个 《员工管理》
就要添加《员工管理添加》
《员工管理添加》
28 楼 ltian 2012-09-07  
xu-zhx 写道
ltian 写道
RBAC这么简单吗,怀疑你是否看过ARBC或者是否理解其精髓,不要以为简单地引入了角色的概念就是RBAC了,恐怕连第二个级别的RBAC都没实现,勉强算是第一个级别的RBAC,恐怕也是最简单的功能,谈不上任何扩展

既然你这么厉害,何不拿出你的见解出来谈谈呢?

NIST RBAC 标准就放在那里,自己去看就好了,无需任何人帮你拿阿。
27 楼 sence_qi 2012-08-10  
hexawing 写道
引用
这里要注意的是,权限表与权限菜单关联表、权限菜单关联表与菜单表都是一对一的关系。(文件、页面权限点、功能操作等同理)。也就是每添加一个菜单,就得同时往这三个表中各插入一条记录。

这里没太明白,LZ能详细讲讲吗?


每添加一个菜单,就需要为这个菜单设置权限,往权限菜单关联表,和权限表里面插入一条记录后,角色就可以引用在权限表里面配置对新添加菜单的权限,使用权限表的好处是,角色只需要直接关联权限表了,而不需要去关联菜单表,功能操作表。职责专一,维护角色权限也比较简单了

  其实我觉得,用户归根到底最终还是需要的是权限:
   用户---用户组---角色---权限(用户授受用户组模式)
   用户---角色---权限(用户可以直接授受角色模式)
  这个相对来说已经很完美了,但是针对用户细粒度的权限需求若是加上用户权限表,将用户和权限直接关联起来,系统的灵活度会更好
   用户---权限(用户可以直接授受权限)

   以上是个人见解,希望和楼主探讨
26 楼 hexawing 2012-08-03  
引用
这里要注意的是,权限表与权限菜单关联表、权限菜单关联表与菜单表都是一对一的关系。(文件、页面权限点、功能操作等同理)。也就是每添加一个菜单,就得同时往这三个表中各插入一条记录。

这里没太明白,LZ能详细讲讲吗?
25 楼 treemap 2011-10-07  
powerdesign画的图? 楼主?
24 楼 aa87963014 2011-06-28  
vtrtbb 写道
实际复杂的是记录或者字段级别的权限设置,并不是页面端的控制

不知道对于记录级别的权限有什么好办法

举个最简单的例子,总经理看全部记录,部门经理部门,员工看自己 的三级权限,如何设置?



我也在考虑这样的问题 另外 页面端控制也很重要
23 楼 george_space 2011-06-27  
simplechinese 写道
楼上区分下功能权限和数据权限,楼主这里没涉及到数据权限


你说的“功能权限”,术语应该叫做“操作权限”。
权限控制通常分为操作权限和数据权限(读取数据的深度(多少)控制)。

数据深度的控制,一般是很难抽象出来,做到通用的,数据深度的控制,跟业务结合非常紧密。
要么是通过不同的权限来区分人员读取数据的深度,要么是在用一种程序中约定的(等于写死的)的标志,来区分不同人员的读取数据的深度。

所以权限之数据深度控制是比较难做到通用型的。
22 楼 george_space 2011-06-27  
<div class="quote_title">
<br><br> rongxh2010 写道</div>
<div class="quote_div">
<p>RBAC(Role-Based Access Control,基于角色的访问控制),就是用户通过角色与权限进行关联。简单地说,一个用户拥有若干角色,每一个角色拥有若干权限。这样,就构造成“用户-角色-权限”的授权模型。在这种模型中,用户与角色之间,角色与权限之间,一般者是多对多的关系。(如下图)</p>
<p><img src="http://dl.iteye.com/upload/attachment/425543/d2573c4d-dca7-380f-b2fc-6cda19d6eaf5.jpg" alt=""><br><br>角色是什么?可以理解为一定数量的权限的集合,权限的载体。例如:一个论坛系统,“超级管理员”、“版主”都是角色。版主可管理版内的帖子、可管理版内的用户等,这些是权限。要给某个用户授予这些权限,不需要直接将权限授予用户,可将“版主”这个角色赋予该用户。 </p>
<p> </p>
<p>当用户的数量非常大时,要给系统每个用户逐一授权(授角色),是件非常烦琐的事情。这时,就需要给用户分组,每个用户组内有多个用户。除了可给用户授权外,还可以给用户组授权。这样一来,用户拥有的所有权限,就是用户个人拥有的权限与该用户所在用户组拥有的权限之和。(下图为用户组、用户与角色三者的关联关系)</p>
<p><img src="http://dl.iteye.com/upload/attachment/425558/90bf9805-c29d-3199-a905-c6ddc7fd4e81.jpg" alt=""></p>
<p>在应用系统中,权限表现成什么?对功能模块的操作,对上传文件的删改,菜单的访问,甚至页面上某个按钮、某个图片的可见性控制,都可属于权限的范畴。有些权限设计,会把功能操作作为一类,而把文件、菜单、页面元素等作为另一类,这样构成“用户-角色-权限-资源”的授权模型。而在做数据表建模时,可把功能操作和资源统一管理,也就是都直接与权限表进行关联,这样可能更具便捷性和易扩展性。(见下图)</p>
<p><br><img src="http://dl.iteye.com/upload/attachment/425567/53bc63c4-52e6-3c6f-91d8-7e23a9aefe4a.jpg" alt=""><br>请留意权限表中有一列“权限类型”,我们根据它的取值来区分是哪一类权限,如“MENU”表示菜单的访问权限、“OPERATION”表示功能模块的操作权限、“FILE”表示文件的修改权限、“ELEMENT”表示页面元素的可见性控制等。</p>
<p> </p>
<p>这样设计的好处有二。其一,不需要区分哪些是权限操作,哪些是资源,(实际上,有时候也不好区分,如菜单,把它理解为资源呢还是功能模块权限呢?)。其二,方便扩展,当系统要对新的东西进行权限控制时,我只需要建立一个新的关联表“权限XX关联表”,并确定这类权限的权限类型字符串。</p>
<p> </p>
<p>这里要注意的是,权限表与权限菜单关联表、权限菜单关联表与菜单表都是一对一的关系。(文件、页面权限点、功能操作等同理)。也就是每添加一个菜单,就得同时往这三个表中各插入一条记录。这样,可以不需要权限菜单关联表,让权限表与菜单表直接关联,此时,须在权限表中新增一列用来保存菜单的ID,权限表通过“权限类型”和这个ID来区分是种类型下的哪条记录。</p>
<p> </p>
<p>到这里,RBAC权限模型的扩展模型的完整设计图如下:</p>
<p><br><img src="http://dl.iteye.com/upload/attachment/425569/c07d99bc-e19d-302d-8dea-dc98309bf919.jpg" alt=""><br>随着系统的日益庞大,为了方便管理,可引入角色组对角色进行分类管理,跟用户组不同,角色组不参与授权。例如:某电网系统的权限管理模块中,角色就是挂在区局下,而区局在这里可当作角色组,它不参于权限分配。另外,为方便上面各主表自身的管理与查找,可采用树型结构,如菜单树、功能树等,当然这些可不需要参于权限分配。</p>
<p> </p>
<p>以上,是从基本的RBAC模型进行了扩展,具体的设计要根据项目业务的需要作调整。欢迎大家提出批评意见!</p>
</div>
<p><br><span style="color: #ff0000; font-size: large;"><strong>不是吧,猛一看以为是我自己的数据模型呢?我以为只有我的权限系统有“页面元素”这个概念呢。</strong></span></p>
<p><strong><span style="color: #ff0000; font-size: large;">--------------------------------------------</span></strong></p>
<p><strong></strong></p>
<p><strong><span style="color: #0000ff; font-size: large;">有时候需要单独为一个用户增加一两个权限的,这时候单独为这个用户设计一个“角色”,不值得,所以我设计的是:既可以通过角色为用户分配权限,也可以直接将权限分配给用户。</span></strong></p>
<p><strong><span style="color: #0000ff; font-size: large;">--------------------------------------------</span></strong></p>
<p><strong></strong></p>
<p><strong><span style="color: #000000; font-size: large;">我接触过的几个开发人员,都不明白为什么要直接给用户分配权限,但是在软件的实际应用中,如果完全基于“角色”为人员分配权限,你会 发现角色之间重复、冗余的权限很多,这样反复的定义多种多样的“角色”,还不如设计成可以直接为人员分配权限呢。</span></strong></p>
<p><strong><span style="font-size: large;">--------------------------------------------</span></strong></p>
<p><strong></strong></p>
<p><strong><span style="font-size: large;">权限管理基本上分为以下几个步骤:</span></strong></p>
<p><strong><span style="font-size: large;">1、定义权限-》定义角色-》为人员分配角色(或者直接分配权限),这是一个分配权限的过程;</span></strong></p>
<p><strong><span style="font-size: large;">--------------------------------------------</span></strong></p>
<p><strong></strong></p>
<p><strong><span style="font-size: large;">2、定义受保护资源-》为“受保护资源”指定授权权限,这是一个授权的过程;</span></strong></p>
<p><strong><span style="font-size: large;">--------------------------------------------</span></strong></p>
<p><strong></strong></p>
<p><strong><span style="font-size: large;">3、应用程序请求“受保护资源”-》“受保护资源”的授权权限与人员持有的权限进行匹配-》匹配成功,允许访问资源,匹配失败,不允许访问资源,这是一个认证的过程。</span></strong></p>
<p><strong><span style="font-size: large;">--------------------------------------------</span></strong></p>
<p><strong></strong></p>
<p><strong></strong></p>
<p><strong><span style="font-size: large;">上面这三个过程,是典型的“操作权限”的流程。</span></strong></p>
<p><strong><span style="font-size: large;">
<p><strong><span style="font-size: large;">--------------------------------------------</span></strong></p>
</span></strong></p>
<p><strong><span style="font-size: large;">
<p><strong><span style="font-size: large;">关于“页面元素”的控制,目前多数权限管理系统,都是用“自定义权限标签”来控制页面元素的显示与否的。</span></strong></p>
<p><strong><span style="font-size: large;">我目前也是这样实现的,但是我一直认为:其实用“自定义权限标签”来控制页面元素的显示与否,跟直接在视图中使用程序逻辑判断,是一样的,并没有做到“灵活配置”,当权限编码改变,或者权限含义改变时,还是要去动页面的标签,所以跟写死没什么分别。</span></strong></p>
<p><strong></strong> </p>
<p><strong><span style="font-size: large;">如果页面元素是通过服务端组装成json,或者别的格式的数据,然后返回到视图层进行渲染,这样的话,就可以做到“页面元素的权限灵活配置了”,可以通过数据库定义那些按钮对那些权限或角色进行显示。</span></strong></p>
<p> </p>
<p>“服务端组装视图层组件,返回视图层渲染”,这个模式虽然做到了“对页面元素的权限灵活配置”,但是牺牲掉了很多东西,比如加大了服务端的复杂度,使得页面的设计更加“程序员化”,而不是“美工化”等。</p>
<p><strong><span style="font-size: large;">--------------------------------------------</span></strong></p>
<p><strong></strong> </p>
<strong><span style="font-size: large;">
<p>至于最关键的“数据权限”,也就是人员对数据的读取深度的控制,是更为复杂的流程。</p>
</span></strong></span>
<p> </p>
</strong></p>
<p> </p>
<p><strong><span style="font-size: large;">--------------------------------------------</span></strong></p>
<p><strong><span style="font-size: large;">对于“数据深度”的控制,我目前的做法是和业务结合的非常紧密,即:在读取数据的程序中,比如“列表”页,首先判断当前登陆者有没有“读取任意深度的权限”,如果有,就不做读取限制;如果没有,则判断当前登录人员是不是部门主管,如果是,则递归读取本部门下的所有数据,如果不是主管,则只读取自己的数据。</span></strong></p>
<p><strong><span style="font-size: large;">--------------------------------------------</span></strong></p>
<p><strong><span style="font-size: large;">“数据深度”的控制,细设计的话,应该可以更通用,更灵活,大家有什么更好的思路,可以讨论一下。</span></strong></p>
<p><strong></strong></p>
<p><strong><span style="font-size: large;">--------------------------------------------</span></strong></p>
<p><strong><span style="font-size: large;">我目前设计的是一个人员只能有一个“角色”,当然,如果设计成一个人员有多个“角色”,也不是很复杂的事情,在“用户表”和“角色表”之间增加一个“用户-角色映射表”就可以了,但是为了系统的简单起见,我把这种设计简化了。</span></strong></p>
<p><strong><span style="font-size: large;">--------------------------------------------</span></strong></p>
<p><strong></strong></p>
<p><strong><span style="font-size: large;">以下是我的“权限控制”的部分数据模型:</span></strong></p>
<p><strong></strong></p>
<p><img src="http://dl.iteye.com/upload/attachment/505365/4464cc41-14d0-3de3-a4ae-e6e41693f347.jpg" alt=""></p>
<p> </p>
<p><span style="color: #ff0000; font-size: large;"><strong>我目前比较关心的是:</strong></span></p>
<p><span style="color: #ff0000; font-size: large;"><strong>1、数据权限(读取数据的深度)有什么更通用的设计?</strong></span></p>
<p><span style="color: #ff0000; font-size: large;"><strong>2、页面元素的控制,除了使用“自定义权限标签”,或者“服务端组装视图层组件”两种方法,还有没有更好的设计?</strong></span></p>
<p><span style="color: #ff0000; font-size: large;"><strong></strong></span></p>
<p><span style="color: #ff0000; font-size: large;"><strong>有木有?有木有?牛人出来讨论下啊。</strong></span></p>
21 楼 openFox 2011-06-27  
本来还挺明白的,看你的我糊涂了
20 楼 hk8082 2011-04-01  
复杂,能否再进一步抽象呢,做个更通用一点的权限管理模块出来

相关推荐

    node-v4.8.6-win-x64.zip

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    基础运维技能(下)md格式笔记

    基础运维技能(下)md格式笔记

    node-v8.1.2-linux-armv7l.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    黑马程序员 C语言学习笔记

    持续更新

    PCL-1.14.1-AllInOne-msvc2022-win64+pdb-msvc2022-win64

    PCL-1.14.1-AllInOne-msvc2022-win64+pdb-msvc2022-win64

    DSmall商城系统源代码

    PC商城系统源码

    Defender Control v2.1(win11 禁用defender服务工具).zip

    Defender Control v2.1(win11 禁用defender服务工具).zip

    node-v8.8.0-linux-armv6l.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    node-v8.9.0-linux-ppc64.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    node-v4.7.2-x86.msi

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    2024年中国超声非侵入式腐蚀检测传感器行业研究报告.docx

    2024年中国超声非侵入式腐蚀检测传感器行业研究报告

    基于知识图谱的问答系统,结合MetaQA知识图谱,用于解决电影领域的问答问题

    【作品名称】:基于知识图谱的问答系统,结合MetaQA知识图谱,用于解决电影领域的问答问题 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 ## 项目目录结构: 1、train_KGE目录下为训练知识图谱嵌入模型的相关代码,包含以下知识图谱嵌入方法: - RotatE - TransE - DistMult - ComplEx 2、KGQA_system目录下包含了问答系统的实现代码,包含以下几个模块: - 知识图谱嵌入模块 - 问题嵌入模块 - 关系预测模块 - 答案生成模块

    node-v8.8.0-linux-ppc64le.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    ISO 3452-3-2013 无损检测渗透检测第3部分:参考试块.pdf

    ISO 3452-3-2013 无损检测渗透检测第3部分:参考试块.pdf

    node-v8.1.1-linux-armv6l.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    用于目标检测的遥感图像数据集

    目标检测遥感数据集。包括训练集、验证集和测试集共1400张遥感图像及相应标注。已处理为适用yolov5的格式。

    node-v8.0.0-linux-ppc64.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    深度学习工具包:Matlab实现的RNN-LSTM与CNN模型 - 专业版下载

    RNN-LSTM(循环神经网络-长短期记忆网络)是一种在序列数据处理中表现出色的深度学习模型,特别擅长于处理和预测时间序列数据。卷积神经网络(CNN)则在图像识别和处理领域有着广泛的应用,以其局部感受野和权重共享特性而闻名。 "RNN-LSTM卷积神经网络Matlab实现"资源为用户提供了一个在Matlab环境中实现这两种网络的机会。该资源包可能包含以下内容: 1. RNN-LSTM网络的Matlab代码实现,允许用户对序列数据进行深入分析和预测。 2. CNN网络的Matlab代码,适用于图像数据的分类和特征提取任务。 3. 示例数据集和使用教程,帮助用户快速理解并应用这些模型。 4. 定制化接口,使用户能够根据自己的需求调整网络结构和参数。 5. 详细的注释和文档,方便用户学习和理解代码的工作原理。 通过这个资源包,研究人员和开发者可以在Matlab平台上,利用RNN-LSTM和CNN的强大功能,进行复杂的数据分析和模式识别任务。无论是在学术研究还是在工业应用中,该资源都能提供强大的支持。

    typescript-4.3.1-rc.tgz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

Global site tag (gtag.js) - Google Analytics