inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 핵심 원리 - 기본편

Thread.sleep 질문입니다.

해결된 질문

194

이찬진

작성한 질문수 3

0

제가 이해한 바로는 챕터9장 request스코프 강의에서 Thread.sleep을 이용해서 request소멸을 지연하였습니다.

이때 sleep메서드는 InterruptedException를 가지고 있기때문에 예외처리를 해줘야합니다.

그래서 throws로 예외를 넘겼는데 어떻게 처리되는 건지 궁금합니다.

package hello.core2.web;

import hello.core2.common.MyLogger;
import hello.core2.logdemo.LogDemoService;
import jakarta.servlet.http.HttpServletRequest;
import lombok.RequiredArgsConstructor;
import org.springframework.beans.factory.ObjectProvider;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

@Controller
@RequiredArgsConstructor
public class LogDemoController {

    private final LogDemoService logDemoService;
    private final ObjectProvider<MyLogger> myLoggerProvider;    //의존관계 주입이 일어남 -> MyLogger는 스코프가 request이다.
    //request의 생존범위는 고객의 요청이 들어오고 나오기까지의 범위이다.
    //그런데 고객의 요청이들어오지를 않으니 오류가 난다.

    @RequestMapping("log-demo")
    @ResponseBody   //뷰 화면이 없으므로 ResponseBody로 바로 반환
    //원래는 뷰리졸버에게 템플릿을 넘긴다.
    public String logDemo(HttpServletRequest request) throws InterruptedException {
        MyLogger myLogger = myLoggerProvider.getObject();// getObject를 호출시키게해서 request 요청을 한다.
        String requestURL = request.getRequestURL().toString();
        myLogger.setRequestURL(requestURL); //request 시작

        myLogger.log("controller test");
        Thread.sleep(1000);
        logDemoService.logic("testId");     //request 요청 마지막
        //request close
        //request 요청이 끝남
        return "OK";
    }
}

spring 객체지향

답변 1

0

David

안녕하세요. 이찬진님, 공식 서포터즈 David입니다.

DispatcherServlet에서 핸들러를 호출하는 쪽을 보면 핸들러 내에서 예외가 터지면 이 예외를 받아서 처리하는 부분이 있습니다. 여기서 처리되어집니다.

자세한 코드는 다음 링크를 참고해 주세요.

https://github.com/spring-projects/spring-framework/blob/main/spring-webmvc/src/main/java/org/springframework/web/servlet/DispatcherServlet.java#L1098

감사합니다🙂

코드 자료

0

45

2

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

0

55

2

MemberService의 인터페이스를 왜 사용하는지 궁금합니다.

0

76

1

롬복 @Setter를 써야 하는 상황이 있는건가요?

0

91

1

빈 등록 메서드의 파라미터가 빈이 아니어도 되나요?

0

81

1

테스트 속도가 나중에 영향이 있을까요?

0

77

1

gradle 설정 안떠서 질문 남깁니다!

0

121

2

build.gradle로 프로젝트를 여는 이유

0

86

1

provider 사용하는 이유

0

89

1

다음 강의 뭘 들어야 할까요

0

126

2

프로토타입 빈, 직접 destroy 호출 안 할 경우

0

66

1

beanB

0

82

2

퀴즈다시풀기

0

68

1

Gradle로 바꿔도 오류가 똑같이 발생하네요 ㅠㅠ

0

92

2

"중복 등록과 충돌" 강의에서 강사님과 다른 에러가 발생합니다.

0

67

3

run 실행했는데 결과창이 이렇게 뜨네요 왜 그런건가요>

0

106

2

도메인의 정의?

0

59

1

ApplicationContext 질문입니다.

0

63

1

@Scope의 proxyMode를 사용할때 단위 테스트 방법

0

89

2

ai api 선정하기 관련 질문

0

118

2

생성자 자동주입 관련해서

0

65

1

생성자 직접 호출 vs 팩토리 메서드 패턴

0

97

2

Spring에서 SessionScope와 RequestScope는 함께 사용되나요?

1

66

1

12:25

0

79

2