使用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萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章