使用jersey上传图片到图片服务器

1. 修改tomcat配置, 允许文件写操作

实际项目中可能要用到单独的文件服务器, 这时候可以使用jersey上传文件的方法达到分离文件服务器和主服务器的目的

使用Tomcat需要修改conf目录下的web.xml, 添加readonly参数为false

[html] view plain copy
  1.  <servlet>  
  2.         <servlet-name>default</servlet-name>  
  3.         <servlet-class>org.apache.catalina.servlets.DefaultServlet</servlet-class>  
  4.         <init-param>  
  5.             <param-name>debug</param-name>  
  6.             <param-value>0</param-value>  
  7.         </init-param>  
  8.         <init-param>  
  9.             <param-name>readonly</param-name>  
  10.             <param-value>false</param-value>  
  11.         </init-param>  
  12.         <init-param>  
  13.             <param-name>listings</param-name>  
  14.             <param-value>true</param-value>  
  15.         </init-param>  
  16.         <load-on-startup>1</load-on-startup>  
  17. </servlet>  

2. 新建文件服务器web工程

新建文件服务器的web工程, 其他默认, 在webapp下新建upload目录用于存储上传后的照片, 放置一个任意文件, 放置打包的时候空文件夹被忽略掉



3. 新建项目web工程

jersey用到的jar

[html] view plain copy
  1. <dependency>  
  2.       <groupId>com.sun.jersey</groupId>  
  3.       <artifactId>jersey-core</artifactId>  
  4.       <version>1.19</version>  
  5.     </dependency>  
  6.     <dependency>  
  7.       <groupId>com.sun.jersey</groupId>  
  8.       <artifactId>jersey-client</artifactId>  
  9.       <version>1.19</version>  
  10. </dependency>  


在springmvc中配置CommonsMultipartResolver支持文件上传

[html] view plain copy
  1. <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">  
  2.         <property name="maxUploadSize" value="10240000"/>  
  3. </bean>  

编写Controller进行文件上传

[java] view plain copy
  1. package cn.codeyang.controller;  
  2.   
  3. import cn.codeyang.util.PropUtils;  
  4. import com.sun.jersey.api.client.Client;  
  5. import com.sun.jersey.api.client.WebResource;  
  6. import org.springframework.stereotype.Controller;  
  7. import org.springframework.web.bind.annotation.RequestMapping;  
  8. import org.springframework.web.bind.annotation.RequestMethod;  
  9. import org.springframework.web.multipart.MultipartFile;  
  10. import org.springframework.web.multipart.MultipartHttpServletRequest;  
  11. import javax.servlet.http.HttpServletRequest;  
  12. import javax.servlet.http.HttpServletResponse;  
  13. import java.io.IOException;  
  14. import java.util.Iterator;  
  15.   
  16. /** 
  17.  * 使用Jersey加springmvc上传文件到文件服务器 
  18.  */  
  19. @Controller  
  20. @RequestMapping("/upload")  
  21. public class UploadController {  
  22.   
  23.     @RequestMapping(value = "/toUpload", method = RequestMethod.GET)  
  24.     public String tuUpload(){  
  25.         return "upload";  
  26.     }  
  27.   
  28.     @RequestMapping(value = "upload", method = RequestMethod.POST)  
  29.     public void upload(HttpServletRequest request, HttpServletResponse response) throws IOException {  
  30.         MultipartHttpServletRequest req = (MultipartHttpServletRequest) request;  
  31.         Iterator<String> iter = req.getFileNames();  
  32.         if (iter.hasNext()){  
  33.             String fileName = iter.next();  
  34.             MultipartFile file = req.getFile(fileName);  
  35.             fileName = file.getOriginalFilename();  
  36.             byte[] byteArr = file.getBytes();  
  37.             Client client = Client.create();  
  38.             WebResource resource = client.resource(PropUtils.readProp("file_path") + "/upload/" + fileName);  
  39.             resource.put(byteArr);  
  40.         }  
  41.     }  
  42. }  


编写前端jsp代码

[html] view plain copy
  1. <%@ page contentType="text/html;charset=UTF-8" language="java" %>  
  2. <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>  
  3. <%@ page isELIgnored="false" %>  
  4. <html>  
  5. <head>  
  6.     <title></title>  
  7. </head>  
  8. <body>  
  9. <form action="<c:url value="/upload/upload"/> " method="post" enctype="multipart/form-data">  
  10.     <input type="file" name="f"/>  
  11.     <input type="submit" value="Submit">  
  12. </form>  
  13. </body>  
  14. </html>  


文件上传效果展示



文件上传成功


发布了50 篇原创文章 · 获赞 24 · 访问量 13万+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章