权限管理,就是给不同的用户分配不同的权限。当用户登录或者操作时候进行判断,来阻止用户进行权限以外的操作。本次讲的是当用户登录一刻,只显示权限开启的内容。
一、建立数据库。
1、权限表funcla。来存储录入所有权限,也是避免因权限名称修改了,权限失效的问题。
2、管理员表admin。主要存储管理员用户名等信息。
3、管理员对应权限表funadmin。主要存储已开启的管理员id与权限id。
二、输出权限列表。
1、通过管理员列表进入权限分配。
2、权限分配列表。
关于权限分配列表,因为权限板块的不同,我们需要区别顶级分类与其子集。并且还需要显示权限状态。在权限状态判断中也使用了一层循环判断。代码中采用了三层嵌套循环输出。具体代码如下。
1 <div>分配管理员{$username}的权限</div> 2 <table width="100%" border="0" cellpadding="0" cellspacing="0" class="list_table mt10"> 3 <tr> 4 <th>权限名称</th> 5 <th>状态</th> 6 7 </tr> 8 <volist name="funcla" id="v" key="j"> 9 <tr class="tr"> 10 <td>{$v.claname}</td> 11 <td><input <volist name="funadmin" id="d"><if condition="$d['funclaid'] eq $v['id']">checked</if></volist> type="checkbox" >> 12 </tr> 13 <volist name="fun" id="vo"> 14 <if condition="$vo['clapid'] eq $v['id']"> 15 <tr class="tr"> 16 <td style="padding-left: 40px;" >{$vo.claname}</td> 17 18 <td> 19 20 <input <volist name="funadmin" id="d"><if condition="$d['funclaid'] eq $vo['id']">checked</if></volist> type="checkbox" /> 21 22 </td> 23 24 </tr> 25 </if> 26 </volist> 27 </volist> 28 </table>