springmvc注解开发-高级之图片上传

1.1    上传图片

 

在页面form中提交enctype="multipart/form-data"的数据时,需要springmvc对multipart类型的数据进行解析。

 

在springmvc.xml中配置multipart类型解析器。


1.1.1 配置虚拟目录

在tomcat上配置图片虚拟目录,在tomcat下conf/server.xml中添加:

 

访问http://localhost:8080/pic即可访问F:\develop\upload\temp下的图片。

 

注意:在图片虚拟目录中,一定将图片目录分级创建(提高i/o性能),一般我们采用按日期(年、月、日)进行分级创建。

也可以通过eclipse配置:

 springmvc注解开发-高级之图片上传_第1张图片

 

1.1.2 配置解析器

    <bean id="multipartResolver"

       class="org.springframework.web.multipart.commons.CommonsMultipartResolver">

      

       <property name="maxUploadSize">

           <value>5242880value>

       property>

    bean>

 

1.1.3 jar包

CommonsMultipartResolver解析器依赖commons-fileupload和commons-io,加入如下jar包:

 

1.1.4 图片上传

u  controller:

 

//商品修改提交

    @RequestMapping("/editItemSubmit")

    public String editItemSubmit(Items items, MultipartFilepictureFile)throws Exception{

      

       //原始文件名称

       String pictureFile_name = pictureFile.getOriginalFilename();

       //新文件名称

       String newFileName = UUID.randomUUID().toString()+pictureFile_name.substring(pictureFile_name.lastIndexOf("."));

      

       //上传图片

       File uploadPic = new java.io.File("F:/develop/upload/temp/"+newFileName);

      

       if(!uploadPic.exists()){

           uploadPic.mkdirs();

       }

       //向磁盘写文件

       pictureFile.transferTo(uploadPic);

 

.....

 

 

u  页面:

 

form添加enctype="multipart/form-data":

<form id="itemForm"

       action="${pageContext.request.contextPath}/item/editItemSubmit.action"

       method="post" enctype="multipart/form-data">

       <input type="hidden"name="pic" value="${item.pic }"/>

 

 

file的name与controller形参一致:

           <tr>

              <td>商品图片td>

              <td><c:if test="${item.pic !=null}">

                     <img src="/pic/${item.pic}"width=100 height=100 />

                     <br />

                  c:if> <input type="file"name="pictureFile" />td>

           tr>


你可能感兴趣的:(SpringMVC)