Today, I will summarize file upload and download in Spring. Before writing this blog, I wrote a blog about file upload and download ——React Native upload pictures to Qiniuyun storage. This blog mainly talked about how to upload files to Qiniuyun storage using React Native framework. The back-end part mainly integrates the API provided by Qiniuyun, but it does not talk about the basic principles of file uploading and downloading from the bottom, so this blog post tries to make up for the deficiencies before, next, let’s start together!
I. The basic principle of Java file upload and download
In the case of Java Web, for file uploads, the front-end browser submits a file, and the back-end processing returns the result of a successful or failed file upload; For file downloads, a lot of times you click a button or click a text link on the front end, and the browser automatically uploads the file to the local. So how does this work? In a Servlet, we can use HttpServletResponse objects associated with Http to output the file stream to the browser. Of course this relates to how our browser recognizes whether the stream is a file or a text string, so file upload and download also refer to setting the Mime type of the Http request header.
I now use HTML forms to upload a file, but when I use a framework, I don’t quite understand how it works. Let’s talk about how Spring Boot to achieve file upload and download, the front part of this example uses a simple HTML form, without any framework, simple to understand.
2. Spring’s support for file upload and download
In the Spring framework, support for file upload and download is implemented through the MultipartFile interface. A MultipartFile represents one file from the client, and an array of multipartFiles [] represents multiple files from the client. This is useful when implementing multiple file uploads.Of course, through this interface, you can get some basic information about the file sent by the client, such as file name, file size, etc. Of course, you can also ask Spring to limit the size and type of files sent from the client (such as PNG images or TXT text files), but the implementation configuration of these features is beyond the scope of this article.
The traditional REst-style use of Spring MVC is implemented through the @Controller, @responseBody, and @RequestMapping annotations. In Spring Boot, You only need to use the @RestController and @RequestMapping annotations. A simple example is as follows:
/** * Test file upload and download ** @author HJW ** / @RestController public class FileUploadCotroller {@requestMapping (value ="/upload.json", method = RequestMethod.POST)
public boolean fileUpload( MultipartFile file) throws IllegalStateException, IOException {
return false; }}Copy the code
Since the Spring framework relies on the Commons-Fileupload package, we need to import this jar package in Maven’s pom.xml file.
pom.xml
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <! -- https://mvnrepository.com/artifact/commons-fileupload/commons-fileupload --> <dependency> < the groupId > Commons fileupload - < / groupId > < artifactId > Commons fileupload - < / artifactId > < version > 1.3.3 < / version > < / dependency >Copy the code
Third, using Spring Boot to achieve the upload and download of a single file
1. Upload files
upload.html
<! DOCTYPE html> <html> <head> <meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<form action="http://localhost:8081/upload.json" method="POST" enctype="multipart/form-data">
<input name="file" type="file"/>
<button type="submit">single submit</button>
</form>
</body>
</html>
Copy the code
FileUploadCotroller.java
@RestController
public class FileUploadCotroller {
@RequestMapping(value = "/upload.json", method = RequestMethod.POST)
public boolean fileUpload( MultipartFile file) throws IllegalStateException, IOException {
if (file.getSize() == 0) {
return false;
}
System.err.println("Is the file empty?" + file.isEmpty());
System.err.println("The file size is:" + file.getSize());
System.err.println(The media type of the file is: + file.getContentType());
System.err.println("File name:" + file.getName());
System.err.println(The originName of the file is: + file.getOriginalFilename());
File newFile = new File("C:\\Users\\hjw\\Desktop\\" + file.getOriginalFilename());
file.transferTo(newFile);
return true; }}Copy the code
Enctype =”multipart/form-data”, and the name value of the tag must be the same as the name of the MultipartFile parameter in the back-end interface
2. File download
The file download front end is simple, we just use a tag.
download.html
<! DOCTYPE html> <html> <head> <meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<a href="http://localhost:8081/download.json">single download</a>
</body>
</html>
Copy the code
FileUploadCotroller.java
@RequestMapping(value="download.json")
public boolean download(HttpServletResponse res) throws IOException {
File file = new File("C:\\Users\\hjw\\Desktop\\design\\code\\project-1\\myapp\\src\\images\\seats\\bg1.png");
String fileName = "bg1.png";
res.setHeader("Content-Disposition"."attachment; filename=" + fileName);
byte[] buff = new byte[1024];
BufferedInputStream bis = null;
OutputStream os = null;
try {
os = res.getOutputStream();
bis = new BufferedInputStream(new FileInputStream(file));
int i = bis.read(buff);
while(i ! = -1) { os.write(buff, 0, buff.length); os.flush(); i = bis.read(buff); } } catch (IOException e) { e.printStackTrace(); } finally {if(bis ! = null) { try { bis.close(); } catch (IOException e) { e.printStackTrace(); } } } System.out.println("success");
return false; }}Copy the code
The file download above is streamed. Note that to enable the file download function, we must set the CONTent-disposition parameter of the Http Header in the response Header. This parameter will enable the browser to download and accept the file we are transferring.
Four, using Spring Boot to achieve multiple file upload
As mentioned above, multi-file uploads correspond to the MultipartFile[] array, so we only need to change the parameters on the back end.
multiUpload.html
<! DOCTYPE html> <html> <head> <meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<form action="http://localhost:8081/multiFile.json" enctype="multipart/form-data" method="post">
<input name="files" type="file" multiple="multiple" value="Please select multiple files"/>
<button type="submit">multi submit second</button>
</form>
</body>
</html>
Copy the code
FileUploadCotroller.java
@RequestMapping(value="multiFile.json",method=RequestMethod.POST)
public boolean multiFile(MultipartFile[] files) throws IllegalStateException, IOException {
if(files.length == 0) {
return false;
}
File file = null;
String path = "C:\\Users\\hjw\\Desktop\\";
for (int i = 0; i < files.length; i++) {
System.err.println("The first" + i + The size of a file is + files[i].getSize());
System.err.println("The first" + i + "Is the file empty?" + files[i].isEmpty());
System.err.println("The first" + i + The media type of a file is + files[i].getContentType());
System.err.println("The first" + i + "File name of a file" + files[i].getName());
System.err.println("The first" + i + "Source file name of a file" + files[i].getOriginalFilename());
file = new File(path + files[i].getOriginalFilename());
files[i].transferTo(file);
}
return false;
}
Copy the code
Note that we want to set the multiple attribute of the tag in the HTML file to multiple=”multiple”, which indicates that multiple file selections are supported. Also, as with single-file uploads, the name attribute of our tag must have the same name as the MultipartFile[] parameter on the back end, i.e., files.
conclusion
These examples are very simple, belonging to the entry level, of course, file upload and download to do well is not so simple, but our daily project is not on file upload and download function is very demanding (such as thunderbolt), of course, if you want to do a little more advanced, You can use Java’s RandomAccessFile class to implement breakpoint uploads and downloads. HTTP also supports breakpoint uploads and downloads. Thanks for reading!