[SHOT]ClassCastException: com.sun.mail.util.BASE64DecoderStream

本文分析了一种特定情况下Java邮件解析失败的问题,错误出现在尝试将BASE64DecoderStream转换为Multipart类型时。通过对比正常邮件与问题邮件的内容,发现后者缺少了必要的boundary设置且未包含正文部分。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

帮忙查了个Email接收失败的问题,Google和Baidu都没搜到,大概太简单了吧。。。

 

报错情况:java.lang.ClassCastException: com.sun.mail.util.BASE64DecoderStream incompatible with javax.mail.Multipart at ……

 

代码:Multipart mp = (Multipart) mpart.getContent();

 

以上代码是解析邮件附件的标准写法,多数邮件处理也正常,问题邮件在Outlook等客户端里也能正常处理,直接取mail服务器上的备份邮件,发现问题如下:

 

问题邮件: ……

Date: Tue, 24 Mar 2015 11:30:18 GMT From: xxx@yyy.com

To: xxx@yyy.net.cn Cc: bbb@ccc.com

Message-ID:

Subject: BLABLABLALALALA

MIME-Version: 1.0

Content-Type: application/EDIFACT; name=0798114O.96608468.608458886.1

Content-Transfer-Encoding: base64

Content-Disposition: attachment; filename=0798114O.96608468.608458886.1

下面就是base64编码的附件报文

 

正常处理的邮件

……

From: xxx@yyy.com

Date: Mon, 9 Feb 2015 11:01:22 +0800

X-MIMETrack: Serialize by Router on NSHAS01/S/AS_ at 02/09/2015 11:01:23 AM

Content-Type: multipart/mixed; boundary="=_mixed 00109A2B48257DE7_="

……

=

--=_mixed 00109A2B48257DE7_=

Content-Type: application/octet-stream; name="嘻嘻嘻.pdf"

Content-Disposition: attachment; filename="嘻嘻嘻.pdf"

Content-Transfer-Encoding: base64

……

对比发现,问题邮件没有正文,没有boundary设置,MIME 1.0的规范还没仔细研究过。可能也是程序外发的mail,后续对接收程序做改造,增加容错机制【待续】

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值