权限控制修改角色code不存在问题
This commit is contained in:
@ -1,10 +1,9 @@
|
|||||||
package com.chinaunicom.mall.ebtp.cloud.security.starter.filter;
|
package com.chinaunicom.mall.ebtp.cloud.security.starter.filter;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Optional;
|
import java.util.Objects;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
import javax.servlet.FilterChain;
|
import javax.servlet.FilterChain;
|
||||||
import javax.servlet.ServletException;
|
import javax.servlet.ServletException;
|
||||||
@ -90,8 +89,9 @@ public class TokenAuthenticationFilter extends OncePerRequestFilter {
|
|||||||
SecurityUser securityUser = entity.getBody();
|
SecurityUser securityUser = entity.getBody();
|
||||||
|
|
||||||
// 根据当前角色设定权限列表
|
// 根据当前角色设定权限列表
|
||||||
List<RoleCodeAuthority> authorities = Optional.ofNullable(currentRoleCode)
|
List<RoleCodeAuthority> authorities = securityUser.getAuthorityList().stream()
|
||||||
.map(o -> Arrays.asList(new RoleCodeAuthority(o))).orElse(Collections.emptyList());
|
.filter(auth -> Objects.equals(auth.getRoleCode(), currentRoleCode))
|
||||||
|
.map(auth -> new RoleCodeAuthority(auth.getRoleCode())).collect(Collectors.toList());
|
||||||
|
|
||||||
return new UsernamePasswordAuthenticationToken(securityUser.setCurrentRoleCode(currentRoleCode), token,
|
return new UsernamePasswordAuthenticationToken(securityUser.setCurrentRoleCode(currentRoleCode), token,
|
||||||
authorities);
|
authorities);
|
||||||
|
Reference in New Issue
Block a user