`
freeboat
  • 浏览: 37829 次
  • 性别: 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 是一组允许你控制对象(用户,远程主机等)访问其他对象(网页,数据库等)权限的函数.  该组函数可以通过简单的管理提供高精度的访问控制,并且运行地...

    ASP.NET某中学图书馆系统的设计与实现(源代码+论文).zip

    ASP.NET是一种基于.NET框架的服务器端编程模型,用于构建高性能、易于维护的Web应用程序。在这个中学图书馆系统的案例中,开发者利用ASP.NET的技术栈设计并实现了这样一个功能丰富的平台,旨在为中学生、教师以及图书馆管理员提供方便的信息管理和检索服务。下面我们将深入探讨这个系统的核心知识点。 1. **ASP.NET架构**:ASP.NET提供了多种开发模式,如Web Forms、MVC、Web API和Blazor。本系统可能采用了Web Forms或MVC架构,这两种模式都支持事件驱动和模型-视图-控制器(MVC)设计原则,便于创建动态网页和处理用户交互。 2. **数据库设计**:图书馆系统通常需要管理书籍信息、借阅记录、用户账户等数据,因此数据库设计是关键。可能使用了SQL Server或MySQL等关系型数据库,通过ADO.NET或Entity Framework进行数据访问,实现CRUD(创建、读取、更新、删除)操作。 3. **身份验证与授权**:为了确保系统安全,。内容来源于网络分享,如有侵权请联系我删除。另外如果没有积分的同学需要下载,请私信我。

    图书管理系统(基于ASP .NET)

    《图书管理系统(基于ASP .NET)》是一款专为学习者设计的应用程序,旨在提供一个全面的图书管理平台。系统的设计采用ASP .NET技术,这是一款由微软开发的用于构建动态网站、web应用和web服务的强大工具。ASP .NET框架以其高效、安全和易于维护的特点,深受开发者的喜爱。 该系统包含了多个核心模块,这些模块覆盖了图书管理的主要功能。有图书录入模块,它允许管理员录入图书的基本信息,如书名、作者、出版社、ISBN号、分类等。图书查询模块提供给用户方便快捷的搜索功能,用户可以根据书名、作者、关键词等条件进行检索。此外,借阅与归还模块确保图书的流通管理,记录图书的借阅状态,提醒用户按时归还,并处理超期罚款等事务。 系统还具备用户管理模块,允许用户注册、登录、修改个人信息。对于权限管理,后台有专门的管理员角色,他们可以对用户进行操作,如分配权限、冻结或解冻账户。同时,系统的统计分析模块能够生成各类报表,如图书借阅量、热门书籍、用户活跃度等,这些数据对于图书馆运营决策有着重要参考价值。 在。内容来源于网络分享,如有侵权请联系我删除。另外如果没有积分的同学需要下载,请私信我。

    思维导图制作-会计初级知识重难点-会计务实-会计基础

    本专刊的主要目的是帮助初学者系统化和结构化地掌握会计知识。我们采用思维导图的形式,将复杂的会计概念和流程进行有效的简化,旨在让学习者能够更清晰地理解这些内容,并增强记忆效果。通过视觉化的方式,读者不仅能够感受到会计知识的关联性,还能轻松掌握关键点,提升学习效率。无论是在学习新知识还是复习旧知识时,这种方法都能够为学习者提供极大的便利和帮助。

    精选毕设项目-todolist,带简易后端.zip

    精选毕设项目-todolist,带简易后端

    精选毕设项目-美食菜谱.zip

    精选毕设项目-美食菜谱

    精选毕设项目-地图定位.zip

    精选毕设项目-地图定位

    精选毕设项目-学富网家教电商平台.zip

    精选毕设项目-学富网家教电商平台

    精选毕设项目-乐租租房工具.zip

    精选毕设项目-乐租租房工具

    chromedriver-linux64_123.0.6296.0.zip

    chromedriver-linux64_123.0.6296.0

    永磁同步电机,基于扩展卡尔曼滤波算法无传感器仿真模型,s函数编写算法,基于matlab simulink搭建 附参考资料

    永磁同步电机,基于扩展卡尔曼滤波算法无传感器仿真模型,s函数编写算法,基于matlab simulink搭建。 附参考资料

    factoryio液位PID仿真程序 使用简单的梯形图编写,通俗易懂,起到抛砖引玉的作用,比较适合有动手能力的入门初学者 软件环境: 1、西门子编程软件:TIA Portal V15(博图V15)

    factoryio液位PID仿真程序 使用简单的梯形图编写,通俗易懂,起到抛砖引玉的作用,比较适合有动手能力的入门初学者。 软件环境: 1、西门子编程软件:TIA Portal V15(博图V15) 2、FactoryIO 2.4.0 内容清单: 1、FactoryIO中文说明书+场景模型文件 2、博图V15PLC程序(源码)。

    comsol光学仿真 任意偏振态BIC,利用扭转光子晶体实现远场偏振的调控,包含能带,品质因子计算以及远场辐射偏振椭圆绘制

    comsol光学仿真 任意偏振态BIC,利用扭转光子晶体实现远场偏振的调控,包含能带,品质因子计算以及远场辐射偏振椭圆绘制

    基于STM32的智能家居控制系统.zip

    STM32使用技巧,实战应用开发小系统参考资料,源码参考。经测试可运行。 详细介绍了一些STM32框架的各种功能和模块,以及如何使用STM32进行应用开发等。 适用于初学者和有经验的开发者,能够帮助你快速上手STM32并掌握其高级特性。。内容来源于网络分享,如有侵权请联系我删除。另外如果没有积分的同学需要下载,请私信我。

    基于数据驱动进化算法的风电场布局优化研究与应用

    内容概要:本文提出了一种数据驱动进化算法(ADE-GRNN)来优化风电场布局,旨在最大化风电场功率输出并减少计算时间。文中引入了自适应差分演化算法和通用回归神经网络来训练数据驱动模型,通过快速过滤低效候选解来提高求解效率。同时详细描述了风力发电机组的位置排布对功率产生成关键影响的因素如湍流效应以及不同算法(ADE、JADE、CLPSO)间的性能对比实验结果。研究表明,在多个评估指标方面,所提出的 ADE-GRNN 方法均表现出显著优势。 适合人群:对于希望深入理解智能算法在工程实践中特别是新能源领域的应用的研发人员和技术爱好者非常适合。 使用场景及目标:用于需要高效能解决复杂组合最优化问题的企业或项目组,特别是在涉及大规模风电场布局规划时的目标定位是提升能源转换率,降低成本消耗,提高运算速度。 其他说明:未来的研究可以进一步考虑更为复杂的风电场拓扑结构及更精确地模拟尾流效应,并探索三维空间下最优布局的可能性;此外还可以尝试不同的机器学习方法来稳定代理模型的表现。

    电流计算方法:.docx

    电流计算方法:.docx

    精选毕设项目-茶叶商城(含后端).zip

    精选毕设项目-茶叶商城(含后端)

    精选毕设项目-化妆品商城.zip

    精选毕设项目-化妆品商城

    chromedriver-linux64_123.0.6286.0.zip

    chromedriver-linux64_123.0.6286.0

    智慧图书管理系统设计与实现-springboot毕业项目,适合计算机毕-设、实训项目、大作业学习.zip

    Spring Boot是Spring框架的一个模块,它简化了基于Spring应用程序的创建和部署过程。Spring Boot提供了快速启动Spring应用程序的能力,通过自动配置、微服务支持和独立运行的特性,使得开发者能够专注于业务逻辑,而不是配置细节。Spring Boot的核心思想是约定优于配置,它通过自动配置机制,根据项目中添加的依赖自动配置Spring应用。这大大减少了配置文件的编写,提高了开发效率。Spring Boot还支持嵌入式服务器,如Tomcat、Jetty和Undertow,使得开发者无需部署WAR文件到外部服务器即可运行Spring应用。 Java是一种广泛使用的高级编程语言,由Sun Microsystems公司(现为Oracle公司的一部分)在1995年首次发布。Java以其“编写一次,到处运行”(WORA)的特性而闻名,这一特性得益于Java虚拟机(JVM)的使用,它允许Java程序在任何安装了相应JVM的平台上运行,而无需重新编译。Java语言设计之初就是为了跨平台,同时具备面向对象、并发、安全和健壮性等特点。 Java语言广泛应用于企业级应用、移动应用、桌面应用、游戏开发、云计算和物联网等领域。它的语法结构清晰,易于学习和使用,同时提供了丰富的API库,支持多种编程范式,包括面向对象、命令式、函数式和并发编程。Java的强类型系统和自动内存管理减少了程序错误和内存泄漏的风险。随着Java的不断更新和发展,它已经成为一个成熟的生态系统,拥有庞大的开发者社区和持续的技术创新。Java 8引入了Lambda表达式,进一步简化了并发编程和函数式编程的实现。Java 9及以后的版本继续在模块化、性能和安全性方面进行改进,确保Java语言能够适应不断变化的技术需求和市场趋势。 MySQL是一个关系型数据库管理系统(RDBMS),它基于结构化查询语言(SQL)来管理和存储数据。MySQL由瑞典MySQL AB公司开发,并于2008年被Sun Microsystems收购,随后在2010年,Oracle公司收购了Sun Microsystems,从而获得了MySQL的所有权。MySQL以其高性能、可靠性和易用性而闻名,它提供了多种特性来满足不同规模应用程序的需求。作为一个开源解决方案,MySQL拥有一个活跃的社区,不断为其发展和改进做出贡献。它的多线程功能允许同时处理多个查询,而其优化器则可以高效地执行复杂的查询操作。 随着互联网和Web应用的快速发展,MySQL已成为许多开发者和公司的首选数据库之一。它的可扩展性和灵活性使其能够处理从小规模应用到大规模企业级应用的各种需求。通过各种存储引擎,MySQL能够适应不同的数据存储和检索需求,从而为用户提供了高度的定制性和性能优化的可能性。

Global site tag (gtag.js) - Google Analytics