inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 인터셉터가 동작하지 않아 질문드립니다.

1818

안민재

작성한 질문수 5

0

안녕하세요, 스프링 MVC 강의를 완강이후 프로젝트를 수행중인 학부생입니다.

로그인 기능 구현과 관련하여 강의 예제 코드를 참고하며 구현하던 중

이해할 수 없는 현상이 발생하여 질문 드립니다.

 

코드

LoginInterceptor.java

package Alchole_free.Cockpybara.interceptor;

import Alchole_free.Cockpybara.constant.SessionLoginConst;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerInterceptor;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;


@Slf4j
//@Component
public class LoginInterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response,
                             Object handler) throws Exception {

        HttpSession session = request.getSession();
        log.info("session = {}", session);
        if(session==null || session.getAttribute(SessionLoginConst.LOGIN_MEMBER)==null){
            log.info("로그인되지 않은 사용자");
            response.sendRedirect("/login");
            return false;
        }

        log.info("정상 요청");

        return true;
    }
}

 

WebConfig.java

package Alchole_free.Cockpybara.config;

import Alchole_free.Cockpybara.interceptor.LoginInterceptor;
import lombok.RequiredArgsConstructor;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

//@Slf4j
@Configuration
//@RequiredArgsConstructor
public class WebConfig implements WebMvcConfigurer {

//    private final LoginInterceptor loginInterceptor;

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(new LoginInterceptor())
                .order(1)
                .addPathPatterns("/**")
                .excludePathPatterns("/", "/join", "/login",
                        "/css/**", "/*.ico", "/error");
    }
}

 

문제

위와 같이 코드를 구성하고 애플리케이션을 동작시켰는데, 인터셉터가 아예 로그에 남지

않는(생성되지 않는 것으로 보이는) 현상이 발생하였습니다. 관련하여 구글링을 하다보니

인터셉터 클래스를 빈으로 등록해주는 형태가 아니면 동작하지 않을 수 있다고 하여,

빈으로 등록하고 WebConfig 클래스에서 생성자를 통해 주입받는 형태로 구현도 해보았는데

여전히 같은 문제가 발생하더군요. 도대체 어느 부분에서 문제가 발생하는 것인지

파악하기가 힘들어 고민끝에 질문드립니다. 혹시 몰라 아래 빌드, 설정 파일도 첨부합니다.

 

문제 실행 화면

/hello 로 Controller @GetMapping 메서드를 구현해놓고 요청을 보냈으나 인터셉터 관련 로그가

기록되지 않는 모습입니다.

build.gradle

plugins {
	id 'java'
	id 'org.springframework.boot' version '2.7.13'
	id 'io.spring.dependency-management' version '1.0.15.RELEASE'
}

group = 'Alchole_free'
version = '0.0.1-SNAPSHOT'

java {
	sourceCompatibility = '11'
}

configurations {
	compileOnly {
		extendsFrom annotationProcessor
	}
}

repositories {
	mavenCentral()
}

dependencies {
	implementation 'org.springframework.boot:spring-boot-starter-data-jpa'
	implementation 'org.springframework.boot:spring-boot-starter-web'
	implementation 'org.springframework.boot:spring-boot-starter-validation'

	compileOnly 'org.projectlombok:lombok'
	runtimeOnly 'org.mariadb.jdbc:mariadb-java-client'
	annotationProcessor 'org.projectlombok:lombok'
	testImplementation 'org.springframework.boot:spring-boot-starter-test'

	//swagger 설정
	implementation group:'io.springfox', name:'springfox-swagger2', version:'2.8.0'
	implementation group:'io.springfox', name:'springfox-swagger-ui', version:'2.8.0'
}

tasks.named('test') {
	useJUnitPlatform()
}

 

application.properties

# ?????? ?? ??
spring.datasource.url=jdbc:mariadb://localhost:3306/cockpybara
spring.datasource.username=root
spring.datasource.password=cockpybara
spring.datasource.driver-class-name=org.mariadb.jdbc.Driver

# JPA ??
spring.jpa.show-sql=true
spring.jpa.hibernate.ddl-auto=create
spring.jpa.properties.hibernate.format_sql=true //JPA ???? Hibernate? ????? ???? SQL? formating?? ??
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL57Dialect

#show parameter binding
logging.level.org.hibernate.type.descriptor.sql=DEBUG
logging.level.org.hibernate.SQL=DEBUG

spring spring-interceptor jpa springboot

답변 1

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴이에요.

스프링 인터셉터가 동작하지 않는 문제입니다. 해당 코드를 봤을 때, LoginInterceptor 클래스 위에 주석 처리된 @Component 어노테이션이 있습니다. 이 어노테이션을 제거하고 @Component를 적용해보세요. 이렇게 하면 스프링이 해당 클래스를 빈으로 등록하고 인터셉터로 동작하게 됩니다.

또한, WebConfig 파일에도 인터셉터를 등록해야 합니다. WebConfig 클래스에 addInterceptors 메소드를 추가하여 인터셉터를 등록해주세요. 예를 들면 다음과 같이 작성할 수 있습니다.

@Configuration
public class WebConfig implements WebMvcConfigurer {

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(new LoginInterceptor())
                .addPathPatterns("/*")
                .excludePathPatterns("/login");
    }
}

위의 예제에서는 addInterceptor 메소드를 사용하여 인터셉터를 등록하고, .addPathPatterns 메소드를 사용하여 인터셉터가 동작할 URL 패턴을 지정합니다. 로그인 페이지 URL인 “/login”은 인터셉터를 제외하도록 설정하였습니다. 필요한 URL 패턴에 맞게 수정하여 사용해주세요.

이제 위의 내용을 확인하고 코드를 수정하여 보시면 스프링 인터셉터가 동작할 것입니다. 문제가 해결되지 않는다면 추가적인 내용을 알려주세요.

강의 중복 확인 요청

0

9

1

벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?

0

22

2

중복내용 제보?!

1

27

2

여러 파드 환경에서 단일 실행 보장 방식

0

26

2

inheritance startegy 선택시 고려사항

0

22

1

Entity 동등성 비교

0

18

1

패키지 구분에 대해 궁금한게 있습니다

0

26

2

스프링부트 서버 에러나요

0

26

1

코드 자료

0

51

2

조회속도 개선에서 더 개선하는 방법이 궁금합니다.

0

41

2

servlet과 container에 대한 질문입니다

0

29

1

RepositoryTest의 패키지 위치가 domain인 이유

0

36

2

도메인 모델에서 관계와 규칙을 구분하는 방법

0

53

2

16 강의 메세지 retryCount의 의도

0

29

2

JPA Repository 질문이 있습니다!

1

38

2

페이지네이션 처리를 쿼리에서 하는 방식 질문

1

38

1

UserService, CertificationService 책임 분리 기준 질문

0

28

1

spring initialiser 어떤걸 선택해야될지 모르겠어요

0

38

2

구현체가 동적으로 정해질 때, 팩토리 기법을 사용하나요?

0

58

2

Json 요청 처리

1

42

2

로그아웃-logout()-2 강에서 겟방식 로그아웃 호출 후 화면이동 질문입니다.

0

28

2

Build 관련 문제 (테스트 관련 문제)

0

44

2

job, step execution 관련 질문 드립니다.

0

45

2

실무 조언 관련 질문입니다.

0

44

1