java解析邮箱中的邮件信息
- import lombok.extern.slf4j.Slf4j;
- import org.springframework.beans.factory.annotation.Value;
- import javax.mail.*;
- import javax.mail.internet.InternetAddress;
- import javax.mail.internet.MimeMessage;
- import javax.mail.internet.MimeMultipart;
- import javax.mail.internet.MimeUtility;
- import java.io.*;
- import java.text.SimpleDateFormat;
- import java.util.Date;
- import java.util.Properties;
- /**
- * 使用POP3协议解析邮件帮助类
- *
- * @author bzs on 2018/6/28.
- */
- @Slf4j
- public class ParsingEmailUtil {
- public static void main(String[] args) throws Exception{
- resceive("**********@163.com", "*****");
- }
- /**
- * 获取邮箱信息
- *
- * @param emailAdress 需要解析的邮箱地址
- * @param password 邮箱的授权密码
- * @throws Exception
- */
- public static void resceive(String emailAdress, String password) throws Exception {
- String port = "110"; // 端口号
- String servicePath = "pop.163.com"; // 服务器地址
- // 准备连接服务器的会话信息
- Properties props = new Properties();
- props.setProperty("mail.store.protocol", "pop3"); // 使用pop3协议
- props.setProperty("mail.pop3.port", port); // 端口
- props.setProperty("mail.pop3.host", servicePath); // pop3服务器
- // 创建Session实例对象
- Session session = Session.getInstance(props);
- Store store = session.getStore("pop3");
- store.connect(emailAdress, password); //163邮箱程序登录属于第三方登录所以这里的密码是163给的授权密码而并非普通的登录密码
- // 获得收件箱
- Folder folder = store.getFolder("INBOX");
- /* Folder.READ_ONLY:只读权限
- * Folder.READ_WRITE:可读可写(可以修改邮件的状态)
- */
- folder.open(Folder.READ_WRITE); //打开收件箱
- // // 由于POP3协议无法获知邮件的状态,所以getUnreadMessageCount得到的是收件箱的邮件总数
- // System.out.println("未读邮件数: " + folder.getUnreadMessageCount());
- //
- // // 由于POP3协议无法获知邮件的状态,所以下面得到的结果始终都是为0
- // System.out.println("删除邮件数: " + folder.getDeletedMessageCount());
- // System.out.println("新邮件: " + folder.getNewMessageCount());
- // 获得收件箱中的邮件总数
- log.warn("邮件总数: {}", folder.getMessageCount());
- // 得到收件箱中的所有邮件,并解析
- Message[] messages = folder.getMessages();
- //解析邮件
- parseMessage(messages);
- //得到收件箱中的所有邮件并且删除邮件
- // deleteMessage(messages);
- //释放资源
- folder.close(true);
- store.close();
- }
- /**
- * 解析邮件
- *
- * @param messages 要解析的邮件列表
- */
- public static void parseMessage(Message... messages) throws MessagingException, IOException {
- if (messages == null || messages.length < 1)
- throw new MessagingException("未找到要解析的邮件!");
- // 解析所有邮件
- for (int i = 0, count = messages.length; i < count; i++) {
- MimeMessage msg = (MimeMessage) messages[i];
- log.info("------------------解析第" + msg.getMessageNumber() + "封邮件-------------------- ");
- log.warn("主题: {}" , getSubject(msg));
- log.warn("发件人: {}" , getFrom(msg));
- log.warn("收件人:{}" , getReceiveAddress(msg, null));
- log.warn("发送时间:{}" , getSentDate(msg, null));
- log.warn("是否已读:{}" , isSeen(msg));
- log.warn("邮件优先级:{}" , getPriority(msg));
- log.warn("是否需要回执:{}" , isReplySign(msg));
- log.warn("邮件大小:{}" , msg.getSize() * 1024 + "kb");
- boolean isContainerAttachment = isContainAttachment(msg);
- log.warn("是否包含附件:{}" ,isContainerAttachment);
- if (isContainerAttachment) {
- saveAttachment(msg, "d:\\log\\" + msg.getSubject() + "_" + i + "_"); //保存附件
- }
- StringBuffer content = new StringBuffer(30);
- //解析邮件正文
- getMailTextContent(msg, content);
- log.warn("邮件正文:{}" , content);
- log.info("------------------第" + msg.getMessageNumber() + "封邮件解析结束-------------------- ");
- System.out.println();
- }
- }
- /**
- * 删除邮件
- *
- * @param messages 要删除邮件列表
- */
- public static void deleteMessage(Message... messages) throws MessagingException, IOException {
- if (messages == null || messages.length < 1)
- throw new MessagingException("未找到要解析的邮件!");
- // 解析所有邮件
- for (int i = 0, count = messages.length; i < count; i++) {
- /**
- * 邮件删除
- */
- Message message = messages[i];
- String subject = message.getSubject();
- // set the DELETE flag to true
- message.setFlag(Flags.Flag.DELETED, true);
- System.out.println("Marked DELETE for message: " + subject);
- }
- }
- /**
- * 获得邮件主题
- *
- * @param msg 邮件内容
- * @return 解码后的邮件主题
- */
- public static String getSubject(MimeMessage msg) throws UnsupportedEncodingException, MessagingException {
- return MimeUtility.decodeText(msg.getSubject());
- }
- /**
- * 获得邮件发件人
- *
- * @param msg 邮件内容
- * @return 姓名 <Email地址>
- * @throws MessagingException
- * @throws UnsupportedEncodingException
- */
- public static String getFrom(MimeMessage msg) throws MessagingException, UnsupportedEncodingException {
- String from = "";
- Address[] froms = msg.getFrom();
- if (froms.length < 1)
- throw new MessagingException("没有发件人!");
- InternetAddress address = (InternetAddress) froms[0];
- String person = address.getPersonal();
- if (person != null) {
- person = MimeUtility.decodeText(person) + " ";
- } else {
- person = "";
- }
- from = person + "<" + address.getAddress() + ">";
- return from;
- }
- /**
- * 根据收件人类型,获取邮件收件人、抄送和密送地址。如果收件人类型为空,则获得所有的收件人
- * <p>Message.RecipientType.TO 收件人</p>
- * <p>Message.RecipientType.CC 抄送</p>
- * <p>Message.RecipientType.BCC 密送</p>
- *
- * @param msg 邮件内容
- * @param type 收件人类型
- * @return 收件人1 <邮件地址1>, 收件人2 <邮件地址2>, ...
- * @throws MessagingException
- */
- public static String getReceiveAddress(MimeMessage msg, Message.RecipientType type) throws MessagingException {
- StringBuffer receiveAddress = new StringBuffer();
- Address[] addresss = null;
- if (type == null) {
- addresss = msg.getAllRecipients();
- } else {
- addresss = msg.getRecipients(type);
- }
- if (addresss == null || addresss.length < 1)
- throw new MessagingException("没有收件人!");
- for (Address address : addresss) {
- InternetAddress internetAddress = (InternetAddress) address;
- receiveAddress.append(internetAddress.toUnicodeString()).append(",");
- }
- receiveAddress.deleteCharAt(receiveAddress.length() - 1); //删除最后一个逗号
- return receiveAddress.toString();
- }
- /**
- * 获得邮件发送时间
- *
- * @param msg 邮件内容
- * @return yyyy年mm月dd日 星期X HH:mm
- * @throws MessagingException
- */
- public static String getSentDate(MimeMessage msg, String pattern) throws MessagingException {
- Date receivedDate = msg.getSentDate();
- if (receivedDate == null)
- return "";
- if (pattern == null || "".equals(pattern))
- pattern = "yyyy年MM月dd日 E HH:mm ";
- return new SimpleDateFormat(pattern).format(receivedDate);
- }
- /**
- * 判断邮件中是否包含附件
- *
- * @param part 邮件内容
- * @return 邮件中存在附件返回true,不存在返回false
- * @throws MessagingException
- * @throws IOException
- */
- public static boolean isContainAttachment(Part part) throws MessagingException, IOException {
- boolean flag = false;
- if (part.isMimeType("multipart/*")) {
- MimeMultipart multipart = (MimeMultipart) part.getContent();
- int partCount = multipart.getCount();
- for (int i = 0; i < partCount; i++) {
- BodyPart bodyPart = multipart.getBodyPart(i);
- String disp = bodyPart.getDisposition();
- if (disp != null && (disp.equalsIgnoreCase(Part.ATTACHMENT) || disp.equalsIgnoreCase(Part.INLINE))) {
- flag = true;
- } else if (bodyPart.isMimeType("multipart/*")) {
- flag = isContainAttachment(bodyPart);
- } else {
- String contentType = bodyPart.getContentType();
- if (contentType.indexOf("application") != -1) {
- flag = true;
- }
- if (contentType.indexOf("name") != -1) {
- flag = true;
- }
- }
- if (flag) break;
- }
- } else if (part.isMimeType("message/rfc822")) {
- flag = isContainAttachment((Part) part.getContent());
- }
- return flag;
- }
- /**
- * 判断邮件是否已读
- *
- * @param msg 邮件内容
- * @return 如果邮件已读返回true, 否则返回false
- * @throws MessagingException
- */
- public static boolean isSeen(MimeMessage msg) throws MessagingException {
- return msg.getFlags().contains(Flags.Flag.SEEN);
- }
- /**
- * 判断邮件是否需要阅读回执
- *
- * @param msg 邮件内容
- * @return 需要回执返回true, 否则返回false
- * @throws MessagingException
- */
- public static boolean isReplySign(MimeMessage msg) throws MessagingException {
- boolean replySign = false;
- String[] headers = msg.getHeader("Disposition-Notification-To");
- if (headers != null)
- replySign = true;
- return replySign;
- }
- /**
- * 获得邮件的优先级
- *
- * @param msg 邮件内容
- * @return 1(High):紧急 3:普通(Normal) 5:低(Low)
- * @throws MessagingException
- */
- public static String getPriority(MimeMessage msg) throws MessagingException {
- String priority = "普通";
- String[] headers = msg.getHeader("X-Priority");
- if (headers != null) {
- String headerPriority = headers[0];
- if (headerPriority.indexOf("1") != -1 || headerPriority.indexOf("High") != -1)
- priority = "紧急";
- else if (headerPriority.indexOf("5") != -1 || headerPriority.indexOf("Low") != -1)
- priority = "低";
- else
- priority = "普通";
- }
- return priority;
- }
- /**
- * 获得邮件文本内容
- *
- * @param part 邮件体
- * @param content 存储邮件文本内容的字符串
- * @throws MessagingException
- * @throws IOException
- */
- public static void getMailTextContent(Part part, StringBuffer content) throws MessagingException, IOException {
- //如果是文本类型的附件,通过getContent方法可以取到文本内容,但这不是我们需要的结果,所以在这里要做判断
- boolean isContainTextAttach = part.getContentType().indexOf("name") > 0;
- if (part.isMimeType("text/*") && !isContainTextAttach) {
- content.append(part.getContent().toString());
- } else if (part.isMimeType("message/rfc822")) {
- getMailTextContent((Part) part.getContent(), content);
- } else 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);
- getMailTextContent(bodyPart, content);
- }
- }
- }
- /**
- * 保存附件
- *
- * @param part 邮件中多个组合体中的其中一个组合体
- * @param destDir 附件保存目录
- * @throws UnsupportedEncodingException
- * @throws MessagingException
- * @throws FileNotFoundException
- * @throws IOException
- */
- public static void saveAttachment(Part part, String destDir) throws MessagingException, IOException {
- 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 disp = bodyPart.getDisposition();
- if (disp != null && (disp.equalsIgnoreCase(Part.ATTACHMENT) || disp.equalsIgnoreCase(Part.INLINE))) {
- InputStream is = bodyPart.getInputStream();
- saveFile(is, destDir, decodeText(bodyPart.getFileName()));
- } else if (bodyPart.isMimeType("multipart/*")) {
- saveAttachment(bodyPart, destDir);
- } else {
- String contentType = bodyPart.getContentType();
- if (contentType.indexOf("name") != -1 || contentType.indexOf("application") != -1) {
- saveFile(bodyPart.getInputStream(), destDir, decodeText(bodyPart.getFileName()));
- }
- }
- }
- } else if (part.isMimeType("message/rfc822")) {
- saveAttachment((Part) part.getContent(), destDir);
- }
- }
- /**
- * 读取输入流中的数据保存至指定目录
- *
- * @param is 输入流
- * @param fileName 文件名
- * @param destDir 文件存储目录
- * @throws FileNotFoundException
- * @throws IOException
- */
- private static void saveFile(InputStream is, String destDir, String fileName) throws FileNotFoundException, IOException {
- BufferedInputStream bis = new BufferedInputStream(is);
- BufferedOutputStream bos = new BufferedOutputStream(
- new FileOutputStream(new File(destDir + fileName)));
- int len = -1;
- while ((len = bis.read()) != -1) {
- bos.write(len);
- bos.flush();
- }
- bos.close();
- bis.close();
- }
- /**
- * 文本解码
- *
- * @param encodeText 解码MimeUtility.encodeText(String text)方法编码后的文本
- * @return 解码后的文本
- * @throws UnsupportedEncodingException
- */
- public static String decodeText(String encodeText) throws UnsupportedEncodingException {
- if (encodeText == null || "".equals(encodeText)) {
- return "";
- } else {
- return MimeUtility.decodeText(encodeText);
- }
- }
- }
通过此方法可以解析出邮箱中邮件的详细信息。
java解析邮箱中的邮件信息的更多相关文章
- 日期格式化(类似QQ邮箱中的邮件列表显示日期)
日期格式化(类似QQ邮箱中的邮件列表显示日期) public static string FormatDateDisplay(DateTime _datetime) { var ts = DateTi ...
- java解析xml实例——获取天气信息
获取xml并解析其中的数据: package getweather.xml; import java.io.IOException; import java.util.HashMap; import ...
- Java 在Word中创建邮件合并模板并合并文本和图片
Word里面的邮件合并功能是一种可以快速批量操作同类型数据的方式,常见的如数据填充.打印等.其中必不可少的步骤包括用于填充的模板文档.填充的数据源以及实现邮件合并的功能.下面,通过Java程序展示如何 ...
- java 解析webservice 中的soapheader
//从MessageContet中获取头域中的值 public HeaderBean getBeanFromRequest(org.apache.axis2.context.MessageContex ...
- Linux中Postfix邮件认证配置(五)
Postfix+Dovecot+Sasl工作原理 1.A用户使用MUA客户端借助smtp协议登陆smtpd服务器,需要先进行用户和密码认证,而SMTPD服务器端支持sasl认证,例如有一个sasl客户 ...
- Android将日志信息自动发送到指定的邮箱中 邮件的内容以附件形式发送
今日整合了网上一些大神的例子(具体看了那些大神的?这个真不好意思我忘记了.下次再整合一定给大家补上,这次也只有默默的给那几个大神说声抱歉了.)做了一个“记录android项目中的日志信息,并将日志信息 ...
- Java解析OFFICE(word,excel,powerpoint)以及PDF的实现方案及开发中的点滴分享
Java解析OFFICE(word,excel,powerpoint)以及PDF的实现方案及开发中的点滴分享 在此,先分享下写此文前的经历与感受,我所有的感觉浓缩到一个字,那就是:"坑&qu ...
- EBS中使用JAVA方式发送HTML格式邮件
转自huan.gu专栏:http://blog.csdn.net/gh320/article/details/17174769 EBS中使用JAVA方式发送HTML格式邮件 一.开发工具:JDevel ...
- JAVA方法调用中的解析与分派
JAVA方法调用中的解析与分派 本文算是<深入理解JVM>的读书笔记,参考书中的相关代码示例,从字节码指令角度看看解析与分派的区别. 方法调用,其实就是要回答一个问题:JVM在执行一个方法 ...
随机推荐
- 激光数据匹配(MATLAB Robotics System Toolbox)
正态分布变换算法是一个配准算法,它应用于三维点的统计模型,使用标准最优化技术来确定两个点云间的最优的匹配,因为其在配准过程中不利用对应点的特征计算和匹配,所以时间比其他方法快.算法细节可以参考:NDT ...
- Java邻接表表示加权有向图,附dijkstra最短路径算法
从A到B,有多条路线,要找出最短路线,应该用哪种数据结构来存储这些数据. 这不是显然的考查图论的相关知识了么, 1.图的两种表示方式: 邻接矩阵:二维数组搞定. 邻接表:Map<Vertext, ...
- spark的外排:AppendOnlyMap与ExternalAppendOnlyMap
相信很多人和我一样, 在控制台中总是可以看到会打印出如下的语句: INFO ExternalAppendOnlyMap: Thread 94 spilling in-memory map of 63. ...
- Docker安装和常用命令
Docker安装 Docker的安装可以参考 https://docs.docker.com/ 下面的 Get Docker / Docker CE / Linux, 需要关注的主要是CentOS和U ...
- Maven + SpringMVC项目集成Swagger
Swagger 是一个规范和完整的框架,用于生成.描述.调用和可视化 RESTful 风格的 Web 服务.总体目标是使客户端和文件系统作为服务器以同样的速度来更新.文件的方法,参数和模型紧密集成到服 ...
- linux(ubuntu) 查看系统设备信息 命令
时间:2012-08-02 00:12 ubuntu查看版本命令 方法一: 在终端中执行下列指令: cat /etc/issue 方法二: 使用 lsb_release 命令也可以查看 Ubunt ...
- ios实例开发精品文章推荐(7.22)
UIView 基本方法 UIView的一些基本方法理解:loadView.viewDidLoad.viewDidUnload.viewWillAppear,viewWillDisappear init ...
- nfs的优化
总结和测试了一下自己的经验: NFS中的rsize.wsize rsize.wsize对于NFS的效能有很大的影响.wsize和rsize设定了SERVER和CLIENT之间往来数据块的大小,这两个参 ...
- Linux下DIR,dirent,stat等结构体详解(转)
最近在看Linux下文件操作相关章节,遇到了这么几个结构体,被搞的晕乎乎的,今日有空,仔细研究了一下,受益匪浅. 首先说说DIR这一结构体,以下为DIR结构体的定义: struct __dirstre ...
- 【ASP.NET】ASP.NET中权限验证使用OnAuthorization实现
在项目开发中,通常我们都会涉及到用户登录才能访问的网页,比如购物网站,我们浏览商品,添加购物车(以前开发的时候在这里就需要登录用户,但是现在有了缓存的实现,这里可以将商品加入缓存,等到结账的时候再登录 ...