`
freeboat
  • 浏览: 37505 次
  • 性别: Icon_minigender_1
  • 来自: 吉林长春
社区版块
存档分类
最新评论

RailsGACL手册(介绍)

阅读更多
(整理好的说明 以后会包含在程序包里面)
  • 大小: 90.5 KB
分享到:
评论
25 楼 prolead 2007-03-10  
和active_acl->http://rubyforge.org/projects/activeacl/有什么不同?
24 楼 mafa 2006-11-27  
老兄的代码风格和布局不敢恭维啊~!
23 楼 jianfeng008cn 2006-11-11  
江南白衣 写道
楼主帅哥阿,养眼~~~~~

您也很帅哦,我一直再猜您的年龄!呵呵
个人感觉,权限这种东西说复杂就复杂,说简单应该也简单,和log一样可以AOP抽离出来的东西,无非是对用户和所进行的操作这2个对象进行一个中间关联(最简单的做法是分有和没有),脱离具体的业务,我们需要的模型只需要把用户和权限这2对象的数据有个很类和采集的入口就可以了,至于权限是针对MVC或者数据哪方面的,如菜单,action,还是对象属性的过滤或者数据集的字段权限的过滤,都是属于权限本身的事情,而用户的分组,分权限组,也只是在这个基本前提下针对用户对象权限相关的处理,从大的视角来看的话也许舒服点,减少因为做不到而很郁闷
22 楼 freeboat 2006-10-24  
这个是这套系统最基本的功能,绝没问题
21 楼 cookoo 2006-10-24  
fyol说的是权限组代表一组相关的权限,统一加到用户身上。
其实也可以理解成role,然后把role加到用户身上。
20 楼 freeboat 2006-10-24  
fyol 写道
和权限组有什么区别?
每人放到组里,如果某个人需要组权限之外的权限或限制就加allow或deny


请问 权限组 是什么,你想说的是什么意思呢?
19 楼 fyol 2006-10-24  
和权限组有什么区别?
每人放到组里,如果某个人需要组权限之外的权限或限制就加allow或deny

18 楼 freeboat 2006-10-24  
17 楼 江南白衣 2006-10-24  
楼主帅哥阿,养眼~~~~~
16 楼 baizhan 2006-10-24  
好东西..收藏啦...准备开始学ROR
15 楼 jack 2006-10-24  
freeboat 写道


其实 使用 RailsGacl 的过程不过是调用 acl_check 这个方法,然后他会给你返回 true or false
其他的设置权限 如果 自带的设置正合你意,当然刚刚好,不过 我想管理员如果不是开发员的话
这个自带的设置还是不要给用户使用的好,因为多数时候我们的 Aco(访问控制对象) 都会写死到逻辑中,

例如 acl_check '系统维护','添加用户','人事处','李刚'

其中的 “系统维护”,“添加用户” 一般情况下都是写在 action 中的 不是吗?
至少我目前还没有动态用过。

不过你提出的 对 动态发表文章的权限控制 我倒是 觉得 可以尝试一下 动态的,不过具体的我还没想好


对于一个既定的系统来说,有哪些操作权限是确定的,如果项目开始就直接引入GACL,到处丢acl_check大概就不成问题了.不过rails本身有各种before_,after_之类的filter函数.如果你的这个GACL直接做成类似这样的方式,虽然不一定完全解决,不过开发人员的接受程度会高很多 .这样就能够方便开发人员修改已经发布的系统了.


草稿权限设置我原先想给javaeye提的建议,不过做起来难度大了点.所以也就算了.刚刚好你发了这个贴,就拿来做例子讨论讨论了.
14 楼 freeboat 2006-10-24  
jack 写道
freeboat 写道
我已经在好多个系统中应用过这个权限管理系统(php版\java版),总的来说还是比较满意的。他对权限的控制真的是非常的精细。
我们大部分开发的系统都是我们自用的,所以在权限管理起来没有什么难度,其中也有一套为客户制作的(进销存),客户在使用这套权限系统为自己的员工分配权限的时候也是没遇到什么操作问题,所以在操作上还是容易让人理解的。

我在使用它的时候 多数是对 菜单的控制,并没有精确到action等(我们是内网自用的办公系统),像 jack 所说的对动态添加的文章动态的设置权限,可能就要做一些特殊的修改了。

这个系统中基础的是 Aro Axo Aco 的设置,具体的权限设置在 Acl 处,所以,实现 jack 的想法也是不无可能的,但不做改动或许就会变得很难。

PS.在这个论坛里我觉得我的想法有时候很肤浅,也讲不出什么大道理,只求向各位多多学习。


看的出来,你这个GACL的主要应用还在于静态对象的权限管理.那原系统受限对象上附加一个GACL对象来做权限控制的这样的做法,只要受限对象是始终存在的,静态的.应该没有什么问题.比如javaeye的每一个帖子上附上一个GACL对象,作单独控制.就可能不是那么方便了.不知道我这样理解是否正确呢?


我想动态的处理 还是要看你如何决定来写自己的代码的,你可以每次填写一个文章都动态的添加上对该文章的相关操作方法,然后针对你的朋友在进行设置,当然,如果像 javaeye 这么大的网站来进行这样的操作的话,那么 aco(访问控制对象) 将会随文章的增多而无限庞大,应该还有其他的更好方法,railsGacl 对于动态权限设置 应该并不太适合
13 楼 freeboat 2006-10-24  
jack 写道
freeboat 写道
jack 写道
 
你例子中提到的是版面访问,那么比如这样的需求,我的博客上有篇草稿,需要几个好友帮助修改下.那么我首先需要对这篇草稿针对这几个好友,设置读权限,回复权限,甚至修改权限.这样的需求,怎么能够在尽量不破坏原先系统的结构上,加入RailsGACL的控制呢?


不破坏原先系统的结构 我想是做不到吧? 有能做到的吗? 或者我不是很理解你的意思。


代码是一定要修改的,不过由于加入新的功能,项目结构是否会发生变化就很难说了.比如以ruby来说,最方便的插入功能代码就是用mixin方式了.你这个GACL框架是否也是提供类似这种方式的访问方法呢?如果因为加入个GACL,导致项目基本上要重写.这个任谁都要三思而后行了.


其实 使用 RailsGacl 的过程不过是调用 acl_check 这个方法,然后他会给你返回 true or false
其他的设置权限 如果 自带的设置正合你意,当然刚刚好,不过 我想管理员如果不是开发员的话
这个自带的设置还是不要给用户使用的好,因为多数时候我们的 Aco(访问控制对象) 都会写死到逻辑中,

例如 acl_check '系统维护','添加用户','人事处','李刚'

其中的 “系统维护”,“添加用户” 一般情况下都是写在 action 中的 不是吗?
至少我目前还没有动态用过。

不过你提出的 对 动态发表文章的权限控制 我倒是 觉得 可以尝试一下 动态的,不过具体的我还没想好
12 楼 jack 2006-10-24  
freeboat 写道
我已经在好多个系统中应用过这个权限管理系统(php版\java版),总的来说还是比较满意的。他对权限的控制真的是非常的精细。
我们大部分开发的系统都是我们自用的,所以在权限管理起来没有什么难度,其中也有一套为客户制作的(进销存),客户在使用这套权限系统为自己的员工分配权限的时候也是没遇到什么操作问题,所以在操作上还是容易让人理解的。

我在使用它的时候 多数是对 菜单的控制,并没有精确到action等(我们是内网自用的办公系统),像 jack 所说的对动态添加的文章动态的设置权限,可能就要做一些特殊的修改了。

这个系统中基础的是 Aro Axo Aco 的设置,具体的权限设置在 Acl 处,所以,实现 jack 的想法也是不无可能的,但不做改动或许就会变得很难。

PS.在这个论坛里我觉得我的想法有时候很肤浅,也讲不出什么大道理,只求向各位多多学习。


看的出来,你这个GACL的主要应用还在于静态对象的权限管理.那原系统受限对象上附加一个GACL对象来做权限控制的这样的做法,只要受限对象是始终存在的,静态的.应该没有什么问题.比如javaeye的每一个帖子上附上一个GACL对象,作单独控制.就可能不是那么方便了.不知道我这样理解是否正确呢?


11 楼 freeboat 2006-10-24  
我已经在好多个系统中应用过这个权限管理系统(php版\java版),总的来说还是比较满意的。他对权限的控制真的是非常的精细。
我们大部分开发的系统都是我们自用的,所以在权限管理起来没有什么难度,其中也有一套为客户制作的(进销存),客户在使用这套权限系统为自己的员工分配权限的时候也是没遇到什么操作问题,所以在操作上还是容易让人理解的。

我在使用它的时候 多数是对 菜单的控制,并没有精确到action等(我们是内网自用的办公系统),像 jack 所说的对动态添加的文章动态的设置权限,可能就要做一些特殊的修改了。

这个系统中基础的是 Aro Axo Aco 的设置,具体的权限设置在 Acl 处,所以,实现 jack 的想法也是不无可能的,但不做改动或许就会变得很难。

PS.在这个论坛里我觉得我的想法有时候很肤浅,也讲不出什么大道理,只求向各位多多学习。
10 楼 jack 2006-10-24  
freeboat 写道
jack 写道
 
你例子中提到的是版面访问,那么比如这样的需求,我的博客上有篇草稿,需要几个好友帮助修改下.那么我首先需要对这篇草稿针对这几个好友,设置读权限,回复权限,甚至修改权限.这样的需求,怎么能够在尽量不破坏原先系统的结构上,加入RailsGACL的控制呢?


不破坏原先系统的结构 我想是做不到吧? 有能做到的吗? 或者我不是很理解你的意思。


代码是一定要修改的,不过由于加入新的功能,项目结构是否会发生变化就很难说了.比如以ruby来说,最方便的插入功能代码就是用mixin方式了.你这个GACL框架是否也是提供类似这种方式的访问方法呢?如果因为加入个GACL,导致项目基本上要重写.这个任谁都要三思而后行了.
9 楼 freeboat 2006-10-24  
together 写道
另外,对权限控制的特殊要求还有,仅允许某个用户,使用某个IP,在某一个时间段内才能对某些数据进行操作。这样变态的需求,任什么权限管理框架,也无可奈何了吧?


这个需求刚好在 RailsGACL 中可以进行控制,而且还算完美。
具体用法后文会提到:)
8 楼 freeboat 2006-10-24  
jack 写道
  这个GACL完全和windows 2000/xp/2003的本地帐户访问权限一样的处理逻辑.

  windows的权限管理中,系统中的很多对象都具有这样的权限设置。比如文件,文件夹是最为常用的权限管理的地方。按你这个GACL的说法就是每一个受限访问对象都具有一个GACL对象(姑且这样叫吧)。这个GACL对象首先继承自系统的GACL,访问对象如果需要独立的受限访问权限,就需要单独设置GACL对象。

  那么你的RailsGACL能够提供给使用RailsGACL的系统做这样的单独的GACL控制吗?

RailsGACL 能够提供给使用 RailsGACL 的系统做单独的 ACL(后文中将会提到)控制。

引用
  你例子中提到的是版面访问,那么比如这样的需求,我的博客上有篇草稿,需要几个好友帮助修改下.那么我首先需要对这篇草稿针对这几个好友,设置读权限,回复权限,甚至修改权限.这样的需求,怎么能够在尽量不破坏原先系统的结构上,加入RailsGACL的控制呢?


不破坏原先系统的结构 我想是做不到吧? 有能做到的吗? 或者我不是很理解你的意思。
7 楼 freeboat 2006-10-24  
谢谢 cookoo , 图片是因为我 用 HTML 排的版,移到论坛里面 就需要再排版,所以 就用图片了,以后会加到 程序包里面的 :)

“如何创建和管理权限控制对象” 今天晚上回去我继续写完 大家就可以看到了

我自认技术还不纯属,也不是科班出身,所以关于一些理论的东西只是一知半解,还请各位高手谅解,多多指教
6 楼 thundercao 2006-10-24  
together 写道
说到权限控制,不是一般的复杂。想起来就头疼。
现在的权限管理框架,也仅能实现粗粒度的控制,控制到菜单、action一级。
举个例子,用户具有ListAction的访问权限,但列表中的数据对他来讲,
有一部分是只能查阅的,有一部分是只能查阅和修改的,有一部分是查阅、修改、删除都能做的。那么怎么来控制呢?
具体到一个UpdateAction中,对于某些ID的数据,当前用户是可以执行update操作的。但对于某些数据,是不可以执行update的。虽然用户具有updateaction的操作权限,但具体到某一条记录,另当别论了。

在政务/OA类系统中,还有一个常用的授权操作,这对权限管理也是一个很大的挑战。
另外,对权限控制的特殊要求还有,仅允许某个用户,使用某个IP,在某一个时间段内才能对某些数据进行操作。这样变态的需求,任什么权限管理框架,也无可奈何了吧?


普通的权限控制做到Action一级也足够了,复杂的权限控制无处不在,这是随着业务需求而变化,目前好像市面上还没有一款像样的且比较通用的权限管理系统

相关推荐

    RailsGacl Rails应用 通用访问控制列表

    RailsGACL 是大名鼎鼎的 PhpGACL 的 Rails 版本.  RailsGACL 是一组允许你控制对象(用户,远程主机等)访问其他对象(网页,数据库等)权限的函数.  该组函数可以通过简单的管理提供高精度的访问控制,并且运行地...

    Java课程设计-java web 网上商城,后台商品管理(前后端源码+数据库+文档) .zip

    项目规划与设计: 确定系统需求,包括商品管理的功能(如添加商品、编辑商品、删除商品、查看商品列表等)。 设计数据库模型,包括商品表、类别表、库存表等。 确定系统的技术栈,如使用Spring MVC作为MVC框架、Hibernate或MyBatis作为ORM框架、Spring Security进行权限控制等。 环境搭建: 搭建开发环境,包括安装JDK、配置Servlet容器(如Tomcat)、配置数据库(如MySQL)等。 创建一个Maven项目,添加所需的依赖库。 数据库设计与创建: 根据设计好的数据库模型,在数据库中创建相应的表结构。 后端开发: 创建Java实体类,对应数据库中的表结构。 编写数据访问层(DAO)代码,实现对商品信息的增删改查操作。 编写服务层(Service)代码,实现业务逻辑,如商品管理的各种操作。 开发控制器层(Controller),实现与前端页面的交互,接收请求并调用相应的服务进行处理。 前端开发: 使用HTML、CSS和JavaScript等前端技术,设计并实现商品管理页面的界面。 通过Ajax技术,实现前后端的数据交互,如异步加载商品列表、实

    母线电容计算 .xmcd

    变频器 母线电容计算 mathcad

    2022年中国大学生计算机设计大赛国赛优秀作品点评微课与教学辅助&数媒静态设计专业组视频

    2022年中国大学生计算机设计大赛国赛优秀作品点评微课与教学辅助&数媒静态设计专业组视频提取方式是百度网盘分享地址

    输出月份英文名pta.doc

    如果您想要在程序中输出月份的英文名称,并且提到了“pta”,但这里的“pta”与月份名称的输出没有直接关系(除非您是在特定的上下文中使用它作为一个变量名或标识符)。不过,我将直接给出如何输出月份英文名称的代码示例。 在Python中,您可以使用一个列表(list)或字典(dictionary)来存储月份的英文名称,并根据需要输出它们。以下是一个简单的示例: python # 使用列表存储月份的英文名称 months = ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"] # 假设我们要输出第5个月份(即May) month_index = 4 # 注意列表索引从0开始,所以5月份是索引4 print(months[month_index]) # 输出: May # 或者,如果您想要通过月份的数字(1-12)来输出名称,可以稍作调整 def get_mo

    单片机C语言Proteus仿真实例万年历

    单片机C语言Proteus仿真实例万年历提取方式是百度网盘分享地址

    base.apk

    base.apk

    setuptools-59.0.1.tar.gz

    Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。

    控制台界面字符版五子棋,有AI,可人机对战,在dev-c++下编写Renju-AI.zip

    五子棋游戏想必大家都非常熟悉,游戏规则十分简单。游戏开始后,玩家在游戏设置中选择人机对战,则系统执黑棋,玩家自己执白棋。双方轮流下一棋,先将横、竖或斜线的5个或5个以上同色棋子连成不间断的一排者为胜。 【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、python、web、C#、EDA、proteus、RTOS等项目的源码。 【技术】 Java、Python、Node.js、Spring Boot、Django、Express、MySQL、PostgreSQL、MongoDB、React、Angular、Vue、Bootstrap、Material-UI、Redis、Docker、Kubernetes

    母亲节祝福html源码.docx

    母亲节祝福html源码 由于HTML是一种标记语言,主要用于网页的结构和内容展示,它本身并不包含大量的文本内容。但我可以为你提供一个简单的HTML页面模板,该模板包含一个针对母亲节的祝福页面,并给出一些建议和提示,以便你可以根据此模板扩展内容至接近2000字(这主要通过在页面中添加文本内容来实现,而不仅仅是HTML代码)。 以下是一个简单的HTML模板: html <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>母亲节祝福</title> <style> body { font-family: Arial, sans-serif; background-color: #f2f2f2; ma

    贪吃蛇.cpp

    贪吃蛇.cpp

    setuptools-65.6.2.tar.gz

    Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。

    2024年5月全国大众点评美食店铺信息,共550万余家 此处仅展示1万家,全量也有

    2024年5月全国大众点评美食店铺信息,共550万余家 。此处仅展示1万家,全量也有。 2024年5月最新大众点评店铺基础信息采集。含美食、休闲娱乐、结婚、电影演出赛事、丽人、酒店、亲子、周边游、运动健身、购物、家装、学习培训、医疗健康、爱车、宠物等十几大类共几千万家店铺信息。

    setuptools-60.7.1.tar.gz

    Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。

    模拟电子技术个人学习笔记

    个人学习上海交大郑益慧老师网课手写的笔记,同时结合自己学校老师的笔记资源。

    照明系统电缆设计软件.zip

    照明系统电缆设计软件

    setuptools-8.2.zip

    Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。

    公司财务部绩效考核表.xlsx

    公司财务部绩效考核表.xlsx

    Python源码-不那么枯燥的猜数游戏.py

    Python源码-不那么枯燥的猜数游戏

    k8s之安装资源ddddddd

    k8s之安装中用于配置cni

Global site tag (gtag.js) - Google Analytics