- 浏览: 2807 次
- 性别:
- 来自: 武汉
最近访客 更多访客>>
文章分类
最新评论
-
godson_2003:
怎么不能获得邮件正文内容呢?
JAVAMAil收取邮件为什么不能判断是否是新邮件 -
camelwoo:
楼上正解.
JAVAMAil收取邮件为什么不能判断是否是新邮件 -
bo_83:
pop3不会告诉你是否是新邮件 统统收下来自己判断 imap好 ...
JAVAMAil收取邮件为什么不能判断是否是新邮件 -
shijiyu:
怎么运行时出现 javax.mail.MessagingExc ...
JAVAMAil收取邮件为什么不能判断是否是新邮件 -
pikachu:
这种冷饭还抄,转的也不说一声,隐藏!
抽象工厂模式
代码如下。。。我收取到的邮件判断的都是false,没有一个true的。
这代码收取邮件会出现乱码。。。不知道怎么解决。。。希望能帮帮忙。。。
这代码收取邮件会出现乱码。。。不知道怎么解决。。。希望能帮帮忙。。。
package com; import java.io.*; import java.text.*; import java.util.*; import javax.mail.*; import javax.mail.internet.*; import javax.servlet.http.HttpServletRequest; import com.gdschina.ccu.util.UIDGenerator; /** * 有一封邮件就需要建立一个ReciveMail对象 */ public class ReciveOneMail { private MimeMessage mimeMessage = null; private String saveAttachPath = ""; //附件下载后的存放目录 private StringBuffer bodytext = new StringBuffer();//存放邮件内容 private String dateformat = "yy-MM-dd HH:mm"; //默认的日前显示格式 public ReciveOneMail(MimeMessage mimeMessage) { this.mimeMessage = mimeMessage; } public void setMimeMessage(MimeMessage mimeMessage) { this.mimeMessage = mimeMessage; } /** * 获得发件人的地址和姓名 */ public String getFrom() throws Exception { InternetAddress address[] = (InternetAddress[]) mimeMessage.getFrom(); String from = address[0].getAddress(); if (from == null) from = ""; String personal = address[0].getPersonal(); //发件人的姓名 if (personal == null) personal = ""; String fromaddr = personal + "<" + from + ">"; //发件人的地址 return fromaddr; } /** * 获得邮件的收件人,抄送,和密送的地址和姓名,根据所传递的参数的不同 "to"----收件人 "cc"---抄送人地址 "bcc"---密送人地址 */ public String getMailAddress(String type) throws Exception { String mailaddr = ""; String addtype = type.toUpperCase(); InternetAddress[] address = null; if (addtype.equals("TO") || addtype.equals("CC")|| addtype.equals("BCC")) { if (addtype.equals("TO")) { address = (InternetAddress[]) mimeMessage.getRecipients(Message.RecipientType.TO); } else if (addtype.equals("CC")) { address = (InternetAddress[]) mimeMessage.getRecipients(Message.RecipientType.CC); } else { address = (InternetAddress[]) mimeMessage.getRecipients(Message.RecipientType.BCC); } if (address != null) { for (int i = 0; i < address.length; i++) { String email = address[i].getAddress(); if (email == null) email = ""; else { email = MimeUtility.decodeText(email); } String personal = address[i].getPersonal(); if (personal == null) personal = ""; else { personal = MimeUtility.decodeText(personal); } String compositeto = personal + "<" + email + ">"; mailaddr += "," + compositeto; } mailaddr = mailaddr.substring(0); } } else { throw new Exception("Error emailaddr type!"); } return mailaddr; } /** * 获得有中文字的参数, 转成 UTF-8 encoding, default 为 "" . * * @param request * @param name * 参数名. * @return */ public static String setDecodeText( String name) { String tmp = ""; try { tmp = new String( name.getBytes( "ISO-8859-1"), "UTF-8"); } catch (UnsupportedEncodingException e) { } return tmp; } /** * 获得邮件主题 */ public String getSubject() throws MessagingException { String subject = ""; try { subject = mimeMessage.getSubject(); String header = ((MimeMessage)mimeMessage).getHeader("SUBJECT")[0]; if ((header.toLowerCase().indexOf("=?"))>0) { subject = new String((subject.getBytes("iso-8859-1")),"gb2312"); } if (subject == null) subject = ""; } catch (Exception exce) {} return subject; } /** * 获得邮件发送日期 */ public String getSentDate() throws Exception { Date sentdate = mimeMessage.getSentDate(); SimpleDateFormat format = new SimpleDateFormat(dateformat); return format.format(sentdate); } /** * 获取收件时间 * @return * @throws Exception */ public String getReceivedDate() throws Exception{ Date receivedDate = mimeMessage.getReceivedDate(); SimpleDateFormat format = new SimpleDateFormat(dateformat); return format.format(receivedDate); } /** * 获得邮件正文内容 */ public String getBodyText() { return bodytext.toString(); } /** * 解析邮件,把得到的邮件内容保存到一个StringBuffer对象中,解析邮件 主要是根据MimeType类型的不同执行不同的操作,一步一步的解析 */ public void getMailContent(Part part) throws Exception { String contenttype = part.getContentType(); int nameindex = contenttype.indexOf("name"); boolean conname = false; if (nameindex != -1) conname = true; System.out.println("CONTENTTYPE: " + contenttype); if (part.isMimeType("text/plain") && !conname) { bodytext.append((String) part.getContent()); } else if (part.isMimeType("text/html") && !conname) { bodytext.append((String) part.getContent()); } else if (part.isMimeType("multipart/*")) { Multipart multipart = (Multipart) part.getContent(); int counts = multipart.getCount(); for (int i = 0; i < counts; i++) { getMailContent(multipart.getBodyPart(i)); } } else if (part.isMimeType("message/rfc822")) { getMailContent((Part) part.getContent()); } else {} } /** * 判断此邮件是否需要回执,如果需要回执返回"true",否则返回"false" */ public boolean getReplySign() throws MessagingException { boolean replysign = false; String needreply[] = mimeMessage .getHeader("Disposition-Notification-To"); if (needreply != null) { replysign = true; } return replysign; } /** * 获得此邮件的Message-ID */ public String getMessageId() throws MessagingException { return mimeMessage.getMessageID(); } /** * 【判断此邮件是否已读,如果未读返回返回false,反之返回true】 */ public boolean isNew() throws MessagingException { boolean isnew = false; Flags flags = ((Message) mimeMessage).getFlags(); Flags.Flag[] flag = flags.getSystemFlags(); System.out.println("flags's length: " + flag.length); for (int i = 0; i < flag.length; i++) { if (flag[i] == Flags.Flag.SEEN) { isnew = true; System.out.println("seen Message......."); break; } } return isnew; } /** * 判断此邮件是否包含附件 */ public boolean isContainAttach(Part part) throws Exception { boolean attachflag = false; String contentType = part.getContentType(); if (part.isMimeType("multipart/*")) { Multipart mp = (Multipart) part.getContent(); for (int i = 0; i < mp.getCount(); i++) { BodyPart mpart = mp.getBodyPart(i); String disposition = mpart.getDisposition(); if ((disposition != null) && ((disposition.equals(Part.ATTACHMENT)) || (disposition .equals(Part.INLINE)))) attachflag = true; else if (mpart.isMimeType("multipart/*")) { attachflag = isContainAttach((Part) mpart); } else { String contype = mpart.getContentType(); if (contype.toLowerCase().indexOf("application") != -1) attachflag = true; if (contype.toLowerCase().indexOf("name") != -1) attachflag = true; } } } else if (part.isMimeType("message/rfc822")) { attachflag = isContainAttach((Part) part.getContent()); } return attachflag; } /** * 【保存附件】 */ public void saveAttachMent(Part part) throws Exception { String fileName = ""; if (part.isMimeType("multipart/*")) { Multipart mp = (Multipart) part.getContent(); for (int i = 0; i < mp.getCount(); i++) { BodyPart mpart = mp.getBodyPart(i); String disposition = mpart.getDisposition(); if ((disposition != null) && ((disposition.equals(Part.ATTACHMENT)) || (disposition .equals(Part.INLINE)))) { fileName = mpart.getFileName(); if (fileName.toLowerCase().indexOf("gbk") != -1) { fileName = MimeUtility.decodeText(fileName); } saveFile(fileName, mpart.getInputStream()); } else if (mpart.isMimeType("multipart/*")) { saveAttachMent(mpart); } else { fileName = mpart.getFileName(); if ((fileName != null) && (fileName.toLowerCase().indexOf("GB2312") != -1)) { fileName = MimeUtility.decodeText(fileName); saveFile(fileName, mpart.getInputStream()); } } } } else if (part.isMimeType("message/rfc822")) { saveAttachMent((Part) part.getContent()); } } /** * 【设置附件存放路径】 */ public void setAttachPath(String attachpath) { this.saveAttachPath = attachpath; } /** * 【设置日期显示格式】 */ public void setDateFormat(String format) throws Exception { this.dateformat = format; } /** * 【获得附件存放路径】 */ public String getAttachPath() { return saveAttachPath; } /** * 【真正的保存附件到指定目录里】 */ private void saveFile(String fileName, InputStream in) throws Exception { String osName = System.getProperty("os.name"); String storedir = getAttachPath(); String separator = ""; if (osName == null) osName = ""; if (osName.toLowerCase().indexOf("win") != -1) { separator = "\\"; if (storedir == null || storedir.equals("")) storedir = "D:\\tmp"; } else { separator = "/"; storedir = "/tmp"; } // fileName = UIDGenerator.getUID(); File storefile = new File(MimeUtility.decodeText(storedir) + MimeUtility.decodeText(separator) + MimeUtility.decodeText(fileName)); System.out.println("storefile's path: " + storefile.toString()); // for(int i=0;storefile.exists();i++){ // storefile = new File(storedir+separator+fileName+i); // } BufferedOutputStream bos = null; BufferedInputStream bis = null; try { bos = new BufferedOutputStream(new FileOutputStream(storefile)); bis = new BufferedInputStream(in); int c; while ((c = bis.read()) != -1) { bos.write(c); bos.flush(); } } catch (Exception exception) { exception.printStackTrace(); throw new Exception("文件保存失败!"); } finally { bos.close(); bis.close(); } } /** * PraseMimeMessage类测试 */ public static void main(String args[]) throws Exception { Properties props = System.getProperties(); props.put("mail.smtp.host", " smtp.163.com"); props.put("mail.smtp.auth", "true"); Session session = Session.getDefaultInstance(props, null); URLName urln = new URLName("pop3", "pop.163.com", 110, null, "[用户名]", "[密码]"); Store store = session.getStore(urln); store.connect(); Folder folder = store.getFolder("INBOX"); folder.open(Folder.READ_ONLY); Message message[] = folder.getMessages(); System.out.println("Messages's length: " + message.length); ReciveOneMail pmm = null; Date sendDate = null; Date today = null; Date date = new Date(); Date day = new Date(); SimpleDateFormat format = new SimpleDateFormat("yyyy/MM/dd"); try{ for (int i = 0; i < message.length; i++) { pmm = new ReciveOneMail((MimeMessage) message[i]); pmm.setDateFormat("yyyy/MM/dd"); String send_date = pmm.getSentDate(); sendDate = format.parse(send_date); today = format.parse(format.format(day)); today.compareTo(sendDate); today.after(sendDate); System.out.println("Message " + i + " 是新邮件: " + pmm.isNew()); //是否是新邮件 System.out.println("第"+i+"封"); System.out.println("======================"); System.out.println("Message " + i + " 主题: " + setDecodeText(pmm.getSubject())); //获取主题 System.out.println("Message " + i + " 发送日期: "+ pmm.getSentDate()); //获取邮件发送日期 System.out.println("Message " + i + " 是否需要回复: "+ pmm.getReplySign());// System.out.println("Message " + i + " 是否新邮件: " + pmm.isNew()); //是否是新邮件 System.out.println("Message " + i + " 是否包含附件: "+ pmm.isContainAttach((Part) message[i])); //是否包含附件 System.out.println("Message " + i + " 发件人和地: " + pmm.getFrom()); //获取发件人和地址 System.out.println("Message " + i + " 收件人: "+ pmm.getMailAddress("to")); //收件人 System.out.println("Message " + i + " 抄送人: "+ pmm.getMailAddress("cc")); //抄送人 System.out.println("Message " + i + " 密抄送人: "+ pmm.getMailAddress("bcc")); //密抄送人 // pmm.setDateFormat("yy年MM月dd日 HH:mm"); System.out.println("Message " + i + " 收件时间 "+ pmm.getSentDate()); System.out.println("Message " + i + " 邮件的ID: "+ pmm.getMessageId()); //获取邮件的ID // 获得邮件内容=============== // pmm.getMailContent((Part) message[i]); System.out.println("Message " + i + " 邮件内容: \r\n" + pmm.getBodyText()); System.out.println("附件的路径"+pmm.getAttachPath()); pmm.setAttachPath("D:\\tmp\\"); pmm.saveAttachMent((Part) message[i]); today.after(sendDate); folder.close(true); store.close(); } }catch(Exception e){ e.printStackTrace(); } } }
评论
4 楼
godson_2003
2009-04-22
怎么不能获得邮件正文内容呢?
3 楼
camelwoo
2008-10-24
楼上正解.
2 楼
bo_83
2008-10-16
pop3不会告诉你是否是新邮件 统统收下来自己判断 imap好像可以 是好像 你去查一下
1 楼
shijiyu
2008-10-15
怎么运行时出现 javax.mail.MessagingException: Connect failed;
nested exception is:
java.net.SocketException: Connection reset
at com.sun.mail.pop3.POP3Store.protocolConnect(POP3Store.java:106)
at javax.mail.Service.connect(Service.java:233)
at javax.mail.Service.connect(Service.java:134)
at javax.mail.Service.connect(Service.java:86)
at myplugin.actions.MailFetcher.listMails(MailFetcher.java:58)
at myplugin.actions.MailFetcher.listMails(MailFetcher.java:40)
at myplugin.actions.MailFetcher.main(MailFetcher.java:131)
这样的错误
nested exception is:
java.net.SocketException: Connection reset
at com.sun.mail.pop3.POP3Store.protocolConnect(POP3Store.java:106)
at javax.mail.Service.connect(Service.java:233)
at javax.mail.Service.connect(Service.java:134)
at javax.mail.Service.connect(Service.java:86)
at myplugin.actions.MailFetcher.listMails(MailFetcher.java:58)
at myplugin.actions.MailFetcher.listMails(MailFetcher.java:40)
at myplugin.actions.MailFetcher.main(MailFetcher.java:131)
这样的错误
相关推荐
基于Javamail的邮件收发系统.zip基于Javamail的邮件收发系统.zip基于Javamail的邮件收发系统.zip基于Javamail的邮件收发系统.zip基于Javamail的邮件收发系统.zip基于Javamail的邮件收发系统.zip基于Javamail的邮件...
JavaMail 是一个强大的开源库,用于在Java应用程序中处理电子邮件。它支持多种协议,包括POP3、IMAP和SMTP,这些协议分别用于接收、检索和发送邮件。在使用JavaMail时,了解如何进行加密和非加密通信对于确保数据...
总的来说,JavaMail 是一个强大的工具,不仅能够发送邮件,还能处理复杂的邮件操作,如邮件搜索、过滤和管理。通过学习和使用 JavaMail,开发者可以轻松地在自己的应用中实现邮件通信,提升用户体验。记得在实际应用...
使用 JavaMail 代发邮件 使用 JavaMail 库可以轻松地在 Java 应用程序中发送电子邮件。JavaMail 是一个 Java API,用于在 Java 应用程序中发送和接收电子邮件。它提供了一个抽象层,允许开发者使用不同的电子邮件...
### JavaMail收发Gmail邮件知识点详解 #### 一、JavaMail简介 JavaMail API是Java平台中的一个标准扩展库,用于发送、接收以及管理电子邮件。它提供了丰富的接口来实现邮件的各种操作,如构建复杂的MIME消息、处理...
在本文中,我们将深入探讨如何使用 JavaMail 收取邮件,包括了解 POP3 和 IMAP 协议以及如何通过 JavaMail API 实现邮件的接收。 首先,我们需要知道发送邮件通常使用 SMTP(简单邮件传输协议),而接收邮件则涉及...
JavaMail邮件收发实例_JavaMail_API JavaMail邮件收发实例_JavaMail_API JavaMail邮件收发实例_JavaMail_API JavaMail邮件收发实例_JavaMail_API JavaMail邮件收发实例_JavaMail_API
通过这些核心概念和方法,开发者可以利用JavaMail在各种应用场景中实现功能丰富的邮件服务,无论是简单的日志报告,还是复杂的业务通知,都能轻松应对。在实际开发中,可以根据项目需求对JavaMail的功能进行扩展和...
**基于Javamail的邮件收发系统** JavaMail是一个开放源码的API,它为Java程序员提供了一套全面的接口来处理电子邮件。这个系统的设计目的是使得开发者能够方便地发送和接收邮件,包括附件、HTML内容以及MIME多部分...
在IT行业中,电子邮件的收发是一项基础且重要的功能,尤其对于开发者来说,了解如何通过编程方式实现邮件的发送和接收是非常必要的。在这个例子中,我们将深入探讨如何利用James服务器和JavaMail API来实现这一目标...
JavaMail 是一个强大的开源类库,用于在Java应用程序中实现电子邮件的发送和接收。它提供了对SMTP(简单邮件传输协议)、POP3(邮局协议)和IMAP(因特网消息访问协议)等标准的全面支持,使得开发者可以方便地进行...
在JavaMail中,我们可以利用其API来实现邮件的收发功能,包括处理附件。下面我们将详细探讨如何使用JavaMail API实现邮件的收取,特别是如何通过POP3和IMAP协议获取邮件信息。 首先,确保你的项目中已经引入了...
在预测阶段,新邮件将根据这些特征的出现情况被分类为垃圾邮件或非垃圾邮件。 文件列表中,“bayesianspam”可能是用来存储和处理贝叶斯算法训练数据和模型的模块;“javamail”是JavaMail的核心库,包含了实现邮件...
- **原因分析**:首先需要检查邮件是否被误判为垃圾邮件并进入垃圾邮件箱。其次,需要关注服务器端的日志记录,了解邮件发送的具体情况。 - **解决方法**:确保邮件地址正确无误;检查邮件服务提供商的设置,确认...
在实际开发中,使用 JavaMail 进行邮件收发的步骤大致如下: 1. 创建 Session 对象,配置邮件服务器的相关信息。 2. 使用 Session 创建 Store 对象,连接到邮件服务器。 3. 打开 Folder,读取或管理邮件。 4. 如果...
javamail收发邮件(带附件,正文带图).doc
回执邮件是邮件服务中的一项功能,它允许发件人在发送邮件后得知收件人是否已阅读邮件。本资料包主要涵盖了使用 JavaMail 实现回执邮件以及相关邮件操作的知识点。 首先,发送带有回执请求的邮件是通过设置邮件头...
基于Javamail的邮件收发系统是一款简单、方便、快捷的邮件系统。它能实现邮件的接收与发送,并能完成附件的传输,具有较好的人机交互性,易于使用。 开发环境:JDK1.6 + Windows平台 开发技术:Javamail 开发工具:...
《基于Javamail的邮件收发系统》项目是一份全面的资料集合,包含了系统实现、相关文档、开题报告、任务书、外文翻译、文献综述以及答辩PPT等重要组成部分,旨在帮助读者深入理解和掌握使用JavaMail进行邮件收发的...
基于JavaMail的电子邮件收发系统旨在为用户提供便捷、高效的电子邮件服务。随着互联网的普及,电子邮件已经成为了人们日常沟通的重要工具,无论是个人用户还是企业,都离不开它的支持。本系统的设计目标是创建一个...