java批量下載,將多文件打包成zip格式下載


現在的需求的:

根據產品族、產品類型,下載該產品族、產品類型下面的pic包;

pic包是zip壓縮文件;

t_product表:

這些包以blob形式存在另一張表中:

t_imagefile表:

現在要做的是:將接入網、OLT下面的兩個包downloadPIC:MA5800系列-pic.zip 和 MA5900-pic.rar一起打包成zip壓縮文件下載下來;

 

代碼:

ProductController.java:

    /**
     * 根據產品族、產品類型下載照片包
     */
    @RequestMapping("/downloadwBatch")
    public void downloadwBatch(HttpServletRequest request, HttpServletResponse response, String productFamily, String productType){
        //http://localhost:8080/MySSM/downloadwBatch?productFamily=接入網&productType=OLT
        try {
            productFamily = new String(productFamily.getBytes("iso-8859-1"), "utf-8");
            productType = new String(productType.getBytes("iso-8859-1"), "utf-8");
        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
        }
        
        //獲取要下載的照片包名
        Map<String, String> params = new HashMap<String, String>();
        params.put("productFamily", productFamily);
        params.put("productType", productType);
        List<String> packageNames = productService.getPackageNamesByFamilyAndType(params);
        
        //根據包名獲取待下載的文件    文件名-字節數組的形式
        Map<String, byte[]> files = new HashMap<String, byte[]>();
        for(String packageName : packageNames){
            byte[] f = productService.getPackage(packageName);
            if(f!=null){
                files.put(packageName, f);
            }
        }
        
        //設置下載的壓縮包名
        String zipName = productFamily + "_"+ productType + ".zip";
        
        //根據文件,進行壓縮,批量下載
        if(files.size() > 0){
            productService.downloadBatchByFile(response, files, zipName);
        }
        
    }

ProductService.java:

    /**
     * 根據包名獲取文件
     */
    public byte[] getPackage(String packageName){
        byte[] bag  = null;
        try{
            ImageFile m = productMapper.getPackage(packageName);
            if(m!=null){
                bag = m.getPicture();
            }
        }catch(Exception e){
            e.printStackTrace();
        }
        return bag;
    }
    
    
    /**
     * 根據產品族、產品類型 獲取待下載的包名
     * @param params
     * @return
     */
    public List<String> getPackageNamesByFamilyAndType(Map<String, String> params) {
        List<String> packageNames = productMapper.getPackageNamesByFamilyAndType(params);
        
        return packageNames;
    }
    
    /**
     * 根據文件,進行壓縮,批量下載
     * @param response
     * @param files
     * @throws Exception 
     */
    public void downloadBatchByFile(HttpServletResponse response, Map<String, byte[]> files, String zipName){
        try{
            response.setContentType("application/x-msdownload");
            response.setHeader("content-disposition", "attachment;filename="+URLEncoder.encode(zipName, "utf-8"));
            
            ZipOutputStream zos = new ZipOutputStream(response.getOutputStream());
            BufferedOutputStream bos = new BufferedOutputStream(zos);
            
            for(Entry<String, byte[]> entry : files.entrySet()){
                String fileName = entry.getKey();            //每個zip文件名
                byte[]    file = entry.getValue();            //這個zip文件的字節
                
                BufferedInputStream bis = new BufferedInputStream(new ByteArrayInputStream(file));
                zos.putNextEntry(new ZipEntry(fileName));
                
                int len = 0;
                byte[] buf = new byte[10 * 1024];
                while( (len=bis.read(buf, 0, buf.length)) != -1){
                    bos.write(buf, 0, len);
                }
                bis.close();
                bos.flush();
            }
            bos.close();
        }catch(Exception e){
            e.printStackTrace();
        }
    }

ProductMapper.java:

    /**
     * 根據包名獲取文件
     */
    public ImageFile getPackage(String packageName) throws Exception;

    /**
     * 據產品族、產品類型 獲取待下載的包名
     */
    public List<String> getPackageNamesByFamilyAndType(Map<String, String> params);
View Code

ProductMapper.xml:

    <!-- 根據包名獲取文件 -->
    <select id="getPackage" parameterType="java.lang.String" resultType="com.cy.model.ImageFile">
        select * from t_imagefile where packageName = #{packageName}
    </select>
    
    <!--  跟據產品族、產品類型 獲取待下載的包名 -->
    <select id="getPackageNamesByFamilyAndType" parameterType="java.util.Map" resultType="java.lang.String">
        select packageName from t_imagefile m join t_product p on m.packageName = p.downloadPic
        where p.productFamily = #{productFamily} and p.productType = #{productType}
    </select>
View Code

 

測試:

在瀏覽器中輸入:http://localhost:8080/MySSM/downloadwBatch?productFamily=接入網&productType=OLT

下載結果如下:

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

---------

 


免責聲明!

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



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