English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
Spring MVC는 이미지나 다른 파일 등을 업로드하는 간편한 방법을 제공합니다. Spring MVC를 사용한 파일 업로드의 간단한 예제를 보겠습니다.
이 예제를 실행하려면 로드해야 합니다:
Spring Core jar 파일 Spring Web jar 파일 commons-fileupload.jar 및 commons-io.jar 파일
1) spring의 모든 jar 파일을 다운로드하세요. core, web, aop, mvc, j2ee, 원격 처리, oxm, jdbc, orm 등.
2)를 다운로드합니다-)io.jar
3)를 Commons -)fileupload.jar
1)에 commons 추가-)io와 fileupload.jar 파일
2)에 spring 추가-servlet.xml에 CommonsMultipartResolver
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"/>
3) 파일을 제출하기 위한 양식을 생성합니다. 메서드 이름은 "post"이어야하며 "multiple"을 입력합니다。/form-data"。
<form action="savefile" method="post" enctype="multipart/form-data"> Select File: <input type="file" name="file"/> <input type="submit" value="Upload File"/> </form>
4)Controller에서 CommonsMultipartFile 클래스를 사용합니다。
@RequestMapping(value="/savefile", method=RequestMethod.POST) public ModelAndView upload(@RequestParam CommonsMultipartFile file, HttpSession session){ String path=session.getServletContext().getRealPath("/); String filename=file.getOriginalFilename(); System.out.println(path+" "+filename); try{ byte barr[]=file.getBytes(); BufferedOutputStream bout=new BufferedOutputStream( new FileOutputStream(path+"/"+filename)); bout.write(barr); bout.flush(); bout.close(); }) { catch(Exception e){System.out.println(e);} return new ModelAndView("upload-success","filename",path+"/"+filename); }
5)이 JSP에서 이미지를 표시합니다。
<h1>Upload Success</h1> <img src="${filename}"/>
이미지 디렉토리 생성
프로젝트에 "이미지" 디렉토리를 생성하세요. 왜냐하면 모든 파일을 저장하려고 작성하고 있기 때문입니다./images" 디렉토리에 있는 코드.
index.jsp
<a href="uploadform">Upload Image</a>
Emp.java
package com.w;3codebox; import java.io.BufferedOutputStream; import java.io.File; import java.io.FileOutputStream; import javax.servlet.ServletContext; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import org.apache.commons.fileupload.disk.DiskFileItemFactory; import org.apache.commons.fileupload.servlet.ServletFileUpload; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.ModelAttribute; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.multipart.commons.CommonsMultipartFile; import org.springframework.web.servlet.ModelAndView; @Controller public class HelloController { private static final String UPLOAD_DIRECTORY ="/images"; @RequestMapping("uploadform") public ModelAndView uploadForm(){ return new ModelAndView("uploadform"); } @RequestMapping(value="savefile",method=RequestMethod.POST) public ModelAndView saveimage( @RequestParam CommonsMultipartFile file, HttpSession session) throws Exception{ ServletContext context = session.getServletContext(); String path = context.getRealPath("UPLOAD_DIRECTORY"); String filename = file.getOriginalFilename(); System.out.println(path+" "+filename); byte[] bytes = file.getBytes(); BufferedOutputStream stream =new BufferedOutputStream(new FileOutputStream( new File(path + File.separator + filename))); stream.write(bytes); stream.flush(); stream.close(); return new ModelAndView("uploadform","filesuccess","File successfully saved!"); } }
web.xml
<?xml version="1.0" encoding="UTF-8"?> <web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-_app_2_5.xsd"> <servlet> <servlet-name>spring</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>spring</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> </web-app>
spring-servlet.xml
CommonsMultipartResolver를 위한 bean을 생성해야 합니다.
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd"> <context:component-scan base-package="com.w3codebox"></context:component-scan> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/jsp/></property> <property name="suffix" value=".jsp"></property> </bean> <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"/> </beans>
uploadform.jsp
이 문서의 폼은 method = "post"와 enctype = "multipart"로 설정되어야 합니다./form-data"。
<%@taglib uri="http://www.springframework.org/tags/form" prefix="form"> <!DOCTYPE html> <html> <head> <title>이미지 파일 업로드</title> </head> <body> <h1>파일 업로드 예제 - w3codebox/h1> <h3 style="color:red">${filesuccess}</h3> <form:form method="post" action="savefile" enctype="multipart/form-data"> <p><label for="image">이미지 선택</label></p> <p><input name="file" id="fileToUpload" type="file" /></p> <p><input type="submit" value="Upload"></p> </form:form> </body> </html>
출력
서버 컨트롤 타블에 출력된 경로로 이동하여 업로드된 파일을 확인하세요。