您好我有一个使用 Zend_Acl / 基于角色的访问控制的 Web 项目设置。
我有一个菜单表设置如下: id | INT(11) 名称 | VARCHAR(50) 访问级别 | 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);
我应该采取哪些步骤来确保菜单不会呈现给客人?