IT 족집게/개발
[Spring] 스프링 파일 업로드/다운로드 총 정리, 쉽게 알아보자
머니킹입니다
2022. 5. 25. 14:18
HTML 폼 전송 방식
- application/x-www-form-urlencoded
폼에 입력하여 전송할 항목들을 Http Body에 문자로 username=kim&age=20와 같이 & 형태로 구분하여 전송한다.
- multipart/form-data
파일의 경우 문가가 아닌 바이너리 형식으로 전송해야 한다. 또한 파일과 문자 둘다 전송해야 하는 상황 경우 사용하는 것이 multipart/form-data이다.
Spring Filre Upload
Controller
@Controller
@Slf4j
@RequiredArgsConstructor
public class ViewController {
@Value("${test.file}")
///Users/jelly/Desktop/images/test/
private String fileDir;
@GetMapping("/upload")
public String newFile() {
return "upload-form";
}
// 파일 업로드 부분
@PostMapping("/upload")
public String saveFile(@RequestParam String itemName,
@RequestParam MultipartFile file, HttpServletRequest
request) throws IOException {
log.info("request={}", request);
log.info("itemName={}", itemName);
log.info("multipartFile={}", file);
System.out.println("fileDir = " + fileDir);
if (!file.isEmpty()) {
String fullPath = fileDir + file.getOriginalFilename();
log.info("파일 저장 fullPath={}", fullPath);
file.transferTo(new File(fullPath));
}
return "upload-form";
}
// 파일 다운로드 부분
@ResponseBody
@GetMapping("/images/{filename}")
public ResponseEntity<UrlResource> downloadImage(@PathVariable String filename) throws
MalformedURLException {
System.out.println("filename = " + filename);
UrlResource resource = new UrlResource("file:/Users/jelly/Desktop/images/test/2.png");
String encodedUploadFileName = UriUtils.encode("2.png", StandardCharsets.UTF_8);
String contentDisposition = "attachment; filename=\""+encodedUploadFileName+"\"";
return ResponseEntity.ok().header(
HttpHeaders.CONTENT_DISPOSITION, contentDisposition
).body(resource);
}
}
- 파일 업로드 시 쓰는 request 객체 형식은
MultiparyFile
이다 file.toTransferTo(new File( [path] )
을 통해 원하는 경로에 파일을 업로드 한다.UrlResource
를 통해 파일을 반환하는데 그냥 반환시 바이너리 코드 형식으로 나온다.- ResponseEntity 형식으로 반환하되 HttpHeader 부분에
attachment
부분을 추가하자- header에 attachment가 있으면 body에 있는 값을 다운받으라는 뜻이다.
- filename 설정 시 해당 파일이름으로 파일이 다운된다.
HTML Upload Form
<html xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="utf-8">
</head>
<body>
<div class="container">
<div class="py-5 text-center"> <h2>상품 등록 폼</h2>
</div>
<h4 class="mb-3">상품 입력</h4>
<form th:action method="post" enctype="multipart/form-data">
<ul>
<li>상품명 <input type="text" name="itemName"></li>
<li>파일<input type="file" name="file" ></li> </ul>
<input type="submit"/>
</form>
</div> <!-- /container -->
</body>
</html>
application.properties
test.file = /Users/jelly/Desktop/images/test/