Chinaunix首页 | 论坛 | 博客
  • 博客访问: 166319
  • 博文数量: 47
  • 博客积分: 10
  • 博客等级: 民兵
  • 技术积分: 466
  • 用 户 组: 普通用户
  • 注册时间: 2012-10-31 23:12
个人简介

知乎:http://www.zhihu.com/people/chanpinjinglizhilu

文章分类

全部博文(47)

分类: PHP

2013-10-15 17:16:22

今天逛博客园,看到一篇面试官问:程序画面怎么和权限结合起来?去年用ZendFramework做的一个投资管理系统权限模块关键思路分享给大家。

因为是总公司的一个项目,内部使用。所以就不存在市场调研,我主要负责获取资源,建立项目时间点,跟踪进展情况,确定关键路径,在需要时获得额外资源,与管理层保持沟通,需求整理,用例图,当时团队人不是很多,测试也自己包了


下面是那原博文链接
http://www.cnblogs.com/nianming/p/3369280.html


1.管理系统权限角色:要求有默认用户属于风控   股东   业务员   财务其中一个角色,其中每个用户的权限可能会因业务需求发生变化,下面是分配权限界面。







2.流程


3.核心代码 

点击(此处)折叠或打开

  1. class Plugin_AclAccess extends Zend_Controller_Plugin_Abstract
  2. {
  3.      public function preDispatch(Zend_Controller_Request_Abstract $request)
  4.      {
  5.         $login = new Zend_Session_Namespace('member');
  6.         $cont=$this->getRequest()->getControllerName();
  7.         $action=$this->getRequest()->getActionName();
  8.         /* Initialize action controller here */
  9.         if(!in_array($cont."_".$action,array("member_login")))
  10.         {
  11.         if (!$login->name) { //如果Session中的name值存在
  12.             //执行后跳转至信息提示页面,并且指定ID值为 loginno
  13.             header("Location: ".SITE_URL."/member/login");
  14.             exit('Access Denied'); //结束当前访问
  15.         }
  16.         }
  17.         $acl_config = new Zend_Config_Ini(APPLICATION_PATH . '/configs/acl.ini', "config");
  18.         $admin_list=explode(",",$acl_config->adminlist);
  19.         if(!empty($login->uid)&&!in_array($login->name,$admin_list))
  20.         {
  21.         $this->_CheckAccess($login->uid);        
  22.         }
  23.         
  24.      }


这套系统前后总共用了三个月,前期预计是两个月,后来因为一个程序离职,加长了项目项目时间。初期的框架是我选择与搭建的,后面基本没怎么参与,因为是管理系统属于个性需求,目前市场上又没找到类似的开源。最后决定重新自己用ZF框架来写,费了很大劲。如果项目比较赶的话,建议还是用开源程序改,至少用户表,登录机制不用自己重新写了,团队的同鞋们辛苦了。
阅读(2316) | 评论(0) | 转发(0) |
0

上一篇:没有了

下一篇:awk个人总结

给主人留下些什么吧!~~