现在我已经下载了所有消息,并将它们存储到
Message[] temp;
如何获取每条消息的附件列表
Listattachments;
注意:请不要使用第三方库,只需JavaMail.
没有异常处理,但是这里:
Listattachments = new ArrayList (); for (Message message : temp) { Multipart multipart = (Multipart) message.getContent(); for (int i = 0; i < multipart.getCount(); i++) { BodyPart bodyPart = multipart.getBodyPart(i); if(!Part.ATTACHMENT.equalsIgnoreCase(bodyPart.getDisposition()) && StringUtils.isBlank(bodyPart.getFileName())) { continue; // dealing with attachments only } InputStream is = bodyPart.getInputStream(); // -- EDIT -- SECURITY ISSUE -- // do not do this in production code -- a malicious email can easily contain this filename: "../etc/passwd", or any other path: They can overwrite _ANY_ file on the system that this code has write access to! // File f = new File("/tmp/" + bodyPart.getFileName()); FileOutputStream fos = new FileOutputStream(f); byte[] buf = new byte[4096]; int bytesRead; while((bytesRead = is.read(buf))!=-1) { fos.write(buf, 0, bytesRead); } fos.close(); attachments.add(f); } }
问题很老,但也许会对某人有所帮助.我想扩展David Rabinowitz的答案.
if(!Part.ATTACHMENT.equalsIgnoreCase(bodyPart.getDisposition()))
不应该按照您的预期返回所有内容,因为您可以拥有邮件,其中混合部分没有定义的处置.
----boundary_328630_1e15ac03-e817-4763-af99-d4b23cfdb600 Content-Type: application/octet-stream; name="00000000009661222736_236225959_20130731-7.txt" Content-Transfer-Encoding: base64
所以在这种情况下,您还可以检查文件名.像这样:
if (!Part.ATTACHMENT.equalsIgnoreCase(part.getDisposition()) && StringUtils.isBlank(part.getFileName())) {...}
编辑
使用上面描述的条件有完整的工作代码.因为每个部分都可以封装另一个部分并且附件应该嵌套,所以递归用于遍历所有部分
public ListgetAttachments(Message message) throws Exception { Object content = message.getContent(); if (content instanceof String) return null; if (content instanceof Multipart) { Multipart multipart = (Multipart) content; List result = new ArrayList (); for (int i = 0; i < multipart.getCount(); i++) { result.addAll(getAttachments(multipart.getBodyPart(i))); } return result; } return null; } private List getAttachments(BodyPart part) throws Exception { List result = new ArrayList (); Object content = part.getContent(); if (content instanceof InputStream || content instanceof String) { if (Part.ATTACHMENT.equalsIgnoreCase(part.getDisposition()) || StringUtils.isNotBlank(part.getFileName())) { result.add(part.getInputStream()); return result; } else { return new ArrayList (); } } if (content instanceof Multipart) { Multipart multipart = (Multipart) content; for (int i = 0; i < multipart.getCount(); i++) { BodyPart bodyPart = multipart.getBodyPart(i); result.addAll(getAttachments(bodyPart)); } } return result; }
保存附件文件的代码可节省一些时间:
与javax邮件版本1.4及之后,你可以说
// SECURITY LEAK - do not do this! Do not trust the 'getFileName' input. Imagine it is: "../etc/passwd", for example. // bodyPart.saveFile("/tmp/" + bodyPart.getFileName());
代替
InputStream is = bodyPart.getInputStream(); File f = new File("/tmp/" + bodyPart.getFileName()); FileOutputStream fos = new FileOutputStream(f); byte[] buf = new byte[4096]; int bytesRead; while((bytesRead = is.read(buf))!=-1) { fos.write(buf, 0, bytesRead); } fos.close();