SpringBoot 사용자 정의 주석 권한 제어
1659 단어 springboot+springcloud
권한 제 어 를 실현 하면 shiro 를 선택 할 수 있 지만, shiro 가 무 거 워 서 사용 할 필요 가 없고, springBoot 의 op 방식 으로 사용자 정의 주 해 를 실현 할 수 있 습 니 다
1. 사용자 정의 주석 을 정의 합 니 다.
@Target({ElementType.PARAMETER, ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface PermissionNeed {
String value() default "";
}
2. aop 의 사용
@Aspect
@Component
public class LovePiAspect {
@Pointcut("@annotation(permissionNeed)")
public void annotationPointCut(PermissionNeed permissionNeed) {
}
@Before("annotationPointCut(permissionNeed)")
public void before(JoinPoint joinPoint,PermissionNeed permissionNeed){
MapperMethod.MethodSignature sign = (MapperMethod.MethodSignature)joinPoint.getSignature();
System.out.print(" :"+" ");
String permission = permissionNeed.value();
//
//
Set userPrivilegeSet = OAuthUserContext.getUserPrivilegeSet();
// ,
if(!userPrivilegeSet.contains(permission)){
throw new AppException(ApiResponseCode.PROMPT.get()," ");
}
}
}
userPrivailegeSet 는 요청 이나 로그 인 할 때마다 모든 권한 을 가 져 오고 threadLocal 을 스 레 드 로 저장 할 수 있 습 니 다.권한 이 만족 하지 않 아 사용자 정의 이상 을 던 집 니 다.
3. 사용자 정의 주석 사용
@ResponseBody
@RequestMapping(value = "/",method = RequestMethod.GET)
@PermissionNeed(value = "sys:user:login")
public String home() {
return "Hello World!";
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
thymeleaf로 HTML 페이지를 동적으로 만듭니다 (spring + gradle)지난번에는 에서 화면에 HTML을 표시했습니다. 이번에는 화면을 동적으로 움직여보고 싶기 때문에 입력한 문자를 화면에 표시시키고 싶습니다. 초보자의 비망록이므로 이상한 점 등 있으면 지적 받을 수 있으면 기쁩니다! ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.