//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>';
}
}
复制代码 这些资源、角色、动作,在以上代码片段里,是作为硬编码存在的,实际项目中,可以作为数据在数据库里保存。灵活应用就需要程序员的智慧了。