用COS實現文件上傳


cos是O'Rrilly公司開發的一款用於HTTP上傳文件的OpenSource組件

需要cos.jar,下載地址:http://www.servlets.com/cos/

cos上傳文件很簡單,比fileupload還簡單:但是上傳最大我試了試,是800多兆,超過直接崩潰:

java.io.IOException: Posted content length of 1627105576 exceeds limit of 889192448 --->byte,800多M

只需一個servelt即可:

package com.lhy.upload;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.util.Enumeration;
import java.util.UUID;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.oreilly.servlet.MultipartRequest;
import com.oreilly.servlet.multipart.FileRenamePolicy;

/**
 * CosServlet 
 *  在Cos中就一個類,
 *  MultipartRequest它是request的包裝類。
 */
@WebServlet(name="CosServlet",urlPatterns="/CosServlet")
public class CosServlet extends HttpServlet{

  @Override
  protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
    //第一步,聲明文件的保存目錄
    String path = getServletContext().getRealPath("/up");
    //第二步:文件上傳
    //聲明文件重新命名策略,默認的不行不能重命名,自己實現FileRenamePolicy接口
//    FileRenamePolicy rename = new DefaultFileRenamePolicy();
    MultipartRequest multiReq = new MultipartRequest(req, path, 1024*1024*100, "UTF-8",new MyRename());
    
    
    
    //輸出所上傳的文件的信息  
    Enumeration fileNames = multiReq.getFileNames();  
    while(fileNames.hasMoreElements()){  
        String name  = (String)fileNames.nextElement(); 
        File file = multiReq.getFile(name);//得到上傳的文件
        if(null != file){  
            String fileName  = multiReq.getFilesystemName(name);   //取得文件名  
            String contentType = multiReq.getContentType(name);//類型
            System.out.println("上傳的文件: " +fileName+",  文件類型: "+contentType);  
        }  
    }  
    
    
    //輸出所提交的表單中其它文本輸入域的值  
    Enumeration formValue = multiReq.getParameterNames();  
    while(formValue.hasMoreElements()){  
        String param = (String)formValue.nextElement();  
        String value = multiReq.getParameter(param);  
        System.out.println(value);  
    } 
    
    
    //第三步:如果知道input的name,還可以直接獲取信息,
    /*resp.setContentType("text/html;charset=UTf-8");
    PrintWriter out = resp.getWriter();
    out.print("文件名稱1:"+multiReq.getOriginalFileName("img1"));
    out.print("<br/>新名稱:"+multiReq.getFilesystemName("img1"));
    out.print("<br/>類型1:"+multiReq.getContentType("img1"));
    out.print("<br/>大小1:"+multiReq.getFile("img1").length());
    out.print("<br/>說明:"+multiReq.getParameter("desc1"));
    if(multiReq.getContentType("img1").contains("image/")){
      out.print("<img width='300px' height='200px' src='"+req.getContextPath()+"/up/"+multiReq.getFilesystemName("img1")+"'></img>");
    }

    
  out.print("<hr/>");
  out.print("文件名稱2:"+multiReq.getOriginalFileName("img2"));
  out.print("<br/>類型2:"+multiReq.getContentType("img2"));
  out.print("<br/>大小2:"+multiReq.getFile("img2").length());
  out.print("<br/>說明2:"+multiReq.getParameter("desc2"));
  
//  
  out.print("<hr/>");
  out.print("文件名稱3:"+multiReq.getOriginalFileName("img3"));
  out.print("<br/>類型3:"+multiReq.getContentType("img3"));
  out.print("<br/>大小3:"+multiReq.getFile("img3").length());
  out.print("<br/>說明3:"+multiReq.getParameter("desc3"));*/

  }

}

/**
 * 重命名策略,
 */
class MyRename implements FileRenamePolicy{
  
  @Override
  public File rename(File file) {
    String fileName = file.getName();
    String extName = fileName.substring(fileName.lastIndexOf("."));
    String uuid = UUID.randomUUID().toString().replace("-","");
    String newName = uuid+extName;//abc.jpg
    file = new File(file.getParent(),newName);
    return file;
  }
  
}

表單:

<form action="<c:url value='/CosServlet'/>" method="post"
        enctype="multipart/form-data">
        File1:<input type="file" name="img1"><br /> 說明1:
        <input type="text" name="desc1"><br />
        
        File2:<input type="file" name="img2"><br/>
        說明2:<input type="text" name="desc2"><br/>
        File3:<input type="file" name="img3"><br/>
        說明3:<input type="text" name="desc3"><br/>
        
        <input type="submit" />
    </form>

啟動上傳:

服務端:

還是很給力的。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM