角色授权显示页面
数据库分析
查询某某角色所拥有的权限 根据role_id来查询所拥有的权限,角色Id是通过页面发送给后台的,所以不涉及角色表,只要中间表与权限表做内连接,查到Id为xxx的所有权限
打开授权页面显示角色名称
//location.href="${path}/system/role/toRoleModule.do?roleId="+id;
@RequestMapping(path="/toRoleModule",method ={ RequestMethod.GET, RequestMethod.POST})
public String toRoleModule(String roleId){//接收页面提交的roleId
//当前授权页面需要显示 角色名称
l.info("toRoleModule roleId="+roleId);
Role role = iRoleService.findById(roleId);
//数据转发到页面
request.setAttribute("role",role);
return "system/role/role-module";
}
role-module.jsp
<script type="text/javascript">
//当前的配置信息
var setting = {
check: {
enable: true
},
data: {
simpleData: {
enable: true
}
}
};
//当前的数据
/*var zNodes =[
{ id:1, pId:0, name:"Sass管理", open:true},
{ id:11, pId:1, name:"企业管理", open:true,checked:true},
{ id:111, pId:1, name:"模块管理"}
];*/
$(document).ready(function(){
var fn =function(data){
//菜单的初始化
$.fn.zTree.init($("#treeDemo"), setting, data);
//参1 显示的标签
//参2 设置的参数 比如支持复选 check enable = true
//参3 数据
}
$.get('${path}/system/role/getZtreeData.do?roleId=${role.roleId}',fn,'json')
});
</script>
RoleController
@RequestMapping(path="/getZtreeData",method ={ RequestMethod.GET, RequestMethod.POST})
public @ResponseBody Object getZtreeData(String roleId) {//接收页面提交的roleId
//所有的权限查询出来
List<Module> all = iModuleService.findAllModules();
//转换成 List<Map<String,Object>> { id:1, pId:0, name:"Sass管理", open:true},
List<Map<String,Object>> list = new ArrayList<>();
//返回给页面
for(Module m:all){
//生成一个集合 Map<String,Object> 表示一节点
Map<String,Object> node = new HashMap<String,Object>();
node.put("id",m.getModuleId());
node.put("pId",m.getParentId());
node.put("name",m.getName());
node.put("open",true);
//添加到集合中
list.add(node);
}
return list;//@ResponseBody将list转成json
}
给角色授权
//$.get('${path}/role/getZtreeData.do?roleId=${role.roleId}',fn,'json')
@RequestMapping(path="/getZtreeData",method ={ RequestMethod.GET, RequestMethod.POST})
public @ResponseBody Object getZtreeData(String roleId) {//接收页面提交的roleId
//所有的权限查询出来
List<Module> all = iModuleService.findAllModules();
//转换成 List<Map<String,Object>> { id:1, pId:0, name:"Sass管理", open:true},
//根据 roleId查 该角色的权限
List<Module> myList = iModuleService.findModuleByRoleId(roleId);
List<Map<String,Object>> list = new ArrayList<>();
//返回给页面
for(Module m:all){
//生成一个集合 Map<String,Object> 表示一节点
Map<String,Object> node = new HashMap<String,Object>();
node.put("id",m.getModuleId());
node.put("pId",m.getParentId());
node.put("name",m.getName());
node.put("open",true);
if(isInMyList(m,myList)){
node.put("checked",true);//为了在菜单页面上打上勾。有打勾就表示有这个权限,否则就是没有
}
//添加到集合中
list.add(node);
}
return list;//@ResponseBody将list转成json
}
//需要判断m是否在myList里面,如果在表示该角色有这个权限,否则没有
private boolean isInMyList(Module m, List<Module> myList) {
for(Module my:myList){
if(m.getModuleId().equals(my.getModuleId())){
l.info("isInMyList moduleId1 "+m.getModuleId()+" "+m.getName());
l.info("isInMyList moduleId2 "+my.getModuleId()+" "+my.getName());
return true;
}
}//end for 循环结束
return false;
}
使用ztree增加授权与减少授权
无论是增加授权,还是减少授权,全都要先把中间表里原来的权限删除,在添加上现在你拥有的权限
TestModuleService
//角色B的权限,更新权限
@Test
public void test07(){
//修改一个角色的权限,不仅仅是添加,也可能是减少
String roleId="4028a1cd4ee2d9d6014ee2df4c6a0010";
//String moduleIds="201,202";//减少指定角色的权限
String moduleIds="201,202,203";//添加角色的权限
iModuleService.updateRoleModule(roleId,moduleIds);
}
字符串的分割split()方法
split() 方法用于把一个字符串分割成字符串数组。
moduleIds =“202,203”;
String[] mids = moduleIds.split(",");
它的返回值为一个字符串数组
ModuleServiceImpl
@Override
public void updateRoleModule(String roleId, String moduleIds) {
//先做删除 指定角色在中间表中的记录
iModuleDao.deleteRoleModule(roleId);
//moduleIds 202,203
String[] mids = moduleIds.split(",");
if (mids.length > 0) { //判断,再操作
//再作添加
for (String mid : mids) {
iModuleDao.saveRoleModule(roleId, mid);
}
}
}
IModuleDao
RoleController
//${path}/system/role/updateRoleModule.do
@RequestMapping(path="/updateRoleModule",method ={ RequestMethod.GET, RequestMethod.POST})
public String updateRoleModule(String roleId,String moduleIds){//接收了页面提交的参数
l.info("updateRoleModule roleId="+roleId);
l.info("updateRoleModule moduleIds="+moduleIds);
//roleId=4028a1cd4ee2d9d6014ee2df4c6a0010
//moduleIds=202,203,204
iModuleService.updateRoleModule(roleId,moduleIds);
return "redirect:/system/role/toList.do";
}