Introducció
Treballar amb fitxers Outlook MSG en C++ ha requerit històricament automatització COM només per a Windows
o biblioteques de tercers pesades amb llicències restrictives. Aspose.Email FOSS per a C++
canvia això: és una biblioteca pura C++17 sense dependències externes, sense COM i sense
codi específic de plataforma. Es compila de manera idèntica a Linux, macOS i Windows.
La biblioteca es publica sota la llicència MIT i es distribueix com a codi font a través de GitHub. La integreu clonant el repositori i afegint-lo com a subdirectori de CMake — no cal registrar cap gestor de paquets, i no cal que els binaris estiguin precompilats.
Aquesta publicació recorre el flux de treball principal: llegir un fitxer MSG existent, inspeccionar-ne les propietats, crear un missatge nou de manera programàtica i fer un viatge d’anada i torn entre els formats MSG i EML.
Característiques clau
Llegir fitxers MSG existents
Utilitzeu msg_reader per obrir un fitxer .msg i msg_document per accedir al seu contingut estructurat.
Ambdues classes es troben a l’espai de noms 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é té una sobrecàrrega from_stream per llegir des d’un std::istream, que és útil en contextos del costat del servidor o de la canalització on els fitxers no es troben al disc.
Crear missatges programàticament
mapi_message::create genera un nou missatge en memòria amb un assumpte i un cos. A continuació, podeu establir els detalls del remitent, afegir destinataris i adjuntar càrregues útils binàries o de text abans de desar.
#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"));
Convertir MSG a EML
mapi_message admet la conversió directa de MSG a EML mitjançant el mètode save_to_eml.
La sortida EML compleix amb RFC 5322 (MIME), fent-la compatible amb qualsevol client de correu
estàndard o pipeline de processament.
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();
Carrega des de EML
La direcció inversa és igualment senzilla: load_from_eml llegeix un fitxer EML i produeix un mapi_message en memòria, que després es pot desar de nou a MSG.
auto from_eml = aef::msg::mapi_message::load_from_eml(
std::filesystem::path("message.eml"));
from_eml.save(std::filesystem::path("restored.msg"));
Accés de baix nivell CFB
Per a casos d’ús avançats — com ara la lectura de propietats MAPI en brut que no exposa l’API de nivell alt — cfb_reader ofereix accés directe al contenidor Compound File Binary que sustenta el format 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();
Inici ràpid
Pas 1 — Clona i afegeix com a subdirectori
git clone https://github.com/aspose-email-foss/Aspose.Email-FOSS-for-Cpp.git
Al vostre projecte 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)
Pas 2 — Incloure i utilitzar
#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";
}
Pas 3 — Construcció
cmake -B build -DCMAKE_BUILD_TYPE=Release
cmake --build build
Formats compatibles
| Format | Extensió | Lectura | Escriptura |
|---|---|---|---|
| MSG (Outlook Message) | .msg | ✓ | ✓ |
| EML (RFC 5322 / MIME) | .eml | ✓ | ✓ |
| CFB (Compound File Binary) | .msg, .cfb | ✓ | ✓ |
Codi obert i llicències
Aspose.Email FOSS per a C++ es publica sota la llicència MIT. El codi font complet està disponible a GitHub a aspose-email-foss/Aspose.Email-FOSS-for-Cpp. L’ús comercial està permès sense royalties. La biblioteca no té dependències d’execució més enllà d’un compilador C++17 i CMake 3.26 o posterior.