JavaMail 正文和邮件主题乱码解决(转)

编码<o:p></o:p>
邮件头<o:p></o:p>
邮件头 ( 参见 RFC822 RFC2047) 只能包含 US-ASCII 字符。邮件头中任何包含非 US-ASCII 字符的部分必须进行编码,使其只包含 US-ASCII 字符。所以使用 java mail 发送中文邮件必须经过编码,否则别人收到你的邮件只能是乱码一堆。不过使用 java mail 包的解决方法很简单,用它自带的 MimeUtility 工具中 encode 开头的方法(如 encodeText )对中文信息进行编码就可以了。
<o:p> </o:p>          例子:
         MimeMessage mimeMsg = new MimeMessage(mailSession);
// javamail 决定用什么方式来编码 ,编码内容的字符集是系统字符集
mimeMsg.setSubject( MimeUtility.encodeText( Subject) );
// 使用指定的 base64 方式编码 , 并指定编码内容的字符集是 gb2312
mimeMsg.setSubject( MimeUtility.encodeText( Subject,”gb2312”,”B”)); //B base64 方式
<o:p></o:p>
        
通常对邮件头的编码方式有 2 , 一种是 base64 方式编码,一种是 QP quoted-printable )方式编码, javamail 根据具体情况来选择编码方式。
         如“ txt 测试”编码后内容如下:
=?GBK?Q?Txt=B2=E2=CA=D4
         里面有个 =?GBK?Q? GBK 表示的是内容的字符集, ?Q? 表示的是以 QP 方式编码的( ?B? 则是以 base64 方式编码),后面紧跟的才是编码后的中文字符。所以用 MimeUtility 工具编码后的信息里包含了编码方式的信息。
<o:p> </o:p>
邮件正文<o:p></o:p>
邮件的正文也要进行编码,但它不能用 MimeUtility 里的方法来编码。邮件正文的编码方式的信息是要放在 Content-Transfer-Encoding 这个邮件头参数中的,而 MimeUtility 里面的方法是将编码方式的信息放在编码后的正文内容中。所以如果你对正文也用 MimeUtility 进行处理,那么其他邮件程序就不会正常显示你编码的邮件,因为其他邮件软件如 outlook,foxmail 只会根据 Content-Transfer-Encoding 这个里面的信息来对邮件正文进行解码。
其实,邮件正文部分的编码 javamail 已经自动帮你做了,当你发送邮件的时候,它会自己决定编码方式,并把编码方式的信息放入 Content-Transfer-Encoding 这个邮件头参数中,然后再发送。所以你所要做的就是直接把邮件正文的内容放入邮件中就可以了。
对邮件正文的编码方式比较多,包括了 base64 QP 方式,还有一些如 7bit,8bit 等等,因为 javamail 自动为邮件正文编码,所以我就不一一祥叙了。
<o:p></o:p>
例子:
// 处理邮件正文
MimeBodyPart mbp=new MimeBodyPart();
if ( ContentType == null || ContentType.equals("")) // ContentType 为编码类型,如 GBK
mbp.setText( Content ); // JavaMail 来决定编码
else
mbp.setContent( Content, ContentType); // 指定编码格式
解码<o:p></o:p>
邮件头<o:p></o:p>
javamail 包中的 MimeUtility 工具中也提供了对邮件信息解码的方法,都是以 decode 开头的一些方法 ( decodeText)
<o:p> </o:p>
例子:
String Subject = mimemsg.getSubject();
String ChSubject = MimeUtility.decodeText(Subject);
<o:p> </o:p>
对于 base64 QP 编码后信息, decode* 方法能将他们正确的解码,但是,如果指定的字符集不对,那么 javamail 就会出现错误,不能正确地将其解码。
如有的邮件系统将” txt 测试”编码后如下:
=?x-unkown?Q?Txt=B2=E2=CA=D4
这里指定的字符集是 x-unknown ,是非明确的字符集, javamail 就不能正确的处理了,但是”测试”这两个中文字还是按照 gbk 字符集编码的,所以你可以手工的将编码方式信息改正确,再用 decode* 方法来解码。
<o:p>         </o:p> 例子:
if ( str.indexOf("=?x-unknown?") >=0 ){
str = str.replaceAll("x-unknown","gbk"); // 将编码方式的信息由 x-unkown 改为 gbk
try{
str = MimeUtility.decodeText( str ); // 再重新解码
} catch( Exception e1){
return str ;
}
         }
<o:p> </o:p>
         邮件正文<o:p></o:p>
decode* 方法都是根据在编码信息中包含的编码方式的信息来解码,所以 decode* 方法对邮件正文解码是无效的,因为邮件正文中不包含编码方式的信息。
同编码一样,邮件正文的解码也是由 javamail 做了。 Javamail 根据 Content-Transfer-Encoding 里的信息,来对邮件的正文解码。
客户程序从 javamail 取得的正文内容字符集为 iso-8859-1, 所以还要将字符集转换一下。
例子:
String CorrectContent = new String( Content.getbytes(“iso-8859-1”),”gb2312”);
CorrentContent 为正确的邮件正文了
 
 

你可能感兴趣的:(邮件,乱码,主题,javamail,正文)