有了部门模块、部门下面用户模块,接下来就是权限模块的开发。
一、参数校验
对模块名称、排序、状态、备注做校验,并指定默认的父id 为0
public class AclModuleParam {
private Integer id;
@NotBlank(message = "权限模块名称不可以为空")
@Length(min = 2, max = 20, message = "权限模块名称长度需要在2~20个字之间")
private String name;
private Integer parentId = 0;
@NotNull(message = "权限模块展示顺序不可以为空")
private Integer seq;
@NotNull(message = "权限模块状态不可以为空")
@Min(value = 0, message = "权限模块状态不合法")
@Max(value = 1, message = "权限模块状态不合法")
private Integer status;
@Length(max = 200, message = "权限模块备注需要在200个字之间")
private String remark;
}
二、权限模块树的开发
1、适配两个dto:权限模块的、权限点的(权限模块应该挂钩权限点)
public class AclModuleLevelDto extends SysAclModule {
private List<AclModuleLevelDto> aclModuleList = Lists.newArrayList();
//权限模块下挂钩权限
private List<AclDto> aclList = Lists.newArrayList();
public static AclModuleLevelDto adapt(SysAclModule aclModule) {
AclModuleLevelDto dto = new AclModuleLevelDto();
BeanUtils.copyProperties(aclModule, dto);
return dto;
}
}
public class AclDto extends SysAcl{
// 是否要默认选中
private boolean checked = false;
// 是否有权限操作
private boolean hasAcl = false;
public static AclDto adapt(SysAcl acl) {
AclDto dto = new AclDto();
BeanUtils.copyProperties(acl, dto);
return dto;
}
}
2、Service层:CRUD
package com.mmall.service;
import com.google.common.base.Preconditions;
import com.mmall.common.RequestHolder;
import com.mmall.dao.SysAclMapper;
import com.mmall.dao.SysAclModuleMapper;
import com.mmall.exception.ParamException;
import com.mmall.model.SysAclModule;
import com.mmall.param.AclModuleParam;
import com.mmall.util.BeanValidator;
import com.mmall.util.IpUtil;
import com.mmall.util.LevelUtil;
import org.apache.commons.collections.CollectionUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import javax.annotation.Resource;
import java.util.Date;
import java.util.List;
@Service
public class SysAclModuleService {
@Autowired
private SysAclModuleMapper sysAclModuleMapper;
@Autowired
private SysAclMapper sysAclMapper;
@Resource
private SysLogService sysLogService;
public void save(AclModuleParam param) {
BeanValidator.check(param);
if(checkExist(param.getParentId(), param.getName(), param.getId())) {
throw new ParamException("同一层级下存在相同名称的权限模块");
}
SysAclModule aclModule = SysAclModule.builder().name(param.getName()).parentId(param.getParentId()).seq(param.getSeq())
.status(param.getStatus()).remark(param.getRemark()).build();
aclModule.setLevel(LevelUtil.calculateLevel(getLevel(param.getParentId()), param.getParentId()));
aclModule.setOperator(RequestHolder.getCurrentUser().getUsername());
aclModule.setOperateIp(IpUtil.getRemoteIp(RequestHolder.getCurrentRequest()));
aclModule.setOperateTime(new Date());
sysAclModuleMapper.insertSelective(aclModule);
sysLogService.saveAclModuleLog(null, aclModule);
}
public void update(AclModuleParam param) {
BeanValidator.check(param);
if(checkExist(param.getParentId(), param.getName(), param.getId())) {
throw new ParamException("同一层级下存在相同名称的权限模块");
}
SysAclModule before = sysAclModuleMapper.selectByPrimaryKey(param.getId());
Preconditions.checkNotNull(before, "待更新的权限模块不存在");
SysAclModule after = SysAclModule.builder().id(param.getId()).name(param.getName()).parentId(param.getParentId()).seq(param.getSeq())
.status(param.getStatus()).remark(param.getRemark()).build();
after.setLevel(LevelUtil.calculateLevel(getLevel(param.getParentId()), param.getParentId()));
after.setOperator(RequestHolder.getCurrentUser().getUsername());
after.setOperateIp(IpUtil.getRemoteIp(RequestHolder.getCurrentRequest()));
after.setOperateTime(new Date());
updateWithChild(before, after);
sysLogService.saveAclModuleLog(before, after);
}
@Transactional
protected void updateWithChild(SysAclModule before, SysAclModule after) {
String newLevelPrefix = after.getLevel();
String oldLevelPrefix = before.getLevel();
if (!after.getLevel().equals(before.getLevel())) {
List<SysAclModule> aclModuleList = sysAclModuleMapper.getChildAclModuleListByLevel(before.getLevel());
if (CollectionUtils.isNotEmpty(aclModuleList)) {
for (SysAclModule aclModule : aclModuleList) {
String level = aclModule.getLevel();
if (level.indexOf(oldLevelPrefix) == 0) {
level = newLevelPrefix + level.substring(oldLevelPrefix.length());
aclModule.setLevel(level);
}
}
sysAclModuleMapper.batchUpdateLevel(aclModuleList);
}
}
sysAclModuleMapper.updateByPrimaryKeySelective(after);
}
public void delete(Integer aclModuleId) {
SysAclModule aclModule = sysAclModuleMapper.selectByPrimaryKey(aclModuleId);
Preconditions.checkNotNull(aclModule, "待删除的权限模块不存在,无法删除");
if(sysAclModuleMapper.countByParentId(aclModule.getId()) > 0) {
throw new ParamException("当前模块下面有子模块,无法删除");
}
if (sysAclMapper.countByAclModuleId(aclModule.getId()) > 0) {
throw new ParamException("当前模块下面有用户,无法删除");
}
sysAclModuleMapper.deleteByPrimaryKey(aclModuleId);
}
private boolean checkExist(Integer parentId, String aclModuleName, Integer deptId) {
return sysAclModuleMapper.countByNameAndParentId(parentId, aclModuleName, deptId) > 0;
}
private String getLevel(Integer aclModuleId) {
SysAclModule aclModule = sysAclModuleMapper.selectByPrimaryKey(aclModuleId);
if (aclModule == null) {
return null;
}
return aclModule.getLevel();
}
}
3、Control层
package com.mmall.controller;
import com.mmall.common.JsonData;
import com.mmall.param.AclModuleParam;
import com.mmall.service.SysAclModuleService;
import com.mmall.service.SysTreeService;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.servlet.ModelAndView;
import javax.annotation.Resource;
@Controller
@RequestMapping("/sys/aclModule")
public class SysAclModuleController {
private final static Logger log = LoggerFactory.getLogger(SysAclModuleController.class);
@Autowired
SysAclModuleService sysAclModuleService;
@Autowired
private SysTreeService sysTreeService;
@RequestMapping("/save.json")
@ResponseBody
public JsonData saveAclModule(AclModuleParam param) {
sysAclModuleService.save(param);
return JsonData.success();
}
@RequestMapping("/update.json")
@ResponseBody
public JsonData updateAclModule(AclModuleParam param) {
sysAclModuleService.update(param);
return JsonData.success();
}
@RequestMapping("/delete.json")
@ResponseBody
public JsonData delete(@RequestParam("id") int id) {
sysAclModuleService.delete(id);
return JsonData.success();
}
@RequestMapping("/tree.json")
@ResponseBody
public JsonData tree() {
return JsonData.success(sysTreeService.aclModuleTree());
}
@RequestMapping("/acl.page")
public ModelAndView page() {
return new ModelAndView("acl");
}
}