Test in einer Live-Umgebung
Test in der Produktion ohne Wasserzeichen.
Funktioniert überall, wo Sie es brauchen.
PDF (Portable Document Format) dateien werden häufig für die gemeinsame Nutzung und Aufbewahrung von Dokumenten in einem einheitlichen Format über verschiedene Plattformen hinweg verwendet. In diesem Artikel wird gezeigt, wie man mit der wkhtmltopdf-Bibliothek PDF-Dateien in C++ erzeugt. Es ist ein Open-Source-Befehlszeilen-Tool, das zur Konvertierung von HTML-Inhalten in PDF-Dateien verwendet wird. Indem wir die Leistungsfähigkeit dieser Bibliothek nutzen, können wir in unseren C++-Anwendungen programmatisch PDF-Dokumente aus HTML-Inhalten erstellen.
wkhtmltopdf ist ein Open-Source-Befehlszeilenwerkzeug und eine Rendering-Engine, die HTML-Webseiten oder HTML-Inhalte in PDF-Dokumente umwandelt. Es nutzt die WebKit-Rendering-Engine, um HTML, CSS und JavaScript zu analysieren und zu rendern, und erzeugt dann eine PDF-Datei auf der Grundlage des gerenderten Inhalts.
"wkhtmltopdf C++ Bibliothek" (auch bekannt als "wkhtmltopdf C API"). Diese Bibliothek bietet eine C++-Schnittstelle für das Kommandozeilen-Tool "wkhtmltopdf", mit dem Sie PDF-Dateien aus HTML-Inhalten direkt in Ihren C++-Anwendungen erstellen können. Lassen Sie uns den schrittweisen Prozess der HTML-zu-PDF-Konvertierung in C++ unter Verwendung der Wkhtmltopdf-Bibliothek nachvollziehen.
Um PDF-Dateien in C++ zu erstellen, müssen die folgenden Voraussetzungen erfüllt sein:
Ein C++-Compiler wie GCC oder Clang, der auf Ihrem System installiert ist. Sie können einfach jede IDE verwenden, die C++-Programmierung unterstützt.
wkhtmltopdf-Bibliothek heruntergeladen und installiert. Sie können die neueste Version von der offiziellen Website herunterladen wkhtmltopdf website und installieren Sie es gemäß den Anweisungen Ihres Betriebssystems.
Erstellen Sie ein Projekt in Code::Blocks und folgen Sie dann den unten stehenden Schritten, um den Bibliotheksordner und die Datei zu verknüpfen. Wenn Sie eine andere IDE verwenden, können die Optionen anders sein, aber Sie müssen die heruntergeladene Bibliothek in Ihrem Projekt referenzieren, damit es funktioniert.
Um sicherzustellen, dass Code::Blocks die erforderlichen Header-Dateien finden kann, müssen wir die Suchverzeichnisse einrichten.
Klicken Sie auf das Menü "Projekt" in der Menüleiste und wählen Sie die "Erstellungsoptionen". Stellen Sie sicher, dass Sie "Debug" auswählen.
Wählen Sie im Dialogfeld "Erstellungsoptionen" die Registerkarte "Verzeichnisse suchen".
Klicken Sie unter der Registerkarte "Compiler" auf die Schaltfläche "Hinzufügen".
Wechseln Sie in das Verzeichnis, in dem sich die wkhtmltox-Header-Dateien befinden (z. B. C:\Programmdateien\wkhtmltopdf\include)und wählen Sie es aus.
Klicken Sie abschließend auf "OK", um das Dialogfeld zu schließen.
Um gegen die wkhtmltox-Bibliothek zu linken, gehen Sie wie folgt vor:
Klicken Sie erneut auf das Menü "Projekt" in der Menüleiste und wählen Sie "Erstellungsoptionen". Stellen Sie sicher, dass Sie "Debug" auswählen.
Wählen Sie im Dialogfeld "Erstellungsoptionen" die Registerkarte "Linker-Einstellungen".
Klicken Sie auf der Registerkarte "Bibliotheken verknüpfen" auf die Schaltfläche "Hinzufügen".
Wechseln Sie zu dem Verzeichnis, in dem sich die wkhtmltox Bibliotheksdateien befinden (z. B. C:\Programmdateien\wkhtmltopdf\lib)und wählen Sie die entsprechende Bibliotheksdatei aus.
Klicken Sie auf "Öffnen", um die Bibliothek zu Ihrem Projekt hinzuzufügen.
Klicken Sie abschließend auf "OK", um das Dialogfeld zu schließen.
Zunächst werden wir die notwendigen Header-Dateien einbinden, um die Funktionalitäten der wkhtmltopdf-Bibliothek in unserem C++-Programm zu nutzen. Fügen Sie die folgenden Header-Dateien am Anfang der Quellcodedatei main.cpp ein:
#include <iostream>
#include <fstream>
#include <string>
#include <wkhtmltox/pdf.h>
Wenn Sie nicht mit der grafischen Benutzeroberfläche arbeiten, müssen Sie diese deaktivieren, um Fehler zu vermeiden. Der Code lautet wie folgt:
wkhtmltopdf_init(false);
Als Nächstes müssen wir globale und objektbezogene Zeiger initialisieren und dann den wkhtmltopdf
-Konverter.
wkhtmltopdf_global_settings* gs = wkhtmltopdf_create_global_settings();
wkhtmltopdf_object_settings* os = wkhtmltopdf_create_object_settings();
wkhtmltopdf_converter* converter = wkhtmltopdf_create_converter(gs);
Lassen Sie uns nun eine HTML-Zeichenkette erstellen, um einige Inhalte in unser neu erstelltes PDF-Dokument einzufügen. Der Code lautet wie folgt:
string htmlString = "<html><body><h1>Create a PDF in C++ using WKHTMLTOPDF Library</h1></body></html>";
wkhtmltopdf_add_object(converter, os, htmlString.c_str());
Wkhtmltopdf bietet eine Konvertierungsmethode, um HTML-Inhalte in PDF zu konvertieren. Hier ist das Codeschnipsel:
wkhtmltopdf_convert(converter);
Mit der Funktion wkhtmltopdf_get_output
können wir die PDF-Daten als Speicherpufferstrom erhalten. Sie gibt auch die Länge der PDF-Datei zurück. Das folgende Beispiel wird diese Aufgabe erfüllen:
const unsigned char* pdfData;
const int pdfLength = wkhtmltopdf_get_output(converter, &pdfData);
Der pdfData
-Zeiger enthält nun den Zeichenstrom des wkhtmltopdf_converter
. Um in einer PDF-Datei zu speichern, geben wir zunächst den Dateipfad an, unter dem wir die PDF-Datei speichern wollen. Dann öffnen wir die Datei mit Hilfe des Ausgabedateistroms im Binärmodus und schreiben die "pdfData" in sie, indem wir sie mit der Funktion "reinterpret_cast" typisieren. Schließlich schließen wir die Datei.
const char* outputPath = "file.pdf";
ofstream outputFile(outputPath, ios::binary);
outputFile.write(reinterpret_cast<const char*>(pdfData), pdfLength);
outputFile.close();
Nach der erfolgreichen Erstellung einer PDF-Datei ist es wichtig, die von Wkhtmltopdf zugewiesenen Ressourcen zu bereinigen, da es sonst zu einem Speicherverlust kommen kann.
wkhtmltopdf_destroy_converter(converter);
wkhtmltopdf_destroy_object_settings(os);
wkhtmltopdf_destroy_global_settings(gs);
wkhtmltopdf_deinit();
cout << "PDF created successfully." << endl;
Erstellen Sie nun das Projekt und führen Sie den Code mit F9 aus. Die Ausgabe wird generiert und im Projektordner gespeichert. Die resultierende PDF-Datei sieht wie folgt aus:
IronPDF ist eine .NET C# PDF-Bibliothek, mit der Entwickler mühelos PDF-Dokumente aus HTML erstellen können. Es bietet eine intuitive API, die den Prozess der Erstellung von PDF-Dateien aus HTML vereinfacht.
IronPDF ist eine robuste und vielseitige Lösung für die Arbeit mit PDF-Dateien. Es erstellt nicht nur PDF aus einfachen HTML-Dokumenten, sondern auch aus komplexen Webseiten mit CSS-Styling, JavaScript-Interaktionen und sogar dynamischen Inhalten. Außerdem können Sie verschiedene PDF-Konverter mit schnellem Zugriff auf ihre Konvertierungsmethoden entwickeln.
Hier ist ein Beispielcode für pDF erstellen mit HTML-String:
using IronPdf;
// Instantiate Renderer
var renderer = new ChromePdfRenderer();
// Create a PDF from a HTML string using C#
var pdf = renderer.RenderHtmlAsPdf("<h1>Hello World</h1>");
// Export to a file or Stream
pdf.SaveAs("output.pdf");
Wir erstellen eine Instanz von ChromePdfRenderer
, um den HTML-Inhalt als PDF zu rendern. Wir rufen die Methode "RenderHtmlAsPdf" für das "Renderer"-Objekt auf und übergeben die HTML-Zeichenfolge. Dadurch wird das PDF-Dokument erzeugt, das dann mit der Methode SaveAs
gespeichert wird.
Für weitere Informationen über eine PDF-Datei erstellen von verschiedenen Ressourcen wie HTML-Dateien, Webseiten-URLs und Bildern, besuchen Sie bitte diese code-Beispielseite.
In diesem Artikel haben wir die PDF-Erzeugung in C++ mit der wkhtmltopdf C++ Library untersucht und gelernt, wie man mit IronPDF PDF-Dokumente in C# erzeugt.
Mit IronPDF wird die Generierung von PDF-Dateien aus HTML-Inhalten zu einer unkomplizierten Aufgabe in .NET-Framework-Sprachen. Seine umfangreichen Funktionen machen es zu einem wertvollen Werkzeug für Entwickler, die Folgendes konvertieren müssen HTML zu PDF in ihren C#-Projekten. Ob es um die Erstellung von Berichten, Rechnungen oder anderen Dokumenten geht, die eine präzise HTML-zu-PDF-Konvertierung erfordern, IronPDF ist eine zuverlässige und effiziente Lösung.
IronPDF ist für Entwicklungszwecke kostenlos, aber für die kommerzielle Nutzung muss es lizenziert werden. Sie bietet auch eine kostenloser Test für die kommerzielle Nutzung, um seine vollständige Funktionalität zu testen. IronPDF herunterladen und probieren Sie es selbst aus.
9 .NET API-Produkte für Ihre Bürodokumente