inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 MVC 2편 - 백엔드 웹 개발 활용 기술

인터셉터가 제대로 동작하지 않습니다.

391

안민재

작성한 질문수 5

0

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

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

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

 

코드

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

# DataSource
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=update
spring.jpa.properties.hibernate.format_sql=true 
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 mvc

답변 1

0

David

안녕하세요. 안민재님, 공식 서포터즈 David입니다.

프로젝트 공유를 요청드리기 전에 아래 사항을 시도해봐 주실 수 있으실까요?

인터셉터 내 브레이크 포인트 걸고, 디버그 모드로 실행하셔서 요청이 인터셉터를 타는지 안타는지 확인 부탁드립니다.

만약 안 탄다면 빈 등록 과정이나 설정에서 문제가 있는건데 딱히 문제될 사항이 보이진 않아서요!

감사합니다.

0

안민재

요청 자체가 인터셉터를 걸치지 않는 것 같습니다.

프로젝트 코드는 혹시 ZIP 형태로 제공해드리면 될까요?

다른 파트 구현을 하느라 답변이 늦었습니다. 죄송합니다.

0

David

답변이 늦어져 죄송합니다.

 

아래 가이드를 참고하여 공유 부탁드립니다.

구글 드라이브 업로드 방법은 다음을 참고해주세요.

https://bit.ly/3fX6ygx


주의: 업로드시 링크에 있는 권한 문제 꼭 확인해주세요


추가로 다음 내용도 코멘트 부탁드립니다.

1. 문제 영역을 실행할 수 있는 방법

2. 문제가 어떻게 나타나는지에 대한 상세한 설명


이미지 업로드와 db 트랜잭션 묶는법

0

47

1

Could not resolve org.springframework.boot:spring-boot-starter-validation:2.4.4

0

58

2

MessageSourceTest 코드

0

49

1

인터셉터 에러 설정

0

48

1

resolveArgument()메서드 질문

0

58

1

43강 검증1 에서 실패 로직 관련 질문있습니다.

0

60

2

타임리프 3.X 버전 rendering, serializer 에러 해결 방법

2

133

3

스프링 빈에 등록이 안되는거 같은데 어떻게 하면 좋을까요?ㅠㅠ

0

93

3

pdf 오타 문의

0

57

1

ItemUpdateForm 검증 관련 질문입니다.

0

50

1

22page 링크 주소 변경

0

59

2

특정 데이터와 파일을 함께 저장 시, 테이블 구조 질문

0

53

1

섹션3번 수업에 대한 질문입니다.

0

81

2

@Autowired 보다 더 좋은 방법이 어떤 걸까요?

0

87

2

타입컨버터 가 람다랑 비슷해 보이는데 저의 생각이 맞는지?.

0

66

1

자바스크립트 인라인에서 객체 직렬화 시 오류가 납니다

0

143

3

스프링부트 - 오류페이지2 에서 500.html 에서 쓰인 객체 질문

0

65

1

톰캣 에러 페이지가 안보입니다.

0

105

2

apiEceptionController에서 센드 에러 호출하면 안되는지?

0

81

1

세션 타임아웃시 쿠키 삭제 방법이 없나요?

0

119

2

ApiExceptionController 질문드립니다.

0

64

1

셀렉박스 챕터에서 option value에 ==배송 방식 선택== 이것을 넣은 이유가 궁금함, 이렇게 구상해도 되는지?

0

67

1

MemberRepository 필드의 fianl 선언 유무

0

85

2

혹시 index.html 에서는 fragment 사용이 안되는건가요

0

59

1