java读取邮件excel附件的方法过程示例

 更新时间:2023年10月07日 15:35:11   作者:光法V3  
这篇文章主要介绍了java读取邮件excel附件的方法过程示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

java读取excel附件的方法

项目中会遇到读取邮件excel附件的信息至后台,下面分享一个java读取excel附件的方法。

1、要在后台中读取邮箱附件邮箱必须开启IMAP服务

下图示例为QQ邮箱开启对应服务的设置方法(其他邮箱也可找到对应的设置):

按照提示开通对应服务,需要注意的是如果邮箱使用的是授权码,则需要在后续使用时用授权码代替密码,授权码授权方式更为安全。

2、添加依赖

收发邮件依赖jakarta.mail

<dependency>
  <groupId>com.sun.mail</groupId>
  <artifactId>jakarta.mail</artifactId>
  <version>{version}</version>
</dependency>

读取execel文件依赖POI

<dependency>
   <groupId>org.apache.poi</groupId>
   <artifactId>poi</artifactId>
   <version>{version}</version>
</dependency>
<dependency>
   <groupId>org.apache.poi</groupId>
   <artifactId>poi-ooxml</artifactId>
   <version>{version}</version>
</dependency>

3、读取接收到的邮件,并读取附件信息

3.1读取接收到的邮件代码:

//设置邮箱服务器地址、端口、用户
Properties props = new Properties();
props.setProperty("mail.imapStore.protocol","imap");
props.setProperty("mail.imap.host", "邮箱服务器host");
props.setProperty("mail.imap.port","邮箱服务端口");
// 是否启用ssl
if (useSsl.equals(1)) {
  MailSSLSocketFactory sf = new MailSSLSocketFactory();
  sf.setTrustAllHosts(true);
  props.put("mail.imap.ssl.enable", true);
  props.put("mail.imap.ssl.socketFactory", sf);
  props.put("mail.imap.ssl.protocols", "TLSv1.2");
}
Session session = Session.getInstance(props);
IMAPStore imapStore = (IMAPStore) session.getStore("imap");
// 输入邮箱及密码(授权码)
imapStore.connect("邮箱服务器host", "邮箱服务端口", "email地址","email密码(授权码)");
//打开收件箱
IMAPFolder imapFolder = (IMAPFolder) imapStore.getFolder("INBOX");
if (!imapFolder.isOpen()) {
   imapFolder.open(Folder.READ_ONLY);
}
//读取指定时间之后的邮件数据
SearchTerm searchTerm = new ReceivedDateTerm(ComparisonTerm.GT, new Date(时间戳));
// 取到文件夹中所有信息
Message[] messages = imapFolder.search(searchTerm);
// 循环处理读取到的邮件信息
for (Message message : messages) {
   // 读取附件
   readAttachment(message )   
}

3.2读取附件并且缓存代码:

public List<EmailAttachmentPojo> readAttachment(Part part) throws Exception {
        List<EmailAttachmentPojo> bodyParts = new LinkedList<>();
        if (part.isMimeType("multipart/*")) {
            Multipart multipart = (Multipart) part.getContent();    //复杂体邮件
            //复杂体邮件包含多个邮件体
            int partCount = multipart.getCount();
            for (int i = 0; i < partCount; i++) {
                // 获得复杂体邮件中其中一个邮件体
                BodyPart bodyPart = multipart.getBodyPart(i);
                // 某一个邮件体也有可能是由多个邮件体组成的复杂体
                String disposition = bodyPart.getDisposition();
                if (disposition != null && (disposition.equalsIgnoreCase(Part.ATTACHMENT) || disposition.equalsIgnoreCase(Part.INLINE))) {
                    bodyParts.add(EmailAttachmentPojo.builder()
                            .bodyPart(bodyPart)
                            .filename(decodeText(bodyPart.getFileName()))
                            .build());
                } else if (bodyPart.isMimeType("multipart/*")) {
                    bodyParts.addAll(readAttachment(bodyPart));
                } else {
                    String contentType = bodyPart.getContentType();
                    if (contentType.contains("name") || contentType.contains("application")) {
                        bodyParts.add(EmailAttachmentPojo.builder()
                                .bodyPart(bodyPart)
                                .filename(decodeText(bodyPart.getFileName()))
                                .build());
                    }
                }
            }
        } else if (part.isMimeType("message/rfc822")) {
            bodyParts.addAll(readAttachment((Part) part.getContent()));
        }
        return bodyParts;
}

3.3读取附件excel里的内容

使用POI读取excel的步骤:

1.创建工作簿

2.获取工作表

3.遍历工作表获得行对象

4.遍历行对象获取单元格对象

5.获得单元格中的值

读取excel内容代码示例:

// 1.获取工作簿
XSSFWorkbook workbook = new XSSFWorkbook("C:\\Users\\ghost\\Desktop\\hello.xlsx");
// 2.获取工作表
// xlsx第一个工作簿(Sheet1),下标从0开始,0就是第一个
XSSFSheet sheet = workbook.getSheetAt(0);
// 开始索引(0) 结束索引
int lastRowNum = sheet.getLastRowNum(); //行的结束索引
for (int i = 0; i <= lastRowNum; i++) {
    // 拿到行
    XSSFRow row = sheet.getRow(i);
    if (row != null){
        short cellNum = row.getLastCellNum(); //单元格的结束索引
        for (int j = 0; j <= cellNum; j ++){
            XSSFCell cell = row.getCell(j);
            // 单元格不为空就去拿他的值
            if (cell != null){
                String stringCellValue = cell.getStringCellValue();
                System.out.println(stringCellValue);
            }
        }
    }
}
// 释放资源
workbook.close();

基于上述读取邮件和读取excel文件的方法就可以从邮箱中获取到所需要的业务数据,更多关于java读取邮件附件的资料请关注脚本之家其它相关文章!

相关文章

  • Java函数式编程(三):列表的转化

    Java函数式编程(三):列表的转化

    这篇文章主要介绍了Java函数式编程(二):列表的转化,lambda表达式不仅能帮助我们遍历集合,并且可以进行集合的转化,需要的朋友可以参考下
    2014-09-09
  • JavaFX Metro UI 和 开发库使用简介

    JavaFX Metro UI 和 开发库使用简介

    这篇文章主要介绍了JavaFX Metro UI 和 开发库解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-08-08
  • MyBatis框架底层的执行原理源码解析

    MyBatis框架底层的执行原理源码解析

    这篇文章主要介绍了MyBatis框架底层的执行原理源码解析,本文通过图文实例代码相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-06-06
  • 解决nacos项目启动报错:Connection refused: no further informa问题

    解决nacos项目启动报错:Connection refused: no further&

    这篇文章主要介绍了解决nacos项目启动报错:Connection refused: no further informa问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • 详解Elasticsearch如何实现简单的脚本排序

    详解Elasticsearch如何实现简单的脚本排序

    Elasticsearch 是位于 Elastic Stack 核心的分布式搜索和分析引擎,可以为所有类型的数据提供近乎实时的搜索和分析。本文主要介绍了Elasticsearch如何实现简单的脚本排序,感兴趣的可以了解一下
    2023-01-01
  • 关于RedisTemplate之opsForValue的使用说明

    关于RedisTemplate之opsForValue的使用说明

    这篇文章主要介绍了关于RedisTemplate之opsForValue的使用说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-06-06
  • SpringBoot响应处理实现流程详解

    SpringBoot响应处理实现流程详解

    这篇文章主要介绍了SpringBoot响应处理实现流程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
    2022-10-10
  • Java Map接口概述和常用方法详解

    Java Map接口概述和常用方法详解

    现实生活中,我们常会看到这样的一种集合:IP地址与主机名,身份证号与个人,系统用户名与系统用户对象等,这种一一对应的关系,就叫做映射。Java提供了专门的集合类用来存放这种对象关系的对象,即java.util.Map接口。本文就来聊聊Map接口概述和常用方法
    2022-10-10
  • Java 数据结构中二叉树前中后序遍历非递归的具体实现详解

    Java 数据结构中二叉树前中后序遍历非递归的具体实现详解

    树是一种重要的非线性数据结构,直观地看,它是数据元素(在树中称为结点)按分支关系组织起来的结构,很象自然界中的树那样。树结构在客观世界中广泛存在,如人类社会的族谱和各种社会组织机构都可用树形象表示
    2021-11-11
  • win7下安装 JDK 基本流程

    win7下安装 JDK 基本流程

    这篇文章主要介绍了win7下安装 JDK 基本流程,需要的朋友可以参考下
    2014-05-05

最新评论