• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

파일업로드,다운로드 궁금한게 있습니다.

24.04.15 13:58 작성 24.04.15 14:01 수정 조회수 109

0

mvc2편 마지막 강의에서

아래 컨드롤러를 추가했다고 화면에 이미지 파일이 나타나는 이유를 정확히 모르겠습니다.

/images/{filename} 디렉토리가 호출된 적이 없잔아요?


@ResponseBody
@GetMapping("/images/{filename}")
public Resource downloadImage(@PathVariable String filename) throws  MalformedURLException {
  return new UrlResource("file:" + fileStore.getFullPath(filename));
}

 

 

 

 

답변 2

·

답변을 작성해보세요.

1

OMG님의 프로필

OMG

2024.04.15

안녕하세요. jfk6725님, 공식 서포터즈 OMG입니다.

images/{filename} 디렉토리가 호출된 적이 없잔아요?

질문에서 디렉토리가 호출되었는지에 대한 내용으로 설명하신 것으로 보아 물리적인 파일의 접근이 발생하지 않았는데, 리소스를 호출하여 의문이 생기신 것 같습니다.

강의 30분~31분 사이에 설명을 해주시는데요, UrlResource를 사용하여 직접 물리적인 파일에 접근하여 리소스를 스트림으로 반환한다고 설명해주시니 해당 부분을 다시 한번 확인해주세요 😀

image

감사합니다.

0

인프런 AI 인턴님의 프로필

인프런 AI 인턴

2024.04.15

안녕하세요, 인프런 AI 인턴입니다.

jfk6725님의 질문에 대해, 파일 업로드와 다운로드에 대한 궁금증을 해결해 줄 수 있는 유사한 내용을 찾았습니다.

질문하신 내용은 스프링 MVC에서 이미지 파일을 다운로드하는 방법과 관련되어 있습니다. 구체적으로, @GetMapping("/images/{filename}")을 통해 이미지 파일을 반환하는 컨트롤러 메소드의 동작 방식에 대한 이해가 필요하신 것 같습니다. 해당 URL이 어떻게 호출되는지에 대한 궁금증을 가지고 계시군요.

이에 대한 답변으로는, 다음과 같은 유사 질문의 답변을 참조하시면 도움이 될 것입니다:

  • 스프링 MVC 2편 - 백엔드 웹 개발 활용 기술에서 윤주훈님의 비슷한 질문에 대한 답변입니다. 여기서는 @GetMapping("/images/{filename}") URL이 뷰의 이미지 소스로 지정될 때 호출되는 방식에 대한 설명이 포함되어 있습니다. 이러한 방식을 통해, 뷰에서 이미지 경로를 지정할 때 해당 컨트롤러 메소드가 호출되어 이미지 파일을 반환하게 됩니다.

이 특정 질문에서는 th:src 속성을 사용하여 타임리프 템플릿 엔진을 통해 이미지 파일의 경로를 지정하는 방법을 언급하고 있습니다. 같은 원리가 jfk6725님의 질문에도 적용될 수 있습니다. 뷰 템플릿에서 해당 URL 경로를 이미지 소스로 지정하면, 브라우저가 페이지를 렌더링할 때 해당 컨트롤러 메소드가 호출되어 이미지를 다운로드하게 됩니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.