spring-boot-plus V 1.4.0 통합 사용자 역할 권한 부서 관리 발표(추천)
사용자 역할 권한 부서 관리 핵심 인터페이스 소개
Shiro 권한 설정
👉 Shiro 권한 설정
데이터베이스 모형 도
👉 spring-boot-plus SQL 다운로드 초기 화
인증번호 가 져 오기
인증번호 데모
spring-boot-plus:
# ansi
enable-ansi: true
#
enable-verify-code: true
enable-verify-code
을 true
으로 설정 하여 인증 코드 인증 사용 하기인증 코드 가 져 오기
인증 코드 백 엔 드 는 Redis 에 저 장 됩 니 다.만 료 시간 은 기본적으로 5 분 입 니 다.
방식 1:
그림 을 브 라 우 저 로 출력 하고 인증 코드 token 을 응답 헤드 로 출력 합 니 다.
http://localhost:8888/verificationCode/getImage
Response Headers
HTTP/1.1 200
verifyToken: 6515b4b798ce49e68b1e40f98ff8eb19
방식 2:Base 64 인 코딩 그림 과 인증 코드 token 가 져 오기
http://localhost:8888/verificationCode/getBase64Image
{
"code": 200,
"msg": " ",
"success": true,
"data": {
"image": "",
"verifyToken": "42ba8abde7bc47b2b1397b4d6676956a"
},
"time": "2019-11-01 22:40:37"
}
시스템 사용자 로그 인POST 요청,Content-Type:
application/json
http://127.0.0.1:8888/login 요청 매개 변수
{
"code": " ",
"password": "123456",
"username": "admin",
"verifyToken": " token"
}
주의 하 다.username
과 password
{
"code": 200,
"msg": " ",
"success": true,
"data": {
"token": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJhdWQiOiJ3ZWIiLCJpc3MiOiJzcHJpbmctYm9vdC1wbHVzIiwiZXhwIjoxNTcyNjIzMDE5LCJpYXQiOjE1NzI2MTk0MTksImp0aSI6IjdlZmVlM2UwMjc2MTRiYTc5M2I2YmYwZmE4NTgzYmUwIiwidXNlcm5hbWUiOiJhZG1pbiJ9.O3w7CNRqw_Miwp8MDzPND6w490c9Q7yFlKpFJK9ubSU",
"loginSysUserVo": {
"id": "1",
"username": "admin",
"nickname": " ",
"gender": 1,
"state": 1,
"departmentId": "1",
"departmentName": " ",
"roleId": "1",
"roleName": " ",
"roleCode": "admin",
"permissionCodes": [
"sys:permission:codes",
"system:management",
"sys:department:update",
"sys:department:page",
"sys:role:management",
"sys:permission:add",
"sys:user:add",
"sys:role:page",
"sys:permission:page",
"sys:department:delete",
"sys:permission:management",
"sys:user:delete",
"sys:department:management",
"sys:user:page",
"sys:user:update",
"sys:user:update:password",
"sys:user:update:head",
"sys:role:add",
"sys:permission:menu:tree",
"sys:department:info",
"sys:permission:all:menu:list",
"sys:permission:info",
"sys:role:info",
"sys:permission:all:menu:tree",
"sys:permission:update",
"sys:permission:menu:list",
"sys:role:update",
"sys:user:info",
"sys:user:management",
"sys:role:delete",
"sys:permission:delete"
]
}
},
"time": "2019-11-01 22:43:39"
}
############################ JWT start #############################
jwt:
# 1 , :
expire-second: 3600
다른 권한 부여 접근 이 필요 한 인터페이스,요청 헤드 는 token 을 휴대 해 야 합 니 다.
부서 트 리 목록
부 서 는 N 레벨 로 설정 할 수 있 으 며,백 엔 드 는 재 귀 를 사용 하여 부서 목록 을 트 리 목록 으로 변환 할 수 있 습 니 다.
SysDepartmentServiceImpl
@Override
public List<SysDepartmentTreeVo> getAllDepartmentTree() {
List<SysDepartment> sysDepartmentList = getAllDepartmentList();
if (CollectionUtils.isEmpty(sysDepartmentList)) {
throw new IllegalArgumentException("SysDepartment ");
}
List<SysDepartmentTreeVo> list = SysDepartmentConvert.INSTANCE.listToTreeVoList(sysDepartmentList);
List<SysDepartmentTreeVo> treeVos = new ArrayList<>();
for (SysDepartmentTreeVo treeVo : list) {
if (treeVo.getParentId() == null) {
treeVos.add(findChildren(treeVo, list));
}
}
return treeVos;
}
/**
*
*
* @param tree
* @param list
* @return
*/
public SysDepartmentTreeVo findChildren(SysDepartmentTreeVo tree, List<SysDepartmentTreeVo> list) {
for (SysDepartmentTreeVo vo : list) {
if (tree.getId().equals(vo.getParentId())) {
if (tree.getChildren() == null) {
tree.setChildren(new ArrayList<>());
}
tree.getChildren().add(findChildren(vo, list));
}
}
return tree;
}
전단 JSON 구조http://127.0.0.1:8888/sysDepartment/getAllDepartmentTree
역할 관리
캐릭터 권한 설정
@Transactional(rollbackFor = Exception.class)
@Override
public boolean updateSysRole(UpdateSysRoleParam updateSysRoleParam) throws Exception {
Long roleId = updateSysRoleParam.getId();
List<Long> permissionIds = updateSysRoleParam.getPermissionIds();
//
SysRole sysRole = getById(roleId);
if (sysRole == null) {
throw new BusinessException(" ");
}
//
if (!sysPermissionService.isExistsByPermissionIds(permissionIds)) {
throw new BusinessException(" id ");
}
//
sysRole.setName(updateSysRoleParam.getName())
.setType(updateSysRoleParam.getType())
.setRemark(updateSysRoleParam.getRemark())
.setState(updateSysRoleParam.getState())
.setUpdateTime(new Date());
boolean updateResult = updateById(sysRole);
if (!updateResult) {
throw new DaoException(" ");
}
// id
List<Long> beforeList = sysRolePermissionService.getPermissionIdsByRoleId(roleId);
//
// before:1,2,3,4,5,6
// after: 1,2,3,4,7,8
// 5,6 7,8
// , deleted @TableLogic
Set<Long> beforeSet = new HashSet<>(beforeList);
Set<Long> afterSet = new HashSet<>(permissionIds);
SetUtils.SetView deleteSet = SetUtils.difference(beforeSet, afterSet);
SetUtils.SetView addSet = SetUtils.difference(afterSet, beforeSet);
log.debug("deleteSet = " + deleteSet);
log.debug("addSet = " + addSet);
//
UpdateWrapper updateWrapper = new UpdateWrapper();
updateWrapper.eq("role_id",roleId);
updateWrapper.in("permission_id",deleteSet);
boolean deleteResult = sysRolePermissionService.remove(updateWrapper);
if (!deleteResult) {
throw new DaoException(" ");
}
//
boolean addResult = sysRolePermissionService.saveSysRolePermissionBatch(roleId, addSet);
if (!addResult) {
throw new DaoException(" ");
}
return true;
}
권한 관리권한 트 리 목록
@Override
public List<SysPermissionTreeVo> getAllMenuTree() throws Exception {
List<SysPermission> list = getAllMenuList();
//
List<SysPermissionTreeVo> treeVos = convertSysPermissionTreeVoList(list);
return treeVos;
}
@Override
public List<SysPermissionTreeVo> convertSysPermissionTreeVoList(List<SysPermission> list) {
if (CollectionUtils.isEmpty(list)) {
throw new IllegalArgumentException("SysPermission ");
}
// level map
Map<Integer, List<SysPermission>> map = list.stream().collect(Collectors.groupingBy(SysPermission::getLevel));
List<SysPermissionTreeVo> treeVos = new ArrayList<>();
//
for (SysPermission one : map.get(LevelEnum.ONE.getKey())) {
SysPermissionTreeVo oneVo = SysPermissionConvert.INSTANCE.permissionToTreeVo(one);
Long oneParentId = oneVo.getParentId();
if (oneParentId == null || oneParentId == 0) {
treeVos.add(oneVo);
}
List<SysPermission> twoList = map.get(LevelEnum.TWO.getKey());
if (CollectionUtils.isNotEmpty(twoList)) {
for (SysPermission two : twoList) {
SysPermissionTreeVo twoVo = SysPermissionConvert.INSTANCE.permissionToTreeVo(two);
if (two.getParentId().equals(one.getId())) {
oneVo.getChildren().add(twoVo);
}
List<SysPermission> threeList = map.get(LevelEnum.THREE.getKey());
if (CollectionUtils.isNotEmpty(threeList)) {
for (SysPermission three : threeList) {
if (three.getParentId().equals(two.getId())) {
SysPermissionTreeVo threeVo = SysPermissionConvert.INSTANCE.permissionToTreeVo(three);
twoVo.getChildren().add(threeVo);
}
}
}
}
}
}
return treeVos;
}
전단 JSON 형식http://127.0.0.1:8888/sysPermission/getAllMenuTree
권한 인 코딩 목록
현재 사용자 의 모든 권한 인 코딩 을 되 돌려 줍 니 다.전단 에 네 비게 이 션 메뉴 와 기능 단 추 를 보 여 줍 니 다.
http://127.0.0.1:8888/sysPermission/getPermissionCodesByUserId/1
{
"code": 200,
"msg": " ",
"success": true,
"data": [
"system:management",
"system:management",
"sys:user:management",
"sys:user:management",
"sys:role:management",
"sys:permission:management",
"sys:department:management",
"sys:user:add",
"sys:user:add",
"sys:user:update",
"sys:user:update",
"sys:user:delete",
"sys:user:delete",
"sys:user:info",
"sys:user:info",
"sys:user:page",
"sys:user:page",
"sys:user:update:password",
"sys:user:update:head",
"sys:role:add",
"sys:role:update",
"sys:role:delete",
"sys:role:info",
"sys:role:page",
"sys:permission:add",
"sys:permission:update",
"sys:permission:delete",
"sys:permission:info",
"sys:permission:page",
"sys:permission:all:menu:list",
"sys:permission:all:menu:tree",
"sys:permission:menu:list",
"sys:permission:menu:tree",
"sys:permission:codes",
"sys:department:update",
"sys:department:delete",
"sys:department:info",
"sys:department:page"
],
"time": "2019-11-02 00:32:17"
}
주의 하 다.Shiro 주석@RequiresPermissions 를 사용 하여 controller 방법 권한 필터 링
@RequiresPermissions("sys:department:add")
코드 생 성 시 Requires Permissions 주석 생 성 설정 가능
// Shiro RequiresPermissions
codeGenerator.setRequiresPermissions(true);
생 성 또는 추 가 된 controller 방법,권한 관리 가 필요 합 니 다.syspermission 표 에 권한 인 코딩 기록 을 추가 하고 해당 캐릭터 에 권한 을 부여 합 니 다.총결산
위 에서 말씀 드 린 것 은 편집장 님 께 서 소개 해 주신 spring-boot-plus V 1.4.0 이 통합 사용자 역할 권한 부서 관 리 를 발표 하여 여러분 께 도움 이 되 기 를 바 랍 니 다.궁금 한 점 이 있 으 시 면 메 시 지 를 남 겨 주세요.편집장 님 께 서 신속하게 답 해 드 리 겠 습 니 다.여기 서도 저희 사이트 에 대한 여러분 의 지지 에 감 사 드 립 니 다!
만약 당신 이 본문 이 당신 에 게 도움 이 된다 고 생각한다 면,전 재 를 환영 합 니 다.번 거 로 우 시 겠 지만 출처 를 밝 혀 주 십시오.감사합니다!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
thymeleaf로 HTML 페이지를 동적으로 만듭니다 (spring + gradle)지난번에는 에서 화면에 HTML을 표시했습니다. 이번에는 화면을 동적으로 움직여보고 싶기 때문에 입력한 문자를 화면에 표시시키고 싶습니다. 초보자의 비망록이므로 이상한 점 등 있으면 지적 받을 수 있으면 기쁩니다! ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.