Java导出压缩包工具类
/**
* @Title: exportZip
* @Description:TODO(导出建压缩文件)
* @param delAdviceinfo 为项目实体类
* @date 2018年4月4日 下午2:36:41
* @param response
*
*/
public void exportZip(DelAdviceinfo delAdviceinfo, HttpServletResponse response) {
OutputStream os = null;
ZipOutputStream zos = null;
try {
os = response.getOutputStream();
zos = new ZipOutputStream(os);
String realpath = request.getSession().getServletContext().getRealPath("/");
String filename = "建议正文内容.zip";
response.setContentType("application/octet-stream");
response.setHeader("Connection", "close"); // 表示不能用浏览器直接打开
response.setHeader("Accept-Ranges", "bytes"); // 告诉客户端允许断点续传多线程连接下载
response.setHeader("Content-disposition", "attachment; filename="
+ new String(URLEncoder.encode(filename, "utf-8").getBytes("UTF-8"), "ISO-8859-1"));
// 查询数据
String userid = getCurrentUserId();
List<String> rolecodes = sysUserMapper.selectRoleCodesByUserID(userid);
// 代表
if (rolecodes.contains("db")) {
delAdviceinfo.setCurruserid(userid);
}
// 代表团管理员
else if (rolecodes.contains("dbtgly")) {
delAdviceinfo.setArea(getCurrentUser().getAreacode());
}
// 承办单位
else if (rolecodes.contains("cbdw")) {
delAdviceinfo.setUnitid(getCurrentUser().getDelunitid());
}
List<DelAdviceinfo> list = delAdviceinfoMapper.selectBootPage(null, delAdviceinfo);
for (DelAdviceinfo item : list) {
// 查询附议代表
if (StringUtils.isNotBlank(item.getResolutionerids())) {
String[] resoids = item.getResolutionerids().split(",");
List<DelDelegationinfoofSc> resos = delDelegationinfoofScMapper.selectResoList(resoids);
item.setResos(resos);
}
// 保存临时文件
String filefullname = item.getTitle() + "正文.doc";
if (StringUtils.isNotEmpty(item.getAdviceno())) {
filefullname = item.getAdviceno() + "_" + filefullname;
}
filefullname = UUID.randomUUID().toString() + "_" + filefullname;
String filepath = realpath + "/upload/tmp/" + filefullname;
File file = new File(filepath);
if (!file.getParentFile().exists()) {
file.getParentFile().mkdirs();
}
FileOutputStream fos = new FileOutputStream(file);
writeAdviceContent(item, fos);
// 加入zip流
String entryname = file.getName();
entryname = entryname.substring(entryname.indexOf("_") + 1);
ZipEntry zipEntry = new ZipEntry(entryname);
zos.putNextEntry(zipEntry);
InputStream is = new FileInputStream(file);
int i;
while ((i = is.read()) != -1) {
zos.write(i);
}
is.close();
file.delete();
}
zos.flush();
} catch (IOException e) {
e.printStackTrace();
}
finally {
try {
zos.close();
os.close();
} catch (IOException e2) {
e2.printStackTrace();
}
}
}
Java导出压缩包工具类的更多相关文章
- Java 通过Xml导出Excel文件,Java Excel 导出工具类,Java导出Excel工具类
Java 通过Xml导出Excel文件,Java Excel 导出工具类,Java导出Excel工具类 ============================== ©Copyright 蕃薯耀 20 ...
- java导出excel工具类
java导出excel须要使用HSSFWorkbook这个类,须要导入poi-3.6-20091214.jar 工具类调用例如以下: package com.qlwb.business.util; i ...
- WordUtil java导出word工具类
import java.io.BufferedInputStream;import java.io.BufferedOutputStream;import java.io.BufferedWriter ...
- 导入导出Excel工具类ExcelUtil
前言 前段时间做的分布式集成平台项目中,许多模块都用到了导入导出Excel的功能,于是决定封装一个ExcelUtil类,专门用来处理Excel的导入和导出 本项目的持久化层用的是JPA(底层用hibe ...
- javaEE开发之导出excel工具类
web开发中,一个系统的普通需求也包含导出excel,一般採用POI做统计报表导出excel. 导出excel工具类: import java.io.FileOutputStream; import ...
- java下载文件工具类
java下载文件工具类 package com.skjd.util; import java.io.BufferedInputStream; import java.io.BufferedOutput ...
- HttpTool.java(在java tool util工具类中已存在) 暂保留
HttpTool.java 该类为java源生态的http 请求工具,不依赖第三方jar包 ,即插即用. package kingtool; import java.io.BufferedReader ...
- java文件处理工具类
import java.io.BufferedInputStream; import java.io.BufferedOutputStream; import java.io.BufferedRead ...
- java格式处理工具类
import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOExceptio ...
随机推荐
- 【重学计算机】计组D3章:运算方法与运算器
1. 定点数运算及溢出 定点数加减法:减法化加法,用补码直接相加,忽略进位 溢出:运算结果超出了某种数据类型的表示范围 溢出检测方法:统一思想概括为正正得负或负负得正则溢出,正负或负正不可能溢出 方法 ...
- 【Android Studio安装部署系列】十二、Android studio代码混淆
版权声明:本文为HaiyuKing原创文章,转载请注明出处! 概述 为什么需要代码混淆呢?原因很简单,你的apk很容易被反编译出来,你写的代码都会被看到,因此我们需要在编译过程中对代码进行一定程度的混 ...
- 机器学习——交叉验证,GridSearchCV,岭回归
0.交叉验证 交叉验证的基本思想是把在某种意义下将原始数据(dataset)进行分组,一部分做为训练集(train set),另一部分做为验证集(validation set or test set) ...
- Mac下安装多版本python
1.安装Homebrew 将命令行复制至终端,进行安装. /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/H ...
- SpringBoot2 application.properties方式加载配置文件
application.properties jdbc.driverClassName=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://127.0.0.1:33 ...
- 回顾曾经的自己,献给java初学者的建议
要不惜代价投资自己,任何对自己的投资都是值得的 要多学习数据结构, 习惯看源码! 一份知识经过n个人的传递早已经不成样子了 遇到问题不要直接百度,百度上那些花里胡哨的东西有用的很少,对症下药才是王道, ...
- [总结]CSS/CSS3常用样式与web移动端资源
CSS/CSS3常用样式与知识点 IE条件注释 条件注释简介 IE中的条件注释(Conditional comments)对IE的版本和IE非IE有优秀的区分能力,是WEB设计中常用的hack方法.条 ...
- SAP MM 明明有需求,为啥MRP RUN后没有PR单据产生?
SAP MM 明明有需求,为啥MRP RUN后没有PR单据产生? 用户报了一个问题说,对于物料号42011222的采购单 4500000156建好了,为啥PR没有自动生成 . 我们检查了物料的MRP ...
- openlayers三:添加图片和图标
openlayers添加图片是指: 添加在地图上的图片会跟随地图同步放大缩小 而添加图标是指: 添加在地图上的图片不会跟随地图同步放大缩小 添加图片: 首先初始化图片图层: initImageLaye ...
- C# 通用单例窗体类
/// <summary> /// 通用的单例制作器 /// </summary> /// <typeparam name="T"></t ...