SSM POI根据预定好的模版导出execle

本文介绍了如何在SSM框架下利用Apache POI库,根据预先设定的Excel模版(xls格式)来导出数据。模版被包含在项目根目录下的template.zip文件中。
摘要由CSDN通过智能技术生成


建立模版文件,xls格式。打包为template.zip,放入项目根目录的zip包下




Controller

import java.util.HashMap;
import java.util.List;
import java.util.Map;


import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;


import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;


import com.jk.danganweihu.entity.Dqxx;
import com.jk.danganweihu.entity.JbXX;
import com.jk.danganweihu.service.RensdataService;
import com.jk.util.POIExportExcel;
import com.jk.util.PagerEntity;
@RequestMapping("out2Execle")
		@ResponseBody
		public boolean out2Execle(HttpServletRequest request,String id){
//			FilesImg fileImg=filesImgService.findBinaryByFid("5b049e95bece499086439ad38ba49118");
			
			JbXX jbxx = rensdataService.queryJbData(id);
			Map<String,Object> map=new HashMap<String,Object>();
			map.put("zwbh", jbxx.getcBh());//职位编号
			map.put("name", jbxx.getcName());//姓名
			map.put("sex", jbxx.getcXb());//性别
			map.put("gzdw", jbxx.getcGzdw());//工作单位
			map.put("oldName", jbxx.getcCym());//曾用名
			map.put("mz", jbxx.getcMz());//民族
			map.put("bmlb", jbxx.getcBmlb());//部门类别
			map.put("gblb", jbxx.getcGblb());//干部类别
//			map.put("age", "26");
			
			
			//注意模版一定要是xls格式
			Map<String, String> impOrSaveExcel = POIExportExcel.ImpOrSaveExcel("basicPersonalInfo.xls", "基本人员信息.xls", map, request);
			if (impOrSaveExcel!=null) {
				return true;
			}else {
				return false;
			}
		}


Util

package com.jk.util;

import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.sql.Blob;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Properties;

import javax.servlet.http.HttpServletRequ
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以的,你可以通过POI库操作数据库,将数据导出为Excel文件(.xls或.xlsx),然后使用JavaMail发送邮件,附带这个Excel文件作为附件。在SSM框架中,你可以使用Spring的JavaMailSender来发送邮件,同时使用POI库来生成Excel文件。以下是一个简单的示例代码: ```java // 导出数据到Excel文件 public void exportDataToExcel() { // 查询数据库数据并获取结果集 List<Data> dataList = dataService.getDataList(); // 创建Excel工作簿 Workbook workbook = new HSSFWorkbook(); Sheet sheet = workbook.createSheet("Data"); // 创建表头 Row headerRow = sheet.createRow(0); headerRow.createCell(0).setCellValue("ID"); headerRow.createCell(1).setCellValue("Name"); // ... // 填充数据 int rowNum = 1; for (Data data : dataList) { Row row = sheet.createRow(rowNum++); row.createCell(0).setCellValue(data.getId()); row.createCell(1).setCellValue(data.getName()); // ... } // 保存Excel文件 try (FileOutputStream outputStream = new FileOutputStream("data.xls")) { workbook.write(outputStream); } catch (IOException e) { e.printStackTrace(); } } // 发送邮件 public void sendEmailWithAttachment() { // 创建一个JavaMailSender实例 JavaMailSenderImpl mailSender = new JavaMailSenderImpl(); // 配置邮件服务器参数 mailSender.setHost("smtp.example.com"); mailSender.setUsername("your-email@example.com"); mailSender.setPassword("your-password"); // 创建一个MimeMessage实例 MimeMessage message = mailSender.createMimeMessage(); try { // 设置邮件内容 MimeMessageHelper helper = new MimeMessageHelper(message, true); helper.setTo("recipient@example.com"); helper.setSubject("Data Export"); helper.setText("Please find the attached Excel file."); // 添加附件 FileSystemResource file = new FileSystemResource(new File("data.xls")); helper.addAttachment("data.xls", file); // 发送邮件 mailSender.send(message); } catch (MessagingException e) { e.printStackTrace(); } } ``` 你可以根据实际情况修改代码中的数据查询、Excel表头和填充、邮件服务器配置等部分。注意替换示例中的邮件服务器参数和收件人地址。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值