ad5081d3
孙向锦
初始化项目
|
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
|
* 修改时间:2015年11月6日
* @version
*/
@Controller
@RequestMapping(value="/role")
public class RoleController extends BaseController {
String menuUrl = "role.do"; //菜单地址(权限用)
@Resource(name="menuService")
private MenuManager menuService;
@Resource(name="roleService")
private RoleManager roleService;
@Resource(name="userService")
private UserManager userService;
@Resource(name="appuserService")
private AppuserManager appuserService;
@Resource(name="fhlogService")
private FHlogManager FHLOG;
/** 进入权限首页
* @param
* @return
* @throws Exception
*/
@RequestMapping
public ModelAndView list()throws Exception{
ModelAndView mv = this.getModelAndView();
PageData pd = new PageData();
try{
pd = this.getPageData();
if(pd.getString("ROLE_ID") == null || "".equals(pd.getString("ROLE_ID").trim())){
pd.put("ROLE_ID", "1"); //默认列出第一组角色(初始设计系统用户和会员组不能删除)
}
PageData fpd = new PageData();
fpd.put("ROLE_ID", "0");
List<Role> roleList = roleService.listAllRolesByPId(fpd); //列出组(页面横向排列的一级组)
List<Role> roleList_z = roleService.listAllRolesByPId(pd); //列出此组下架角色
pd = roleService.findObjectById(pd); //取得点击的角色组(横排的)
mv.addObject("pd", pd);
mv.addObject("roleList", roleList);
mv.addObject("roleList_z", roleList_z);
mv.addObject("QX",Jurisdiction.getHC()); //按钮权限
mv.setViewName("system/role/role_list");
} catch(Exception e){
logger.error(e.toString(), e);
}
return mv;
}
/**去新增页面
* @param
* @return
*/
@RequestMapping(value="/toAdd")
public ModelAndView toAdd(){
ModelAndView mv = this.getModelAndView();
PageData pd = new PageData();
try{
pd = this.getPageData();
mv.addObject("msg", "add");
mv.setViewName("system/role/role_edit");
mv.addObject("pd", pd);
} catch(Exception e){
logger.error(e.toString(), e);
}
return mv;
}
/**保存新增角色
* @return
* @throws Exception
*/
@RequestMapping(value="/add",method=RequestMethod.POST)
public ModelAndView add()throws Exception{
if(!Jurisdiction.buttonJurisdiction(menuUrl, "add")){return null;} //校验权限
logBefore(logger, Jurisdiction.getUsername()+"新增角色");
ModelAndView mv = this.getModelAndView();
PageData pd = new PageData();
try{
pd = this.getPageData();
String parent_id = pd.getString("PARENT_ID"); //父类角色id
|
ad5081d3
孙向锦
初始化项目
|
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
|
pd.put("ROLE_ID", parent_id);
if("0".equals(parent_id)){
pd.put("RIGHTS", ""); //菜单权限
}else{
String rights = roleService.findObjectById(pd).getString("RIGHTS");
pd.put("RIGHTS", (null == rights)?"":rights); //组菜单权限
}
pd.put("ROLE_ID", this.get32UUID()); //主键
pd.put("ADD_QX", "0"); //初始新增权限为否
pd.put("DEL_QX", "0"); //删除权限
pd.put("EDIT_QX", "0"); //修改权限
pd.put("CHA_QX", "0"); //查看权限
roleService.add(pd);
FHLOG.save(Jurisdiction.getUsername(), "新增角色:"+pd.getString("ROLE_NAME"));
} catch(Exception e){
logger.error(e.toString(), e);
mv.addObject("msg","failed");
}
mv.setViewName("save_result");
return mv;
}
/**请求编辑
* @param ROLE_ID
* @return
* @throws Exception
*/
@RequestMapping(value="/toEdit")
public ModelAndView toEdit( String ROLE_ID )throws Exception{
ModelAndView mv = this.getModelAndView();
PageData pd = new PageData();
try{
pd = this.getPageData();
pd.put("ROLE_ID", ROLE_ID);
pd = roleService.findObjectById(pd);
mv.addObject("msg", "edit");
mv.addObject("pd", pd);
mv.setViewName("system/role/role_edit");
} catch(Exception e){
logger.error(e.toString(), e);
}
return mv;
}
/**保存修改
* @return
* @throws Exception
*/
@RequestMapping(value="/edit")
public ModelAndView edit()throws Exception{
if(!Jurisdiction.buttonJurisdiction(menuUrl, "edit")){return null;} //校验权限
logBefore(logger, Jurisdiction.getUsername()+"修改角色");
ModelAndView mv = this.getModelAndView();
PageData pd = new PageData();
try{
pd = this.getPageData();
roleService.edit(pd);
FHLOG.save(Jurisdiction.getUsername(), "修改角色:"+pd.getString("ROLE_NAME"));
mv.addObject("msg","success");
} catch(Exception e){
logger.error(e.toString(), e);
mv.addObject("msg","failed");
}
mv.setViewName("save_result");
return mv;
}
/**删除角色
* @param ROLE_ID
* @return
* @throws Exception
*/
@RequestMapping(value="/delete")
@ResponseBody
public Object deleteRole(@RequestParam String ROLE_ID)throws Exception{
if(!Jurisdiction.buttonJurisdiction(menuUrl, "del")){return null;} //校验权限
logBefore(logger, Jurisdiction.getUsername()+"删除角色");
Map<String,String> map = new HashMap<String,String>();
PageData pd = new PageData();
String errInfo = "";
try{
pd.put("ROLE_ID", ROLE_ID);
List<Role> roleList_z = roleService.listAllRolesByPId(pd); //列出此部门的所有下级
if(roleList_z.size() > 0){
errInfo = "false"; //下级有数据时,删除失败
}else{
List<PageData> userlist = userService.listAllUserByRoldId(pd); //此角色下的用户
List<PageData> appuserlist = appuserService.listAllAppuserByRorlid(pd); //此角色下的会员
if(userlist.size() > 0 || appuserlist.size() > 0){ //此角色已被使用就不能删除
errInfo = "false2";
}else{
roleService.deleteRoleById(ROLE_ID); //执行删除
FHLOG.save(Jurisdiction.getUsername(), "删除角色ID为:"+ROLE_ID);
errInfo = "success";
}
}
} catch(Exception e){
logger.error(e.toString(), e);
}
map.put("result", errInfo);
return AppUtil.returnObject(new PageData(), map);
}
/**
* 显示菜单列表ztree(菜单授权菜单)
* @param model
* @return
*/
@RequestMapping(value="/menuqx")
public ModelAndView listAllMenu(Model model,String ROLE_ID)throws Exception{
ModelAndView mv = this.getModelAndView();
try{
Role role = roleService.getRoleById(ROLE_ID); //根据角色ID获取角色对象
String roleRights = role.getRIGHTS(); //取出本角色菜单权限
List<Menu> menuList = menuService.listAllMenuQx("0"); //获取所有菜单
menuList = this.readMenu(menuList, roleRights); //根据角色权限处理菜单权限状态(递归处理)
JSONArray arr = JSONArray.fromObject(menuList);
String json = arr.toString();
json = json.replaceAll("MENU_ID", "id").replaceAll("PARENT_ID", "pId").replaceAll("MENU_NAME", "name").replaceAll("subMenu", "nodes").replaceAll("hasMenu", "checked");
model.addAttribute("zTreeNodes", json);
mv.addObject("ROLE_ID",ROLE_ID);
mv.setViewName("system/role/menuqx");
} catch(Exception e){
logger.error(e.toString(), e);
}
return mv;
}
/**保存角色菜单权限
* @param ROLE_ID 角色ID
* @param menuIds 菜单ID集合
* @param out
* @throws Exception
*/
@RequestMapping(value="/saveMenuqx")
public void saveMenuqx(@RequestParam String ROLE_ID,@RequestParam String menuIds,PrintWriter out)throws Exception{
if(!Jurisdiction.buttonJurisdiction(menuUrl, "edit")){} //校验权限
logBefore(logger, Jurisdiction.getUsername()+"修改菜单权限");
FHLOG.save(Jurisdiction.getUsername(), "修改角色菜单权限,角色ID为:"+ROLE_ID);
PageData pd = new PageData();
try{
if(null != menuIds && !"".equals(menuIds.trim())){
BigInteger rights = RightsHelper.sumRights(Tools.str2StrArray(menuIds));//用菜单ID做权处理
Role role = roleService.getRoleById(ROLE_ID); //通过id获取角色对象
role.setRIGHTS(rights.toString());
roleService.updateRoleRights(role); //更新当前角色菜单权限
pd.put("rights",rights.toString());
}else{
Role role = new Role();
role.setRIGHTS("");
role.setROLE_ID(ROLE_ID);
roleService.updateRoleRights(role); //更新当前角色菜单权限(没有任何勾选)
pd.put("rights","");
}
pd.put("ROLE_ID", ROLE_ID);
if(!"1".equals(ROLE_ID)){ //当修改admin权限时,不修改其它角色权限
roleService.setAllRights(pd); //更新此角色所有子角色的菜单权限
}
out.write("success");
out.close();
} catch(Exception e){
logger.error(e.toString(), e);
}
}
/**请求角色按钮授权页面(增删改查)
* @param ROLE_ID: 角色ID
* @param msg: 区分增删改查
* @param model
* @return
* @throws Exception
*/
@RequestMapping(value="/b4Button")
public ModelAndView b4Button(@RequestParam String ROLE_ID,@RequestParam String msg,Model model)throws Exception{
ModelAndView mv = this.getModelAndView();
try{
List<Menu> menuList = menuService.listAllMenuQx("0"); //获取所有菜单
Role role = roleService.getRoleById(ROLE_ID); //根据角色ID获取角色对象
String roleRights = "";
if("add_qx".equals(msg)){
roleRights = role.getADD_QX(); //新增权限
}else if("del_qx".equals(msg)){
roleRights = role.getDEL_QX(); //删除权限
}else if("edit_qx".equals(msg)){
roleRights = role.getEDIT_QX(); //修改权限
}else if("cha_qx".equals(msg)){
roleRights = role.getCHA_QX(); //查看权限
}
menuList = this.readMenu(menuList, roleRights); //根据角色权限处理菜单权限状态(递归处理)
JSONArray arr = JSONArray.fromObject(menuList);
String json = arr.toString();
json = json.replaceAll("MENU_ID", "id").replaceAll("PARENT_ID", "pId").replaceAll("MENU_NAME", "name").replaceAll("subMenu", "nodes").replaceAll("hasMenu", "checked");
model.addAttribute("zTreeNodes", json);
mv.addObject("ROLE_ID",ROLE_ID);
mv.addObject("msg", msg);
} catch(Exception e){
logger.error(e.toString(), e);
}
mv.setViewName("system/role/b4Button");
return mv;
}
/**根据角色权限处理权限状态(递归处理)
* @param menuList:传入的总菜单
* @param roleRights:加密的权限字符串
* @return
*/
public List<Menu> readMenu(List<Menu> menuList,String roleRights){
for(int i=0;i<menuList.size();i++){
menuList.get(i).setHasMenu(RightsHelper.testRights(roleRights, menuList.get(i).getMENU_ID()));
this.readMenu(menuList.get(i).getSubMenu(), roleRights); //是:继续排查其子菜单
}
return menuList;
}
/**
* 保存角色按钮权限
*/
/**
* @param ROLE_ID
* @param menuIds
* @param msg
* @param out
* @throws Exception
*/
@RequestMapping(value="/saveB4Button")
public void saveB4Button(@RequestParam String ROLE_ID,@RequestParam String menuIds,@RequestParam String msg,PrintWriter out)throws Exception{
if(!Jurisdiction.buttonJurisdiction(menuUrl, "edit")){} //校验权限
logBefore(logger, Jurisdiction.getUsername()+"修改"+msg+"权限");
FHLOG.save(Jurisdiction.getUsername(), "修改"+msg+"权限,角色ID为:"+ROLE_ID);
PageData pd = new PageData();
pd = this.getPageData();
try{
if(null != menuIds && !"".equals(menuIds.trim())){
BigInteger rights = RightsHelper.sumRights(Tools.str2StrArray(menuIds));
pd.put("value",rights.toString());
}else{
pd.put("value","");
}
pd.put("ROLE_ID", ROLE_ID);
roleService.saveB4Button(msg,pd);
out.write("success");
out.close();
} catch(Exception e){
logger.error(e.toString(), e);
}
}
}
|