Introdução
Trabalhar com arquivos Outlook MSG em C++ historicamente exigiu automação COM apenas para Windows
ou bibliotecas de terceiros pesadas com licenças restritivas. Aspose.Email FOSS para C++
muda isso: é uma biblioteca pura C++17 sem dependências externas, sem COM, e sem
código específico de plataforma. Ela compila de forma idêntica no Linux, macOS e Windows.
A biblioteca é lançada sob a licença MIT e distribuída como código‑fonte via GitHub. Você a integra clonando o repositório e adicionando‑o como um subdiretório CMake — não é necessário registrar em gerenciador de pacotes, e nenhum binário precisa ser pré‑compilado.
Esta postagem percorre o fluxo de trabalho principal: ler um arquivo MSG existente, inspecionar suas propriedades, criar uma nova mensagem programaticamente e fazer a conversão de ida e volta entre os formatos MSG e EML.
Recursos Principais
Ler arquivos MSG existentes
Use msg_reader para abrir um arquivo .msg e msg_document para acessar seu conteúdo estruturado.
Ambas as classes estão no namespace aspose::email::foss::msg.
#include "aspose/email/foss/msg/msg_reader.hpp"
#include "aspose/email/foss/msg/msg_document.hpp"
#include <filesystem>
namespace aef = aspose::email::foss;
auto reader = aef::msg::msg_reader::from_file(std::filesystem::path("message.msg"));
auto document = aef::msg::msg_document::from_reader(reader);
msg_reader também possui uma sobrecarga from_stream para leitura a partir de um std::istream, que é útil em contextos de servidor ou de pipeline onde os arquivos não estão presentes no disco.
Criar Mensagens Programaticamente
mapi_message::create produz uma nova mensagem em memória com assunto e corpo.
Você pode então definir os detalhes do remetente, adicionar destinatários e anexar cargas úteis binárias ou de texto antes de salvar.
#include "aspose/email/foss/msg/mapi_message.hpp"
namespace aef = aspose::email::foss;
auto msg = aef::msg::mapi_message::create(
"Quarterly status update",
"Hello team,\n\nPlease find the rollout summary attached.\n\nRegards");
msg.set_sender_name("Build Agent");
msg.set_sender_email_address("build.agent@example.com");
msg.add_recipient("alice@example.com", "Alice Example");
msg.save(std::filesystem::path("output.msg"));
Converter MSG para EML
mapi_message suporta conversão direta de MSG para EML através do método save_to_eml.
A saída EML está em conformidade com o RFC 5322 (MIME), tornando‑a compatível com qualquer cliente de e‑mail padrão
ou pipeline de processamento.
auto loaded = aef::msg::mapi_message::from_file(
std::filesystem::path("message.msg"), /*strict=*/false);
// Save as EML to a file
loaded.save_to_eml(std::filesystem::path("message.eml"));
// Or capture as bytes
std::vector<std::uint8_t> eml_bytes = loaded.save_to_eml();
Carregar a partir de EML
A direção inversa é igualmente simples: load_from_eml lê um arquivo EML e produz um mapi_message na memória, que pode então ser salvo de volta para MSG.
auto from_eml = aef::msg::mapi_message::load_from_eml(
std::filesystem::path("message.eml"));
from_eml.save(std::filesystem::path("restored.msg"));
Acesso CFB de baixo nível
Para casos de uso avançados — como ler propriedades MAPI brutas que não são expostas pela API de alto nível — cfb_reader fornece acesso direto ao contêiner Compound File Binary que sustenta o formato MSG.
#include "aspose/email/foss/cfb/cfb_reader.hpp"
namespace aef = aspose::email::foss;
auto cfb = aef::cfb::cfb_reader::from_file(std::filesystem::path("message.msg"));
auto storage_ids = cfb.storage_ids();
auto stream_ids = cfb.stream_ids();
Início Rápido
Etapa 1 — Clonar e Adicionar como Subdiretório
git clone https://github.com/aspose-email-foss/Aspose.Email-FOSS-for-Cpp.git
No seu projeto CMakeLists.txt:
cmake_minimum_required(VERSION 3.26)
project(my_project)
add_subdirectory(Aspose.Email-FOSS-for-Cpp)
add_executable(my_app main.cpp)
target_link_libraries(my_app PRIVATE AsposeEmailFoss::AsposeEmailFoss)
Etapa 2 — Incluir e Usar
#include <iostream>
#include "aspose/email/foss/msg/mapi_message.hpp"
namespace aef = aspose::email::foss;
int main()
{
// Create a message
auto msg = aef::msg::mapi_message::create("Hello from C++", "Body text here");
msg.save(std::filesystem::path("hello.msg"));
// Round-trip to EML
auto loaded = aef::msg::mapi_message::from_file(
std::filesystem::path("hello.msg"), false);
loaded.save_to_eml(std::filesystem::path("hello.eml"));
std::cout << "Done\n";
}
Etapa 3 — Compilar
cmake -B build -DCMAKE_BUILD_TYPE=Release
cmake --build build
Formatos suportados
| Formato | Extensão | Ler | Gravar |
|---|---|---|---|
| MSG (Outlook Message) | .msg | ✓ | ✓ |
| EML (RFC 5322 / MIME) | .eml | ✓ | ✓ |
| CFB (Compound File Binary) | .msg, .cfb | ✓ | ✓ |
Código Aberto e Licenciamento
Aspose.Email FOSS for C++ é lançado sob a licença MIT. O código‑fonte completo está disponível no GitHub em aspose-email-foss/Aspose.Email-FOSS-for-Cpp. O uso comercial é permitido sem royalties. A biblioteca não tem dependências de tempo de execução além de um compilador C++17 e CMake 3.26 ou posterior.