SpringMVC : 파일 업로드 및 다운로드

1. 파일 업로드


비고 :

다음 코드는 매우 성숙합니다. 개인의 필요에 따라 관련 클래스 이름이나 요청 경로 및 기타 이름 만 변경하면됩니다. 코드를 크게 수정할 필요는 없습니다.

방법 1 :

1. 종속성 가져 오기

commons-fileupload 파일에 의해 업로드 된 jar 패키지를 가져 오십시오. Maven은 자동으로 그의 종속성 패키지 commons-io 패키지를 가져올 수 있도록 도와줍니다
.pom.xml에 다음 종속성을 추가하십시오 .

<!--文件上传-->
<dependency>
    <groupId>commons-fileupload</groupId>
    <artifactId>commons-fileupload</artifactId>
    <version>1.3.3</version>
</dependency>
<!--servlet-api导入高版本的-->
<dependency>
    <groupId>javax.servlet</groupId>
    <artifactId>javax.servlet-api</artifactId>
    <version>4.0.1</version>
</dependency>

2. springmvc-servlet.xml 파일에 다음 구성을 추가합니다.

노트! 이 bena의 ID는 multipartResolver 여야합니다. 그렇지 않으면 업로드 파일이 400 오류를보고합니다!

 <!--文件上传配置-->
 <bean id="multipartResolver"  class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
     <!-- 请求的编码格式,必须和jSP的pageEncoding属性一致,以便正确读取表单的内容,默认为ISO-8859-1 -->
     <property name="defaultEncoding" value="utf-8"/>
     <!-- 上传文件大小上限,单位为字节(10485760=10M) -->
     <property name="maxUploadSize" value="10485760"/>
     <property name="maxInMemorySize" value="40960"/>
 </bean>

CommonsMultipartFile 공통 메소드 :
String getOriginalFilename () : 업로드 된 파일의 원래 이름 가져 오기
InputStream getInputStream () : 파일 스트림 가져 오기
void transferTo (File dest) : 업로드 된 파일을 디렉토리 파일에 저장

3. 프론트 엔드 페이지 index.jsp 작성

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
  <head>
    <title>$Title$</title>
  </head>
  <body>

  <form action="${pageContext.request.contextPath}/upload" enctype="multipart/form-data" method="post">
    <input type="file" name="file"/>
    <input type="submit" value="upload">
  </form>
  </body>
</html>

4. 컨트롤러 쓰기

package com.lzcu.controller;

import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.commons.CommonsMultipartFile;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.*;
import java.net.URLEncoder;

@RestController
public class FileController {
    
    
	//@RequestParam("file") 将name=file控件得到的文件封装成CommonsMultipartFile 对象
	//批量上传CommonsMultipartFile则为数组即可
	@RequestMapping("/upload")
	public String fileUpload(@RequestParam("file") CommonsMultipartFile file , HttpServletRequest request) throws IOException {
    
    

		//获取文件名 : file.getOriginalFilename();
		String uploadFileName = file.getOriginalFilename();

		//如果文件名为空,直接回到首页!
		if ("".equals(uploadFileName)){
    
    
			return "redirect:/index.jsp";
		}
		System.out.println("上传文件名 : "+uploadFileName);

		//上传路径保存设置
		String path = request.getServletContext().getRealPath("/upload");
		//如果路径不存在,创建一个
		File realPath = new File(path);
		if (!realPath.exists()){
    
    
			realPath.mkdir();
		}
		System.out.println("上传文件保存地址:"+realPath);

		InputStream is = file.getInputStream(); //文件输入流
		OutputStream os = new FileOutputStream(new File(realPath,uploadFileName)); //文件输出流

		//读取写出
		int len=0;
		byte[] buffer = new byte[1024];
		while ((len=is.read(buffer))!=-1){
    
    
			os.write(buffer,0,len);
			os.flush();
		}
		os.close();
		is.close();
		return "redirect:/index.jsp";
	}
}

5. tomcat을 구성하고 테스트를 시작합니다.

브라우저 페이지 :
여기에 사진 설명 삽입
파일이 로컬로 업로드되었는지 확인합니다.
여기에 사진 설명 삽입

방법 2 :

file.Transto를 사용하여 업로드 된 파일 저장

위의 환경이 갖추어야합니다.

1. 컨트롤러 쓰기

package com.lzcu.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.multipart.commons.CommonsMultipartFile;

import javax.servlet.http.HttpServletRequest;
import java.io.File;
import java.io.IOException;

/**
 * Created by wangshilin on 2020/2/27
 */
@Controller
public class FileController02 {
    
    
	/*
	 * 采用file.Transto 来保存上传的文件
	 */
	@RequestMapping("/upload2")
	public String  fileUpload2(@RequestParam("file") CommonsMultipartFile file, HttpServletRequest request) throws IOException {
    
    

		//上传路径保存设置
		String path = request.getServletContext().getRealPath("/upload");
		File realPath = new File(path);
		if (!realPath.exists()){
    
    
			realPath.mkdir();
		}
		//上传文件地址
		System.out.println("上传文件保存地址:"+realPath);

		//通过CommonsMultipartFile的方法直接写文件(注意这个时候)
		file.transferTo(new File(realPath +"/"+ file.getOriginalFilename()));

		return "redirect:/index.jsp";
	}
}

2. 프런트 엔드 페이지 요청 변경

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
  <head>
    <title>$Title$</title>
  </head>
  <body>

  <form action="${pageContext.request.contextPath}/upload2" enctype="multipart/form-data" method="post">
    <input type="file" name="file"/>
    <input type="submit" value="upload">
  </form>
  </body>
</html>

3. 테스트를 시작합니다.

브라우저 :
여기에 사진 설명 삽입
로컬 인증 :
여기에 사진 설명 삽입

2. 파일 다운로드

0. 준비

  • 환경은 위와 동일합니다.
  • 업로드 디렉토리에 사진 저장 : hello.png

1. 컨트롤러 쓰기

package com.lzcu.controller;

import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.URLEncoder;

/**
 * Created by wangshilin on 2020/2/27
 */
@RestController
public class FileDownController {
    
    
	@RequestMapping(value="/download")
	public String downloads(HttpServletResponse response , HttpServletRequest request) throws Exception{
    
    
		//要下载的图片地址
		String  path = request.getServletContext().getRealPath("/upload");
		String  fileName = "hello.png";

		//1、设置response 响应头
		response.reset(); //设置页面不缓存,清空buffer
		response.setCharacterEncoding("UTF-8"); //字符编码
		response.setContentType("multipart/form-data"); //二进制传输数据
		//设置响应头
		response.setHeader("Content-Disposition",
				"attachment;fileName="+ URLEncoder.encode(fileName, "UTF-8"));

		File file = new File(path,fileName);
		//2、 读取文件--输入流
		InputStream input=new FileInputStream(file);
		//3、 写出文件--输出流
		OutputStream out = response.getOutputStream();

		byte[] buff =new byte[1024];
		int index=0;
		//4、执行 写出操作
		while((index= input.read(buff))!= -1){
    
    
			out.write(buff, 0, index);
			out.flush();
		}
		out.close();
		input.close();
		return null;
	}
}

2. 프론트 엔드 페이지 수정 : index.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
  <head>
    <title>$Title$</title>
  </head>
  <body>

  <form action="${pageContext.request.contextPath}/upload2" enctype="multipart/form-data" method="post">
    <input type="file" name="file"/>
    <input type="submit" value="upload">

    <a href="/download">点击下载</a>
  </form>
  </body>
</html>

3. 바람둥이를 구성하고 테스트합니다. 확인

여기에 사진 설명 삽입

추천

출처blog.csdn.net/qq_37955704/article/details/104537898