下载导出
来源:互联网 发布:国际云计算大会 编辑:程序博客网 时间:2024/05/16 23:39
* 下载银行文件
*/
public String updateCardFile() {
OutputStream os = null;
InputStream is = null;
try {
String cardFileId = request.getParameter("cardFileId");
SimpleDateFormat sdf = new SimpleDateFormat(Const.YYYY_MM_DD_HH_MM_SS);
// SimpleDateFormat sdf = new SimpleDateFormat(Const.YYYY_MM_DD);
// Calendar calendar = Calendar.getInstance(Locale.CHINA);
// calendar.set(Calendar.DAY_OF_WEEK, Calendar.FRIDAY);
// Calendar calendarTwo = Calendar.getInstance(Locale.CHINA);
// calendarTwo.add(Calendar.WEEK_OF_YEAR, -1);
// calendarTwo.set(Calendar.DAY_OF_WEEK, Calendar.FRIDAY);
// String fileName = sdf.format(calendar.getTime());
// filePath = Const.EXCEL_PATH;// Thread.currentThread().getContextClassLoader().getResource(Const.EXCEL_PATH).toString();
// filePath = Const.EXCEL_PATH + fileName + Const.DOT
// + Const.FILE_TYPE_XLS;
// File file = new File(filePath);
// if (!file.exists()) {
// fileName = sdf.format(calendarTwo.getTime());
// filePath = Const.EXCEL_PATH + fileName + Const.DOT
// + Const.FILE_TYPE_XLS;
// }
if(null!=cardFileId&&!"".equals(cardFileId)){
CardFileQuery cardFileQuery = new CardFileQuery();
cardFileQuery.setCard_File_Id(Integer.parseInt(cardFileId));
PageInfo pageInfo = new PageInfo(Integer.MAX_VALUE, Const.DEFAULT_PAGE_NO,Const.DEFAULT_MAX_RECORD);
List<CardFileVO> cardFileVOs = cardFileServiceImpl.getCardFileByList(cardFileQuery, pageInfo);
if(null!=cardFileVOs&&cardFileVOs.size()>0){
CardFileVO cardFileVO = cardFileVOs.get(0);
String path = cardFileVO.getCard_File_Path();
String fileName = cardFileVO.getCard_File_Create_Time();
File file = new File(path);
is = new BufferedInputStream(new FileInputStream(file));
cardFileQuery = new CardFileQuery();
cardFileQuery.setCard_File_Id(cardFileVO.getCard_File_Id());
if(null!=cardFileVO.getCard_File_Update_Count()){
cardFileQuery.setCard_File_Update_Count(cardFileVO.getCard_File_Update_Count()+1);
}else{
cardFileQuery.setCard_File_Update_Count(1);
}
cardFileQuery.setCard_File_Update_Time(sdf.format(new Date()));
cardFileServiceImpl.updateCardFile(cardFileQuery);
byte[] buffer = new byte[is.available()];
is.read(buffer);
// 清空response
response.reset();
response.setContentType(Const.EXCEL_CONTENT_TYPE);// 设置生成的文件类型
response.setHeader("Content-Disposition", "filename="
+ new String(fileName.getBytes(Const.ENCODING_UTF8),
Const.ENCODING_ISO88951) + Const.DOT
+ Const.FILE_TYPE_XLS);// 设置文件头编码方式和文件名
os = response.getOutputStream();
response.setContentType("application/octet-stream");
os.write(buffer);
Utils.insertLogInfo("获取提现自动生成的EXCEL", "相关信息:"+path, Utils.getUserID(request, Const.COOKIEID));
}else{
System.out.println("cardFileVOs为空");
}
}else{
System.out.println("cardFileId为空");
}
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
if (os != null) {
os.flush();
os.close();
}
if (is != null) {
is.close();
}
} catch (IOException e) {
e.printStackTrace();
}
System.gc();
}
return null;
}
/**
* 下载EXCEL
*/
private void uploadExcel(int cashState) {
OutputStream os = null;
try {
HSSFWorkbook workbook = createCashExcelReport(cashState);
if (workbook != null) {
String fileName = UUID.randomUUID().toString();
response.setContentType(Const.EXCEL_CONTENT_TYPE);// 设置生成的文件类型
response.setHeader("Content-Disposition", "filename="
+ new String(fileName.getBytes(Const.ENCODING_UTF8),
Const.ENCODING_ISO88951) + ".xls");// 设置文件头编码方式和文件名
os = response.getOutputStream();
workbook.write(os);
}
Utils.insertLogInfo("下载提现EXCEL", "提现状态:"+cashState,
Utils.getUserID(request, Const.COOKIEID));
} catch (Exception e) {
e.printStackTrace();
} finally {
if (os != null) {
try {
os.flush();
os.close();
} catch (IOException e) {
e.printStackTrace();
}
}
System.gc();
}
}
/**
* 创建提现EXCEL报表
*
* @param cashState
* @return
*/
private HSSFWorkbook createCashExcelReport(int cashState) {
HSSFWorkbook workbook = null;
try {
logger.info("创建Excel");
UserCashDetailQuery query = new UserCashDetailQuery();
query.setCashState(cashState);
PageInfo pageInfo = new PageInfo(Integer.MAX_VALUE, Const.DEFAULT_PAGE_NO, Const.DEFAULT_MAX_RECORD);
List<UserCashDetailVO> lists = pPayAccountServiceImpl
.getUserCashDetailByPage(query, pageInfo);
BigDecimal money = pPayAccountServiceImpl
.getUserCashDetailMoney(query);
String sheetName = cashState == Const.CASE_STATE_ONE ? Const.CASE_STATE_ONE_STR
: cashState == Const.CASE_STATE_TWO ? Const.CASE_STATE_TWO_STR
: cashState == Const.CASE_STATE_THREE ? Const.CASE_STATE_THREE_STR
: cashState == Const.CASE_STATE_FOUR ? Const.CASE_STATE_FOUR_STR
: Const.CASE_STATE_OTHER;
workbook = new HSSFWorkbook();
HSSFSheet sheet = workbook.createSheet(sheetName);
sheet.setDefaultColumnWidth(15);
sheet.createFreezePane(0, 1);
String[] titles = { "编号", "交易ID", "申请时间", "昵称", "姓名", "银行账号",
"开户行", "金额" };
HSSFRow row = sheet.createRow((short) 0);
if (titles != null && titles.length > 0) {
for (int i = 0; i < titles.length; i++) {
ExcelReportUtil.cteateCell(workbook, row, i, titles[i]);
}
}
if (lists != null && lists.size() > 0) {
int size = lists.size();
for (int i = 0; i < lists.size(); i++) {
int num = i + 1;
row = sheet.createRow((short) num);
UserCashDetailVO userCashDetailVO = lists.get(i);
ExcelReportUtil.cteateCell(workbook, row, 0,
String.valueOf(num));
ExcelReportUtil.cteateCell(workbook, row, 1,
userCashDetailVO.getTradeNum());
ExcelReportUtil.cteateCell(workbook, row, 2,
userCashDetailVO.getApplyTime());
ExcelReportUtil.cteateCell(workbook, row, 3,
userCashDetailVO.getNick());
ExcelReportUtil.cteateCell(workbook, row, 4,
userCashDetailVO.getBackUserName());
ExcelReportUtil.cteateCell(workbook, row, 5,
userCashDetailVO.getBackCardNum());
ExcelReportUtil.cteateCell(workbook, row, 6,
userCashDetailVO.getBankCardName());
ExcelReportUtil.cteateCell(workbook, row, 7, String
.valueOf(userCashDetailVO.getMoney().intValue()));
}
row = sheet.createRow((short) size + 1);
ExcelReportUtil.cteateCell(workbook, row, 6, "总金额:");
ExcelReportUtil.cteateCell(workbook, row, 7,
String.valueOf(money.intValue()));
}
} catch (Exception e) {
e.printStackTrace();
}finally{
System.gc();
}
return workbook;
}
- 下载导出
- 导出数据包及下载
- 导入,导出 上传,下载
- ASP导出excel,下载
- 控件 数据下载 导出
- 各种导出下载
- 文件上传、下载、导出
- Excel导出 和下载
- excel的下载导出
- execel导出和下载
- 浏览器下载导出excel
- excel 导出并下载
- 文件下载(导出)
- 文件下载/导出
- POI导出下载
- 前端 下载导出功能
- flex 导出文件&导出图片&文件下载
- 数据导出 下载另类做法
- Android报Caused by: android.content.res.Resources$NotFoundException: String resource ID #0x0 .解决办法
- 在A20上演示老罗的Android硬件抽象层(HAL)概要介绍和学习计划3--关于hal部分
- android sdk manager无法下载的解决办法
- winnt.h error C2146: syntax error : missing ';' before identifier 'PVOID64'
- 一个继承单例,临界区的类CEStnDefinition
- 下载导出
- [mac] ssd optimize
- 一个最简单的计算器
- JavaScript编程风格
- js本地图片预览
- hibernate中使用数据库关键字(保留字)
- 基于HTML5的超级玛丽游戏demo http://www.cnblogs.com/Cson/archive/2012/02/14/2350652.html
- URAL 1036
- 编写NT驱动使得APP能够读取PCI设备配置信息