轉載 http://duanmumu.blog.163.com/blog/static/1911133502012715104016481/html
// TODO Auto-generated method stub
Properties props =newProperties();
Session session =Session.getInstance(props);
Message message =newMimeMessage(session);
// message.setFrom(new InternetAddress("duan_lonshan@126.com"));
Multipart msgmultipart =newMimeMultipart("mixed");//mixed表示混合性,這裏由於有文本,附件,因此是混合的。
message.setContent(msgmultipart);
//添加附件圖片
BodyPart picpart =newMimeBodyPart();
msgmultipart.addBodyPart(picpart);
DataSource ds1 =newFileDataSource("e:\\login.jpg");
DataHandler dh1 =newDataHandler(ds1);
picpart.setDataHandler(dh1);
picpart.setFileName("login.jpg");
//添加附件文件
BodyPart mg =newMimeBodyPart();
msgmultipart.addBodyPart(mg);
DataSource ds2 =newFileDataSource("e:\\test.xls");
DataHandler dh2 =newDataHandler(ds2);
mg.setDataHandler(dh2);
mg.setFileName("mess.xls");
//添加文本內容
BodyPart msgpart =newMimeBodyPart();
msgmultipart.addBodyPart(msgpart);
Multipart bodyMultipart =newMimeMultipart("related");//這裏的圖片和文本是在一塊兒顯示的因此他們是關係型的。
msgpart.setContent(bodyMultipart);
BodyPart jpgpart =newMimeBodyPart();
BodyPart htmlpart =newMimeBodyPart();
bodyMultipart.addBodyPart(jpgpart);
bodyMultipart.addBodyPart(htmlpart);
//文本中添加圖片
DataSource ds =newFileDataSource("e:\\background.jpg");
DataHandler jpgdh =newDataHandler(ds);
jpgpart.setDataHandler(jpgdh);
jpgpart.setHeader("Content-Location","http://www.test.com/bg.jpg");//這裏的地址就是跟img標籤中的地址相同。而後就能夠在文本中直接顯示出來圖片。這裏的Content-Location固定的,
htmlpart.setContent("this is the first email <img src='http://www.test.com/bg.jpg'>","text/html;charset=gb2312");
message.saveChanges();//保存數據
OutputStream os =newFileOutputStream("e:\\dome3.eml");//寫出到的文件
message.writeTo(os);session