Spring Boot + RESTful + 檔案下載

Photo by Fezbot2000 on Unsplash
Photo by Fezbot2000 on Unsplash
在開發後端程式時,我們常常需要開一個 RESTful API,讓前端(如 Angular、React)可以下載檔案。用 Spring Boot 的 StreamingResponseBody 可以輕鬆地實作檔案下載功能。

在開發後端程式時,我們常常需要開一個 RESTful API,讓前端(如 Angular、React)可以下載檔案。用 Spring Boot 的 StreamingResponseBody 可以輕鬆地實作檔案下載功能。

如下方的程式碼,只要用 FileCopyUtils.copy()InputStream 的資料複製到 StreamingResponseBodyOutputStream 就可以了!

Plain text
Copy to clipboard
Open code in new window
EnlighterJS 3 Syntax Highlighter
import org.springframework.http.MediaType;
import org.springframework.http.ResponseEntity;
import org.springframework.util.FileCopyUtils;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.servlet.mvc.method.annotation.StreamingResponseBody;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;
@RestController
@RequestMapping("/logs")
public class LogController {
@GetMapping(value = "/download", produces = MediaType.APPLICATION_OCTET_STREAM_VALUE)
public ResponseEntity<StreamingResponseBody> downloadLog() throws FileNotFoundException {
InputStream inputStream = new FileInputStream("/path/to/log");
StreamingResponseBody body = outputStream -> FileCopyUtils.copy(inputStream, outputStream);
return ResponseEntity.ok()
.header("Content-Disposition", "attachment;filename=server.log")
.body(body);
}
}
import org.springframework.http.MediaType; import org.springframework.http.ResponseEntity; import org.springframework.util.FileCopyUtils; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import org.springframework.web.servlet.mvc.method.annotation.StreamingResponseBody; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.InputStream; @RestController @RequestMapping("/logs") public class LogController { @GetMapping(value = "/download", produces = MediaType.APPLICATION_OCTET_STREAM_VALUE) public ResponseEntity<StreamingResponseBody> downloadLog() throws FileNotFoundException { InputStream inputStream = new FileInputStream("/path/to/log"); StreamingResponseBody body = outputStream -> FileCopyUtils.copy(inputStream, outputStream); return ResponseEntity.ok() .header("Content-Disposition", "attachment;filename=server.log") .body(body); } }
import org.springframework.http.MediaType;
import org.springframework.http.ResponseEntity;
import org.springframework.util.FileCopyUtils;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.servlet.mvc.method.annotation.StreamingResponseBody;

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;

@RestController
@RequestMapping("/logs")
public class LogController {
    @GetMapping(value = "/download", produces = MediaType.APPLICATION_OCTET_STREAM_VALUE)
    public ResponseEntity<StreamingResponseBody> downloadLog() throws FileNotFoundException {
        InputStream inputStream = new FileInputStream("/path/to/log");
        StreamingResponseBody body = outputStream -> FileCopyUtils.copy(inputStream, outputStream);
        return ResponseEntity.ok()
                .header("Content-Disposition", "attachment;filename=server.log")
                .body(body);
    }
}

現在你可以試著用瀏覽器開 http://localhost:8080/logs/download,就會直接下載檔案!

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *

You May Also Like
Photo by Charles Jackson on Unsplash
Read More

Springdoc-OpenAPI 教學

Springdoc 是一個整合 OpenAPI Specification 和 Spring Boot 的套件。和 SpringFox 套件一樣,它產出 Swagger 文件。兩者不同在於,Springdoc 是用 Swagger 3,而 SpringFox 是用 Swagger 2。
Read More