간단하지만 생각보다 어려운 설정 문제로 인해서 한참 고생을 했다.
Spring Security에서 기존에 있는 공통 Expression 외에 별도의 Expression을 만드려고 했는데 이게 제대로 문서도 없고 관련 예제가 있는 곳도 없다.
결국 구글링으로 만들긴 만들었다만 이 간단한 커스텀 개발을 위해서 쓴 시간이 아깝긴 하다. 막상 만들고 보니 고민거리가 있어서 실제로 쓸지도 모르겠다.
이 부분을 위해서 삽질하는 분들에게 도움이 되길 바란다.
우선 custom expression에는 2가지 종류가 있다.
메서드단에 설정하는 MethodSecurityExpression과 웹쪽에 설정하는 WebSecurityExpression이 있다. 이것을 몰라서 Method만 갖고 한참 삽질을 했다.
MethodSecurityExpression은 관련 클래스나 용어로 찾다보면 자료가 많이 있다. WebSecurityExpression이 별로 없다.
Version
- 3.1.7을 기준으로 함
- 3.0.7을 사용하다가 DefaultWebSecurityExpressionHandler을 상속받아서 사용할 때 원하는 메서드가 없어서 3.1.7로 올려서 사용하게 되었음
- 3.1.7의 경우 Spring 3.0.7 Version에 대해 의존하고 있어서 다행히 문제되지 않음 ([4] 참조)
MethodSecurityExpression
- 관련 클래스
- DefaultMethodSecurityExpressionHandler
- SecurityExpressionRoot
- MethodSecurityExpressionOperations
- 메소드쪽에 제한 설정
- @PreAuthorize와 함께 사용
WebSecurityExpression
- 관련 클래스
- WebSecurityExpressionRoot
- DefaultWebSecurityExpressionHandler
- 웹쪽(xml or java config)에 설정
- http intercept-url access에 설정
spring-security.xml (3.0.7의 경우)
SpringSecurity 3.0 에서는 XML 태그를 통해 웹 전반에 관한 expressionHandler 설정이 불가능
access-decision-manager-ref를 지정함으로써만 가능 (권남 블로그 참조)
spring-security.xml (3.1.7의 경우)
CustomWebSecurityExpressionHandler.java
CustomSecurityExpressionRoot.java
기타 참고 소스 1 - CustomMethodSecurityExpression
CustomMethodSecurityExpressionHandler.java
CustomMethodSecurityExpressionRoot.java
기타 참고 소스 2 - CustomAuthenticationToken
CustomAuthenticationToken.java
SampleCode - JaasGrandtedAuthority(3.1.7 사용 가능), SimpleGrantedAuthority(상위 버전)를 사용하거나 GrantedAuthority를 직접 구현해서 사용
Reference
[1] 16. Expression-Based Access Control (http://docs.spring.io/autorepo/docs/spring-security/3.1.x/reference/el-access.html)
[2] 권남 Spring Security (http://kwonnam.pe.kr/wiki/springframework/security)
[3] Github 참고 소스 (https://gist.github.com/bmchild/1642655)
[4] Maven Repository - spring security 3.1.7 (http://mvnrepository.com/artifact/org.springframework.security/spring-security-core/3.1.7.RELEASE)
'Devlopment > Spring' 카테고리의 다른 글
RestController의 기본 컨텐츠 타입 변경 (0) | 2017.03.07 |
---|---|
Spring message 설정하기 (0) | 2017.02.20 |
Spring에서 Webjars 사용하기 (0) | 2017.02.20 |
[Spring Security] 필터 Filter, SecurityFilterChain 이해하기 (1) | 2017.02.08 |
[SpringSecurity] Method 레벨에서 AccessDeniedException 처리하기 (0) | 2017.02.07 |
Spring Security 관련 레퍼런스 정리 (0) | 2017.02.01 |
Jackson에서 null string 안 보이게 설정 (1) | 2016.08.12 |
JPA Hibernate 사용 중 ORA-00001: 무결성 제약 조건( ORA-00001 에러 (0) | 2016.06.07 |
Spring에서 기본적인 component-scan 설정 (0) | 2016.05.23 |
Spring에서 Pageable, Valid 설정 유의 설정 (0) | 2016.05.23 |