Java 文件流 io实现下载

/**
         * 下载数据文件压缩包
         * https://www.cnblogs.com/esther-qing/p/6222643.html
         *  https://www.cnblogs.com/zhao1949/p/6731601.html
         * @throws IOException
         * @throws Exception 
         */
        @Action(value = "datefile")
        public void filedate() throws IOException, Exception { 
            HttpServletRequest request = ServletActionContext.getRequest();
            request.setCharacterEncoding("utf-8");
            String key =req.getParameter("key");
             ByteArrayOutputStream os =new ByteArrayOutputStream();
             String sbb="123";
               InputStream imgInputStream = null;
               ByteArrayOutputStream outStream = new ByteArrayOutputStream();  
            if (key!=null&&!"".equals(key)) {
                Analyse analyse=analyseService.find(key);
                if (analyse!=null) {
                    String sql="SELECT * from measure_object where measure_id='8a22de5859d992290159da04b6ef16d0'";
                    String datname=jdbc.GetObject(sql,"name");
                    String measure_object_id=jdbc.GetObject(sql,"id");
                    String device_id=jdbc.GetObject(sql,"device_id");        
                     String pic=jdbc.GetObject(sql,"c_id");        
                    if (datname==null||"".equals(datname)) {
                        datname= UUID.randomUUID().toString().replaceAll("-","");  
                    }
                    
                    sbb=datname;
                      ZipOutputStream zos = null;
                        zos = new ZipOutputStream(os);
                        zos.setEncoding("UTF-8");
                       zos.putNextEntry(new ZipEntry(datname+ ".dat"));//创建文件
                        StringBuilder sb = new StringBuilder();
                        sb.append("测线名称").append(",").append("测点增量").append(",");
                        //查找设备频率
                        //第一行
                        String sql2="select * from frequency where device_id='"+device_id+"' order by sort asc ";
                        List<Map<String, Object>> listFile =  jdbc.select(sql2, "unit,value");// 制定输出
                        for (Map<String, Object> map :listFile) {
                            sb.append("\"").append((String)map.get("value")+(String)map.get("unit")).append("\",");
                        }
//                        sb.delete(sb.length() - 1, sb.length());
                        sb.append("创建时间");
                        sb.append(System.lineSeparator());
                        zos.write(sb.toString().getBytes());
                        //写入数据
                        String sql3="select * from measure_cell  where measure_object_id='"+measure_object_id+"' order by col asc,row  asc";
                        // String sql3="select * from measure_cell  where measure_object_id='8a22de5859d992290159da04b6ef16d1' GROUP BY col asc";
                        List<Map<String, Object>> list2=  jdbc.select(sql3, "id,col,row,value,measure_object_id");// 制定输出
                        int a=1;
                        for (Map<String, Object> map : list2) {//得到所有行数据,按照col的值 从1开始写
                            sb.setLength(0);
                            sb.append(datname).append(",");
                            sb.append(a * 10).append(",");
                            a++;
                             String col=(String) map.get("col");//行
                             String row=(String) map.get("row");//列
                             String value=(String) map.get("value");
                             String object_id=(String) map.get("measure_object_id");
                             if (col!=null&&!"".equals(col)&&object_id!=null&&!"".equals(object_id)) {
                                 String sql44="select * from measure_cell  where measure_object_id='"+object_id+"' and col='"+col+"' order by  row  asc";
                                  List<Map<String, Object>> list4=  jdbc.select(sql44, "id,col,row,value,measure_object_id");// 制定输出
                                  for (Map<String, Object> map2 : list4) {//得到所属行的列数据
                                      String value3=(String) map2.get("value");
                                      if (value3!=null&&!"".equals(value3)) {
                                          sb.append(value3).append(",");
                                    }
                                  }
                                  if (analyse.getCreatetime()!=null&&!"".equals(analyse.getCreatetime())) {
                                     sb.append(sdf.format(analyse.getCreatetime()));
                                }else{
                                    sb.append(sdf.format(new Date()));
                                 }
                                  sb.append(System.lineSeparator());
                                  zos.write(sb.toString().getBytes());
                            }
                        }
                        
                        ///写入图片
                        String image =QiniuFile.down(pic);
                        if (image!=null&&!"".equals(image)) { 
                             //new一个URL对象  
                             zos.putNextEntry(new ZipEntry(pic + ".png"));
                            URL url = new URL(image);  
                            //打开链接  
                            HttpURLConnection conn = (HttpURLConnection)url.openConnection();  
                            //设置请求方式为"GET"  
                            conn.setRequestMethod("GET");  
                            //超时响应时间为5秒  
                            conn.setConnectTimeout(5 * 1000);  
                            //通过输入流获取图片数据  
                            InputStream inStream = conn.getInputStream();  
                            //得到图片的二进制数据,以二进制封装得到数据,具有通用性  
                          //  byte[] data = readInputStream(inStream);  //outStream.toByteArray()
                           
                            //创建一个Buffer字符串  
                            byte[] buffer = new byte[1024];  
                            //每次读取的字符串长度,如果为-1,代表全部读取完毕  
                            int len = 0;  
                            //使用一个输入流从buffer里把数据读取出来  
                            while( (len=inStream.read(buffer))>0){  
                                //   while( (len=inStream.read(buffer))>-1){  
                                //用输出流往buffer里写入数据,中间参数代表从哪个位置开始读,len代表读取的长度  
                               //outStream.write(buffer, 0, len);  
                               zos.write(buffer, 0, len);  
                            }  
                            //关闭输入流  
                            inStream.close();  
                            //把outStream里的数据写入内存  
                           // return outStream.toByteArray();
//                            zos.flush();
//                            zos.closeEntry();
                        }
                        zos.flush();
                        zos.closeEntry();
                }

            }
            os.flush();
            ByteArrayResource res=new ByteArrayResource(os.toByteArray());
            HttpServletResponse response = ServletActionContext.getResponse();
            response.setContentType("application/octet-stream;charset=UTF-8");
             response.setHeader("Content-disposition", "attachment;filename=123.zip" );
             OutputStream ouputStream = response.getOutputStream();
             ouputStream.write(os.toByteArray());
              ouputStream.flush();
              os.close();
              ouputStream.close();
         
        }

主要是将文件流装入到os中,然后通过ouputstream输出文件

转载于:https://my.oschina.net/u/2299924/blog/3056223

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值