Создание и сохранение файлов MSG

Обратите внимание, что в статусе черновика Outlook не отображает информацию об отправителе, присвоенную MapiMessage. Если необходимо отобразить информацию об отправителе, следует установить флаг MSGFLAG_READ.

  • Aspose.Email поддерживает создание файлов Outlook (MSG). Эта статья объясняет, как:
  • Создать сообщения MSG.
  • Создать сообщения MSG со вложениями.
  • Создать сообщение MSG с телом RTF.
  • Сохранить сообщение как черновик.

Работа со сжатием тела.

Этот MailMessage Создание и сохранение сообщений Outlook сохранением класс имеет MailMessage классом, задайте свойства, такие как from, to, subject и body. Метод, который может сохранять файлы Outlook MSG на диск или в поток. Ниже приведён фрагмент кода, создающий экземпляр сохранением метод принимает имя файла в качестве аргумента. Кроме того, сообщения Outlook могут быть созданы с сжатого тела RTF используя MapiConversionOptions.

  1. Создайте новый экземпляр MailMessage и задаёт свойства From, To, Subject и Body.
  2. Вызвать MapiMessage класс из MailMessage принимает объект класса MailMessage тип. Метод из MailMessage метод преобразует MailMessage в MapiMessage (MSG).
  3. Вызвать MapiMessage.save метод для сохранения файла MSG.
// For complete examples and data files, please go to https://github.com/aspose-email/Aspose.Email-for-Java
// The path to the File directory.
String dataDir = "outlook/";

// Create an instance of the MailMessage class
MailMessage mailMsg = new MailMessage();

// Set from, to, subject and body properties
mailMsg.setFrom(MailAddress.to_MailAddress("sender@domain.com"));
mailMsg.setTo(MailAddressCollection.to_MailAddressCollection("receiver@domain.com"));
mailMsg.setSubject("This is test message");
mailMsg.setBody("This is test body");

// Create an instance of the MapiMessage class and pass MailMessage as argument
MapiMessage outlookMsg = MapiMessage.fromMailMessage(mailMsg);

// Save the message (MSG) file
String strMsgFile = "CreatingAndSavingOutlookMessages_out.msg";
outlookMsg.save(dataDir + strMsgFile);

Создание файлов MSG со вложениями

В приведённом выше примере, мы создали простой файл MSG. Aspose.Email также поддерживает сохранение файлов сообщений с вложениями. Всё, что нужно сделать — добавить вложения к MailMessage экземпляр. Добавляйте вложения, вызывая метод addItem у MailMessage.Attachments коллекцию.

// For complete examples and data files, please go to https://github.com/aspose-email/Aspose.Email-for-Java
// The path to the File directory.
String dataDir = "outlook/";

String[] files = new String[2];
files[0] = "attachment.doc";
files[1] = "attachment.png";

// Create an instance of the MailMessage class
MailMessage mailMsg = new MailMessage();

// Set from, to, subject and body properties
mailMsg.setFrom(MailAddress.to_MailAddress("sender@domain.com"));
mailMsg.setTo(MailAddressCollection.to_MailAddressCollection("receiver@domain.com"));
mailMsg.setSubject("This is test message");
mailMsg.setBody("This is test body");

// Add the attachments
for (String strFileName : files)
{
    mailMsg.getAttachments().addItem(new Attachment(strFileName));
}

// Create an instance of MapiMessage class and pass MailMessage as argument
MapiMessage outlookMsg = MapiMessage.fromMailMessage(mailMsg);
String strMsgFile = "CreateMessagesWithAttachments.msg";
outlookMsg.save(dataDir + strMsgFile);

Создание файлов MSG с телом RTF

Вы также можете создавать файлы Outlook Message (MSG) с телом в формате RTF с помощью Aspose.Email. Тело RTF поддерживает текстовое форматирование. Создайте его, задав MailMessage.HtmlBody свойство. При конвертации MailMessage в экземпляр в MapiMessage в данном случае HTML‑тело преобразуется в RTF. Таким образом форматирование тела сообщения сохраняется.

В следующем примере создаётся файл MSG с телом в формате RTF. В HTML‑теле присутствует один заголовок, полужирное и подчёркнутое форматирование. Это форматирование сохраняется при конвертации HTML в RTF.

// For complete examples and data files, please go to https://github.com/aspose-email/Aspose.Email-for-Java
// The path to the File directory.
String dataDir = "outlook/";

// Create an instance of the MailMessage class
MailMessage mailMsg = new MailMessage();

// Set from, to, subject and body properties
mailMsg.setFrom(MailAddress.to_MailAddress("sender@domain.com"));
mailMsg.setTo(MailAddressCollection.to_MailAddressCollection("receiver@domain.com"));
mailMsg.setSubject("This is test message");
mailMsg.setHtmlBody("<h3>rtf example</h3><p>creating an <b><u>outlook message (msg)</u></b> file using Aspose.Email.</p>");

MapiMessage outlookMsg = MapiMessage.fromMailMessage(mailMsg);
outlookMsg.save(dataDir + "CreatingMSGFilesWithRTFBody_out.msg");

Сохранение сообщения в статусе черновика

Электронные письма сохраняются как черновики, когда пользователь начал их редактировать, но хочет вернуться к ним позже, чтобы завершить. Aspose.Email поддерживает сохранение сообщений электронной почты в статусе черновика путем установки флага сообщения. Ниже приведён пример кода, который сохраняет сообщение Outlook (MSG) как черновик.

// For complete examples and data files, please go to https://github.com/aspose-email/Aspose.Email-for-Java
// The path to the File directory.
String dataDir = "outlook/";

// Change properties of an existing MSG file
String strExistingMsg = "message.msg";

// Load the existing file in MailMessage and Change the properties
MailMessage msg = MailMessage.load(dataDir + strExistingMsg, new MsgLoadOptions());
msg.setSubject(msg.getSubject() + " NEW SUBJECT (updated by Aspose.Email)");
msg.setHtmlBody(msg.getHtmlBody() + " NEW BODY (udpated by Aspose.Email)");

// Create an instance of type MapiMessage from MailMessage, Set message flag to un-sent (draft status) and Save it
MapiMessage mapiMsg = MapiMessage.fromMailMessage(msg);
mapiMsg.setMessageFlags(MapiMessageFlags.MSGFLAG_UNSENT);
mapiMsg.save(dataDir + "SavingMessageInDraftStatus_out.msg");

Работа с вложениями сообщений

Последствия сжатия тела

// For complete examples and data files, please go to https://github.com/aspose-email/Aspose.Email-for-Java
String fileName = "outlook/test.msg";

MailMessage message = MailMessage.load(fileName);
MapiConversionOptions options = new MapiConversionOptions();
options.setUseBodyCompression(true);
MapiMessage ae_mapi = MapiMessage.fromMailMessage(message, options);