안녕하세요! 제가 react 를 잘 알지는 못합니다만, Spring 서버 관점에서 제가 진행했던 프로젝트 경험을 토대로 말씀드리겠습니다. client(react) 에서 Spring 으로 이미지를 업로드 해주시면 Spring 에서는 업로드된 이미지를 Storage(여기서 Storage 는 Spring Server 의 File System 이 될수도 있고 NAS 나 Amazon S3 와 같은 외부 Storage 일수도 있겠죠) 에 저장하고 저장된 경로와 필요시 이미지의 metadata 등을 DB 에 저장하도록 구현할 것입니다. (이미지 데이터를 db 에 그대로 저장하는것도 불가능한것은 아니나 추천드리진 않습니다.) 이미지 저장이 완료되었으면 이 이미지를 다운로드 받을 수 있어야 화면에 노출이 가능할테니 Spring 에서는 Storage 에 저장된 이미지를 다운로드 받을 수 있는 API 를 제공해줘야합니다. 이미지 다운로드 API 가 어떻게 구현이 되느냐에 따라 client(react) 에서 어느정도 가공이 필요할수도, 혹은 그대로 사용이 가능할수도 있습니다. 정확한 스펙을 말씀해 주시질 않았기 때문에 게시판 게시글에 이미지를 업로드한다고 가정하고 예를 들어 보겠습니다. 이미지 다운로드 API 를 이미지를 업로드한 게시글ID 만 주면 다운로드 가능하게 구현이 되어있다면 "/downloadImg?id={게시글ID}" 형태로만 img 태그에 src 를 넣으면 되겠죠. 하지만 서버에서 저장한 Storage 경로나 DB 에 저장한 metadata 등으로 다운로드가 가능하게 구현이 되어있다면, 이 정보를 조회한 뒤에 조합해서 img 태그에 src 를 넣어야겠죠. 어느것이 정답이라고 할 순 없고 구현하시려는 기능의 스펙에 따라 효율적인 방법으로 선택하시면 되겠습니다. 부디 제 짧은 식견이 도움이 되셨길 바랍니다.

다음 내용이 궁금하다면?

지금 간편 가입하고 다음 내용을 확인해 보세요!

또는

이미 회원이신가요?

2022년 12월 2일 오전 1:40

댓글 0