Menu Pro Zend框架技术的访问控制?

时间:2013-10-21 09:44:17

标签: php mysql zend-framework

您好我有一个基于Zend_Acl / Role的访问控制的Web项目设置。

我有一个菜单表设置如下: id | INT(11) 名字| VARCHAR(50) access_level | VARCHAR(50)

目前,所有菜单的访问级别字段都设置为空。

在布局中:

$this->layout()->adminMenu = $this->action('render', 'menu', null, array('menu' => $this->adminMenuId));

菜单控制器的渲染操作:

public function renderAction()
    {
        $menu = $this->_request->getParam('menu');
        $mdlMenuItems = new Model_Menuitem();
        $menuItems = $mdlMenuItems->getItemByMenu($menu);

        if (count($menuItems) > 0)
        {
            foreach ($menuItems as $item)
            {
                $label = $item->label;
                if(!empty($item->link))
                {
                    $uri = $item->link;
                }
                else
                {
                    $uri = '/page/' . $item->page_id;
                }
            $itemArray[] = array(   'label' => $label,
                                    'uri' => $uri);
            }
            $container = new Zend_Navigation($itemArray);
            $this->view->navigation()->setContainer($container);
        }
    }

Acl详情:

            $acl->addRole(new Zend_Acl_Role('guest'));
        $acl->addRole(new Zend_Acl_Role('readonly'), 'guest');
        $acl->addRole(new Zend_Acl_Role('administrator'), 'readonly');

//设置访问规则         $ acl-> allow(null,array('index','error'));

//guest can only read content and login
        $acl->allow('guest', 'page', array('index', 'error'));
        $acl->allow('guest', 'user', array('login'));
        $acl->deny('guest', 'menu', array('render'));
        $acl->allow('administrator', null);

我应该采取哪些措施来确保菜单无法呈现给客人?

1 个答案:

答案 0 :(得分:-1)

您可以使用以下

访问授权用户的身份
    $auth = Zend_Auth::getInstance();
    $identity = $auth->getIdentity();