JAVA mail 和POI结合使用POI生产Excel直接发送(通过字节流)

2 篇文章 0 订阅
1 篇文章 0 订阅

POI导出生产Excel我就不说了,请参考文章:https://blog.csdn.net/zhuwei_clark/article/details/91040056

首先,先配置发送邮件功能,修改pom文件

		<!-- https://mvnrepository.com/artifact/javax.mail/mail -->
		<dependency>
		    <groupId>javax.mail</groupId>
		    <artifactId>mail</artifactId>
		    <version>1.4.7</version>
		</dependency>

构建发送邮件工具类

package com.xuebaclass.sato.com.util;

import java.io.InputStream;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.Properties;

import javax.activation.DataHandler;
import javax.activation.DataSource;
import javax.mail.Authenticator;
import javax.mail.BodyPart;
import javax.mail.Message.RecipientType;
import javax.mail.Multipart;
import javax.mail.PasswordAuthentication;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeBodyPart;
import javax.mail.internet.MimeMessage;
import javax.mail.internet.MimeMultipart;
import javax.mail.internet.MimeUtility;
import javax.mail.util.ByteArrayDataSource;

import org.apache.log4j.Logger;
/**
 * 发送邮件
 * @author 大仙
 *
 */
public class EmailUtil {
    private static final String SMTP_HOST = "smtp.exmail.qq.com";
    private static final String USER_NAME = "itadmin@xuebaedu.com";
    private static final String PASSWORD = "qeAHYNj2P2nStsKk";

    static final Logger logger = Logger.getLogger(EmailUtil.class);
    /**
     * 发送邮件
     * @param title
     * @param content
     * @param receiveList
     * @throws Exception
     */
    public static void sendEmail(String title, String content,List<String> receiveList,byte[] fileBytes){
        logger.info("send report start.");

        Session session = EmailUtil.getSession();
        MimeMessage message = new MimeMessage(session);
        InternetAddress[] toArray = new InternetAddress[receiveList.size()];
        try {
	        //接收列表
	        for (int i = 0; i < toArray.length; i++) {
	        	toArray[i]= new InternetAddress(receiveList.get(i));
			}
            message.setSubject(title);
            message.setSentDate(new Date());
            message.setFrom(new InternetAddress(USER_NAME));
            message.addRecipients(RecipientType.TO, toArray);
            // 创建消息部分
            BodyPart messageBodyPart = new MimeBodyPart();
            // 消息
            messageBodyPart.setContent(content, "text/html;charset=utf-8");
            // 创建多重消息
            Multipart multipart = new MimeMultipart();
            // 设置文本消息部分
            multipart.addBodyPart(messageBodyPart);
            // 附件部分
            messageBodyPart = new MimeBodyPart();
            // 设置要发送附件的文件路径
            DataSource source=new ByteArrayDataSource(fileBytes, "application/excel");
            messageBodyPart.setDataHandler(new DataHandler(source));
            // 处理附件名称中文(附带文件路径)乱码问题
            messageBodyPart.setFileName(MimeUtility.encodeText(title+".xls"));
            multipart.addBodyPart(messageBodyPart);
            // 发送完整消息
            message.setContent(multipart);
            // 发送消息
            Transport.send(message);
            logger.info("send refund email successful.");
        } catch (Exception e) {
            logger.error(e, e);
        }
    }
    public static void main(String[] args) {
    	List<String> receiveList = new ArrayList<String>();
    	receiveList.add("zwahyh@qq.com");
//		sendEmail("【TMK】集赞/助力成功数据诊断课约课情况", "测试", receiveList);
	}

    public static Session getSession() {
        Properties props = new Properties();
        props.setProperty("mail.transport.protocol", "smtp");
        props.setProperty("mail.smtp.host", SMTP_HOST);
        props.setProperty("mail.smtp.port", "25");
        props.setProperty("mail.smtp.auth", "true");
        Session session = Session.getInstance(props,
                new Authenticator() {
                    @Override
                    protected PasswordAuthentication getPasswordAuthentication() {
                        return new PasswordAuthentication(USER_NAME, PASSWORD);
                    }
                });

        return session;
    }
}

生成Excel内容

	@Override
	public String sendExperiencesStatusEmail(String startDate, String endDate) {
		//查询数据
		List<Map<String, Object>> data = crmCourseDao.getExperiencesStatusByDate(startDate, endDate);
		//获取表头
		String[] titile = createTitle();
		String[][] content = new String[data.size()][];
		//处理数据
		for (int i = 0; i < data.size(); i++) {
			Map<String, Object> map = data.get(i);
			content[i] = new String[titile.length];
			content[i][0] = Pub_Tools.getString_TrimZeroLenAsNull(map.get("contactName"));
			content[i][1] = Pub_Tools.getString_TrimZeroLenAsNull(map.get("contactMobile"));
			content[i][2] = Pub_Tools.getString_TrimZeroLenAsNull(map.get("tmkName"));
			content[i][3] = Pub_Tools.getString_TrimZeroLenAsNull(map.get("lessonStatus"));
			content[i][4] = Pub_Tools.getString_TrimZeroLenAsNull(map.get("salesName"));
			content[i][5] = Pub_Tools.getString_TrimZeroLenAsNull(map.get("jizanDate"));
			content[i][6] = Pub_Tools.getString_TrimZeroLenAsNull(map.get("lessonDate"));
		}
		//创建HSSFWorkbook 
		HSSFWorkbook wb = ExcelUtil.getHSSFWorkbook("【TMK】助力成功数据诊断课约课情况",titile , content, null);
		ByteArrayOutputStream os = new ByteArrayOutputStream();
		try {
			wb.write(os);
		} catch (IOException e) {
			e.printStackTrace();
		}
		List<String> receiveList = new ArrayList<String>();
		receiveList.add("yangzhipeng@xuebaedu.com");
		receiveList.add("zwahyh@qq.com");
		EmailUtil.sendEmail("【TMK】集赞/助力成功数据诊断课约课情况", "【TMK】集赞/助力成功数据诊断课约课情况", receiveList,os.toByteArray());
		return null;
	}
	/**
	 * 获取标题
	 * @return
	 */
	private String[] createTitle() {
		String[] title = new String[] {"客户名称","客户电话","TMK姓名"," 诊断课状态","CC姓名","集赞成功时间","诊断课时间"};
		return title;
	}

 

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
好的,以下是一个简单的 Java 代码示例,演示如何将图片流导出到 Excel使用 POI 库: ```java import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import org.apache.poi.ss.usermodel.*; import org.apache.poi.xssf.usermodel.XSSFWorkbook; import org.apache.poi.util.IOUtils; import org.apache.poi.ss.util.ImageUtils; public class PoiExportImageStreamToExcelExample { public static void main(String[] args) throws IOException { String excelPath = "path_to_excel.xlsx"; int rowIndex = 0; int columnIndex = 0; // 创建 Excel 工作簿 Workbook workbook = new XSSFWorkbook(); Sheet sheet = workbook.createSheet("Sheet1"); // 加载图片流 InputStream imageStream = new FileInputStream("path_to_image.png"); // 将图片流转换为字节数组 byte[] imageData = IOUtils.toByteArray(imageStream); // 插入图片到单元格中 Drawing<?> drawing = sheet.createDrawingPatriarch(); ClientAnchor anchor = drawing.createAnchor(0, 0, 0, 0, columnIndex, rowIndex, columnIndex + 1, rowIndex + 1); Picture picture = drawing.createPicture(anchor, workbook.addPicture(imageData, Workbook.PICTURE_TYPE_PNG)); // 输出到 Excel 文件 FileOutputStream fileOut = new FileOutputStream(excelPath); workbook.write(fileOut); fileOut.close(); workbook.close(); imageStream.close(); System.out.println("图片已经成功导出到 Excel 文件中!"); } } ``` 这个示例假设图片已经存在于本地文件系统中,你需要将 `path_to_image.png` 替换为你的图片路径。它还假设你想将图片插入到单元格的第一行第一列,如果你想插入到其他位置,你需要修改 `rowIndex` 和 `columnIndex` 变量的值。 这个示例使用 POI 的 `Workbook` 和 `Sheet` 类创建了一个 Excel 文件,然后使用 `Drawing` 和 `ClientAnchor` 类将图片插入到单元格中。最后,使用 `FileOutputStream` 将工作簿写入到本地文件系统中。注意,流需要在写入完毕后关闭,所以我们使用 `imageStream.close()` 关闭流。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值