Spring/Tistory

블로그-V3. 프로젝트 외부 파일 경로 지정

JJJAEOoni 2022. 4. 27. 00:15
반응형

 

썸네일을 글 목록에 불러오기 위해 경로를 지정해주는데

우리는 파일을 프로젝트 외부의 C드라이브에 저장해두었다.

 

외부 파일에 접근할 수 없기 때문에 설정 파일에서 설정을 해주어야 한다.

 

 

이 파일에 WebMvcConfigurer을 implements 받아준다.

이 파일이 web.xml 설정 파일과 같은 것이다.

 

메모리에 띄우기 위해 @Configuration을 달아준다.

 

package site.metacoding.blogv3.config;

import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import org.springframework.web.servlet.resource.PathResourceResolver;
import org.springframework.beans.factory.annotation.Value;

@Configuration
public class WebMvcConfig implements WebMvcConfigurer { // web.xml 설정 파일 -> POJO

    @Value("${file.path}")
    private String uploadFolder;

    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) { // web.xml이 가지고있는 기본설정이므로 날리면 안됨!
        WebMvcConfigurer.super.addResourceHandlers(registry);

        registry
            .addResourceHandler("/upload/**")
            .addResourceLocations("file:///" + uploadFolder) // file 프로토콜은 :/// 사용
            .setCachePeriod(60*60) // 초 단위 => 한시간
            .resourceChain(true)
            .addResolver(new PathResourceResolver());
    }
}

 

/upload/** 의 요청이 들어오면

file:/// + uploadFolder 내부를 찾게 된다.

 

내가 브라우저에서 파일을 한번 다운로드하였으면 브라우저가 한 시간 동안 캐싱하고 있다.

resourceChain을 트루로 해두지 않으면 요청받을 때마다 브라우저에서 새로 다운로드한다.

 

요청받는 주소만 신경 써주면 된다.

 

필요한 곳에서 요청할 때 src="/upload/" 라고만 하면

"file:///" + uploadFolder로 가서 찾게 된다.

 

업로드 폴더에 UUID가 포함되어 있는 이름으로 저장되어있는 사진의 이름을 a.png로 바꾸고

src="/upload/a.png"를 설정해주고 화면에 띄우기 테스트를 해보자.

 

{{>/layout/main-header}}

<div class="container">
    <h3>메인페이지입니다</h3>
    <img src="/upload/a.png" width="200px" height="200px" />
</div>

{{>/layout/footer}}

 

테스트가 끝났으니 게시글 목록을 볼 때 이미지 파일을 당겨오면 되겠다.

글 목록을 불러올 때 PostResponseDto를 모델에 담아줬었다.

list.mustache에 뿌려보자.

 

<div class="my_post_list">
    {{#postResponseDto.posts}}
    <div class="my_post_list_item">
        <div class="my_post_list_item_left">

            <!-- <div class="my_fakeimg">Fake Image</div> -->
            <img src="/upload/{{thumnail}}" width="100%" height="100%">

        </div>
        <div class="my_post_list_item_right my_ellipsis">
            <div class="my_text_title my_ellipsis">{{title}}
            </div>
            <div class="my_text_body_sm">{{createDate}}</div>
            <div class="my_mt_md_1">
                <a href="/user/{{user.id}}/post/{{id}}" class="my_success_btn">Read More</a>
            </div>
        </div>
    </div>
    {{/postResponseDto.posts}}
</div>

 

 

createDate의 형태가 예쁘지 않으니까 format 해주자.

Post.java에 포맷 메서드를 만들어주자.

그리고 머스태치에서 createDate를 뿌릴 때

{{createDate}}가 아닌 {{formatCreateDate}}를 뿌려주면 지정해준 형식으로 예쁘게 나온다.

 

public String getFormatCreateDate() {
    DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd hh:mm");
    return createDate.format(formatter);
}

 

 

 

 

 

[출처]

 

https://cafe.naver.com/metacoding

 

메타코딩 : 네이버 카페

코린이들의 궁금증

cafe.naver.com

메타 코딩 유튜브

https://www.youtube.com/c/%EB%A9%94%ED%83%80%EC%BD%94%EB%94%A9

 

메타코딩

문의사항 : getinthere@naver.com 인스타그램 : https://www.instagram.com/meta4pm 깃헙 : https://github.com/codingspecialist 유료강좌 : https://www.easyupclass.com

www.youtube.com

 
반응형