phphot

php,linux,mysql,apache

小秘密ID:phphot
825913次访问,排名38好友61人,关注者172
php,apache,mysql,linux,html,css,javascript
phphot的文章
原创 3280 篇
翻译 0 篇
转载 11 篇
评论 574 篇
phphot的公告


经典推荐!!!
史上最全的小白兔的笑话

从一则笑话分析需求的陷阱

本科差点没能毕业,工作五年后年收入过百万

从小公司到500强 80年代人的面试宝典

那些雷得我们如此销魂的台词

老IT人追忆十五年IT从业经历

汶川大地震牛B语录集锦

千百万学子未来几年的出路

大学时代影响我的人生的10件大事-前辈的经验

噩梦的那一年-程序员之路

成功的背后!(给所有IT人)

一部让大学生少奋斗10年的成功宝典

职业生涯中12个最致命的想法

华为面试,第三轮被拒,想哭

一个牛人给java初学者的建议

黑客帝国之PHP与ASP.net不得不说的故事

一个应界毕业生的深圳求职经历。

程序人生:女程序员的求职奋斗史

2008春晚诗朗诵《心里话》之程序员版

最高境界---笑到肚子疼!!!!

是非人生——一个菜鸟程序员的5年人生路

网友10年跳槽经验总结

2008年IT行业10大热门职业调查结果出炉

百度实习经验总结

一点感慨,与诸君共勉,正式告别程序员生涯

程序员V.S.编程语言你上“贼船”了吗

上海IT精英群体某些行为特征被妖魔化

五百强各大行业简介+面试流程及技巧

08年各大公司薪水最新行情全面曝光


XML聚合
feedsky
最近评论
Lee:这篇文章写得很不错,分析得很透彻,为新手指明了方向
恋上你的泪:太对了 为程序员们致敬!!!!!!!
ba527:我在2005上开发的程序,升级到2008就不能使用LINQ TO XML了。不知道为什么。

已经引用了System.Xml.Linq。
热舞人:斯蒂芬
Ian:這些文字如果是在一年半至兩年前看到了話,
說不定眼淚會很不爭氣的滴下來,
但是在現在的我,
看完這些文字,
還是能感同身受的~
文章分类
收藏
    相册
    YY的图(禁)
    绝对精彩
    网上好图(禁)
    我的工作(禁)
    我的作品(禁)
    热门站
    baidu
    google
    yahoo
    存档
    订阅我的博客
    XML聚合  FeedSky

    原创 Zend Framework 中的认证和授权浅见收藏

    新一篇: Borland以2300万美元卖掉CodeGear开发工具部门 | 旧一篇: 重签劳动合同,公司会害我吗?

        --兼谈权限系统设计的一些问题

        Zend Framework 作为 PHP 的一个官方编程框架,刚一推出来就引起了震动,大家把它简称为“ZF”。看来 PHP 已经在寻求向企业开发市场进军。但是由于推出时间短,熟悉 ZF 的开发人员,特别是国内的程序员,对 ZF 了解的还不多。现在市面上还找不到一本专门介绍 ZF 的图书,现有的资料,大部分是英文版,Zend 公司与中国公司合作翻译的 Zend FrameWork 中文手册,还是个烂尾工程,而且是 1.0 或 1.2 版本的,最新的 ZF 1.5.1 资料更少。而用 ZF 全程编写的产品更是凤毛麟角。

        有人说,ZF 简直就是 ROR 的翻版,看来 ZF 应该具有当前流行的动态语言的优点,特别是对 MVC 的良好支持,

        了解 ZF 的人,应该对 ZF 的权限管理印象深刻。ZF 手册在第一章的简介之后,第二章就拉出 Zend_Acl(访问控制授权)来介绍,而第三章就是Zend_Auth 的内容(认证)。从知识认知的顺序上,我个人感觉这样安排的不合适的。事实上第二和第三章的内容介绍,牵扯了众多后续章节的内容,我们不得不从第 7 章 Zend_Controller 开始看起。

        但是不得不承认 ZF 的认证和授权是个优秀的设计。ZF 的认证相对简单,我们可以直接连接数据库表,对用户输入的用户名和密码进行比较,确认当前用户的身份。还提供了摘要式认证等方法。而 ACL(访问控制列表)提供的授权就很强大。

        ACL 提出了资源、角色、动作(访问)三个概念,用这些概念可以轻易构造一个强大的权限管理系统。而且权限管理可以细化到模块下的浏览、添加、删除、修改等细微 动作。(ASP.NET 只能控制到页面(模块)级别,更细致的控制需要程序员自己设计和实现)。这里粘一些代码,仅仅是说明一下(在 IIS6.0 + ZF1.51 + Apache2.2 下调试的):

         //4种角色:admin, editor, guest, auditor, poweruser
         //4种资源:channel, item, bbs, blog
         //3种动作:view, edit, revise
         //要求:
         //admin对所有资源有所有权限
         //guest对所有资源只有view权限
         //editor对channel, item, bbs有view, edit权限
         //auditor对channel, item, bbs, blog有revise权限
         //poweruser继承editor, auditor权限

          //定义角色
          $acl = new Zend_Acl();

          $roleAdmin = new Zend_Acl_Role('admin');
          $acl->addRole($roleAdmin);
          $roleEditor = new Zend_Acl_Role('editor');
          $acl->addRole($roleEditor);
          $roleGuest = new Zend_Acl_Role('guest');
          $acl->addRole($roleGuest);
          $roleAuditor = new Zend_Acl_Role('auditor');
          $acl->addRole($roleAuditor);
          $rolePoweruser = new Zend_Acl_Role('poweruser');
          $acl->addRole($rolePoweruser, array('editor', 'auditor'));

          //添加资源
          $acl->add(new Zend_Acl_Resource('channel'));
          $acl->add(new Zend_Acl_Resource('item'));
          $acl->add(new Zend_Acl_Resource('bbs'));
          $acl->add(new Zend_Acl_Resource('blog'));

          //分配权限
          //admin:
          $acl->allow($roleAdmin, null, null);

          //editor:
          $acl->allow('editor', array('channel', 'item', 'bbs'), array('view', 'edit'));

          //guest:
          $acl->allow('guest', null, 'view');

          //auditor:
          $acl->allow('auditor', array('channel', 'item', 'bbs', 'blog'), array('revise'));

          //poweruser(从 editor, auditor 继承权限),可以再叠加另外的权限
          //$acl->allow('poweruser', null, null);

          //给所有角色分配权限(包括 admin)
          //$acl->allow(null, '', '');
          //$acl->deny(null, '', '');

          查看以上代码的最终权限,可以参考一下代码:

          foreach (array('admin', 'editor', 'guest', 'auditor', 'poweruser') as $role)
          {
           echo '<br>' . '角色 ' . $role . '<br>';
           echo '<table border=1>';
           echo '<tr><td align=center>\</td><th>channel</th><th>item</th><th>bbs</th><th>blog</th></tr>';
            foreach (array('view', 'edit', 'revise') as $right)
            {
              echo '<tr>';
              echo '<th>'. $right .'</th>';
              foreach (array('channel', 'item', 'bbs', 'blog') as $resource)
              {
               echo '<td>';
                  echo $acl->isAllowed($role, $resource, $right)?"allowed" : "denied";
               echo '</td>';
              }
              echo '</tr>';
            }
            echo '</table>';
          }
        }

        这些资源、角色、动作,在以上代码片段里,是作为硬编码存在的,实际项目中,可以作为数据在数据库里保存。灵活应用就需要程序员的智慧了。

        ZF 的用户,只划分到“角色”这一级,也就是说,不能给某个用户直接分配权限。这肯定是出于简化设计而考虑的,否则设计和实现会复杂的多!这个有个小缺点,就 是要为一个用户分配权限,必须首先建一个角色(相当于用户组),再把该用户加入到该角色下,通过角色来给该用户分配权限。而权限设计中,用户、角色、资 源、动作的相互包含、交叉,其结果导致问题变得非常复杂!这么复杂的逻辑关系,不借助其他工具(例如计算机),人的大脑大多数情况下是很难想明白的。

    发表于 @ 2008年05月11日 14:34:57|评论(loading...)|编辑

    新一篇: Borland以2300万美元卖掉CodeGear开发工具部门 | 旧一篇: 重签劳动合同,公司会害我吗?

    评论:没有评论。

    发表评论  


    登录
    Csdn Blog version 3.1a
    Copyright © phphot