Úvod
Práce se soubory Outlook MSG v C++ historicky vyžadovala pouze Windows COM automatizaci
nebo těžkopádné knihovny třetích stran s restriktivními licencemi. Aspose.Email FOSS pro C++
to mění: jedná se o čistou knihovnu C++17 bez externích závislostí, bez COM a bez
kódu specifického pro platformu. Kompiluje se identicky na Linuxu, macOS a Windows.
Knihovna je vydána pod licencí MIT a distribuována jako zdrojový kód přes GitHub. Integrujete ji klonováním repozitáře a přidáním jako podadresář CMake — není vyžadována registrace u správce balíčků a není nutné předem sestavovat binární soubory.
Tento příspěvek provádí krok za krokem základní pracovní postup: čtení existujícího souboru MSG, kontrolu jeho vlastností, programové vytvoření nové zprávy a zpětnou konverzi mezi formáty MSG a EML.
Klíčové vlastnosti
Číst existující soubory MSG
Použijte msg_reader k otevření souboru .msg a msg_document k přístupu k jeho strukturovanému obsahu.
Obě třídy se nacházejí v jmenném prostoru 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 také má from_stream přetížení pro čtení z std::istream, což je užitečné v server‑side nebo pipeline kontextech, kde soubory nejsou na disku.
Vytvářet zprávy programově
mapi_message::create vytvoří novou zprávu v paměti s předmětem a tělem.
Můžete pak nastavit údaje o odesílateli, přidat příjemce a připojit binární nebo textové přílohy před uložením.
#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"));
Převést MSG na EML
mapi_message podporuje přímou konverzi MSG na EML pomocí metody save_to_eml.
Výstup EML odpovídá RFC 5322 (MIME), což ho činí kompatibilním s jakýmkoli standardním poštovním
klientem nebo zpracovatelským řetězcem.
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();
Načíst z EML
Obrácený směr je stejně jednoduchý: load_from_eml načte soubor EML a vytvoří mapi_message v paměti, který pak může být uložen zpět do MSG.
auto from_eml = aef::msg::mapi_message::load_from_eml(
std::filesystem::path("message.eml"));
from_eml.save(std::filesystem::path("restored.msg"));
Nízkourovňový přístup k CFB
Pro pokročilé případy použití — například čtení surových MAPI vlastností, které nejsou zpřístupněny vysokou úrovní API — cfb_reader poskytuje přímý přístup k binárnímu kontejneru Compound File, který je základem formátu 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();
Rychlý start
Krok 1 — Klonovat a přidat jako podadresář
git clone https://github.com/aspose-email-foss/Aspose.Email-FOSS-for-Cpp.git
Ve vašem projektu 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)
Krok 2 — Zahrnout a použít
#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";
}
Krok 3 — Sestavení
cmake -B build -DCMAKE_BUILD_TYPE=Release
cmake --build build
Podporované formáty
| Formát | Přípona | Číst | Zapisovat |
|---|---|---|---|
| MSG (Outlook Message) | .msg | ✓ | ✓ |
| EML (RFC 5322 / MIME) | .eml | ✓ | ✓ |
| CFB (Compound File Binary) | .msg, .cfb | ✓ | ✓ |
Open Source a licencování
Aspose.Email FOSS for C++ je vydán pod licencí MIT. Plný zdrojový kód je k dispozici na GitHubu na adrese aspose-email-foss/Aspose.Email-FOSS-for-Cpp. Komerní použití je povoleno bez licenčních poplatků. Knihovna nemá žádné runtime závislosti kromě kompilátoru C++17 a CMake 3.26 nebo novějšího.