다른 로그인 방식으로 로그인 한 사용자를 같은 세션으로 처리하는 방법

‍bng4535·2023년 3월 24일
0

문제 상황

글의 조회수 기능을 구현하고 있다. 다음과 같은 방식으로 세션과 addAttribute를 활용하면 구현할 수 있다고 생각했다.

    String viewKey = "_q"+id;
        if(!isHit(req,viewKey)){  //현재 세션으로 처음 방문
			//조회수 증가
        }
        
    private boolean isHit(HttpServletRequest req, String viewKey){
        return (String)req.getSession().getAttribute(viewKey) != null;
    }

    // 현재 세션으로 페이지에 처음 접속한다면 viewKey를 key로 추가
    private void setHit(HttpServletRequest req, String viewKey){
        req.getSession().setAttribute(viewKey,true);
    }

문제점

  • 현재 Form login 방식과 OAuth2 방식으로 로그인을 구현하였고, 같은 이메일 계정일 때 같은 사용자로 처리하도록 코드를 작성하였으므로, 위 소스코드를 적용하면 같은 사용자이더라도 서로 다른 사용자로 구분한다. (Spring Security에서 로그인 방식에 따라 세션을 알아서 생성해줌)

해결방안

- 위 포스트에서 서로 다른 로그인 방식으로 로그인 한 사용자는 서로 다른 사용자로 취급하기로 하였다.

결과

https://github.com/hanbonghun/spring-QA-board/commit/a1ddb8f31c82959d67fba7f3024ec0d210364b71

후기

  • Spring Security는 기능이 매우 많고 복잡하다. 처음에는 자주 활용되니까 공통적인 구현 방식이 있겠거니하고 다른 코드를 보면서 이해하려 했는데 도무지 이해가 안됐다. 그래서 블로그나 유튜브의 강의를 통해 Oauth2가 어떻게 동작하는지 먼저 이해를 하고 코드를 다시 천천히 보았고 전체적인 흐름의 이해와 내 상황에 맞게 코드를 수정할 수 있게 되었다. 시간이 오래 걸렸지만 구현했을 때 매우 뿌듯했다.
  • http 요청이 들어온다

  • http.authorizeHttpRequests()를 통해 설정된 체인을 거친다

  • AuthenticationManager가 인증 요청을 처리할 수 있는 provider를 찾는다

  • 해당 provider는 인증 방식에 맞는Service를 수행하여 인증에 성공한 User를 반환한다


  • DefaultOAuth2UserService나 UserDetailsService를 구현하고 해당 인터페이스의 메서드를 구현하여 사용하는 것은, Authentication Provider가 인증을 어떻게 처리할지에 대한 명세

  • AuthenticationManager은 이러한 인증 Provider 중 적절한 Provider를 선택하여 인증을 수행

   @Bean
    AuthenticationManager authenticationManager(AuthenticationConfiguration authenticationConfiguration) throws Exception {
        return authenticationConfiguration.getAuthenticationManager();
    }
  • 위 코드는 프로바이더를 관리하는 매니저를 등록하는 과정이며, 매니저가 등록될 때 프로바이더가 등록되고 프로바이더가 어떤 과정을 통해 인증을 수행할 것인지도 등록된다.

참고

Oauth2 동작 과정 : https://lotuus.tistory.com/83
구글 로그인 : https://lotuus.tistory.com/79
Form, Oauth2 로그인 구현 : https://lotuus.tistory.com/78
WEB2 - Oauth2 : https://www.youtube.com/watch?v=hm2r6LtUbk8&t=3s

profile
공부 기록

0개의 댓글