比較

FO.NET vs IronPDF:技術比較ガイド

FO.NETとIronPDFの比較:.NET開発者のための技術比較

.NET開発者がPDF生成ソリューションを評価するとき、FO.NETは、XSL-FO文書をPDFに変換するために特別に設計されたニッチツールとして浮上します。 しかし、時代遅れのXSL-FO言語への依存、HTML/CSSのサポート不足、メンテナンスの放棄により、多くのチームが代替案を検討しています。 IronPdfはほとんどの開発者がすでに知っているHTML/CSSウェブスタンダードを使用し、Chromiumレンダリングエンジンとアクティブな毎月のアップデートによるモダンなアプローチを提供します。

この比較では、プロの開発者やアーキテクトが.NET PDFの要件について十分な情報を得た上で決定できるように、技術的に関連する次元で両ライブラリを検証します。

FO.NETを理解する

FO.NET(別名FoNet)は、C#を使用してXSL Formatting Object(XSL-FO)ドキュメントをPDFに変換するために設計されたオープンソースライブラリです。 このライブラリは、Apache 2.0ライセンスの下で動作し、XSL-FO言語をPDF形式に直接マッピングします。

FO.NETは、FonetDriverを主要クラスとして使用し、Make()ファクトリーメソッドがドライバーインスタンスを作成し、Render()メソッドがXSL-FO入力ストリームを処理してPDF出力ストリームを生成します。 構成は、fo:simple-page-masterfo:layout-master-setのような要素や、余白、ページサイズ、フォントのフォーマット属性を使って、XSL-FOマークアップの中で行われます。

FO.NETにはXSL-FOの知識が必要です。XSL-FOはXMLベースの言語で、2001年のW3C仕様で、2006年以降は更新されていません。このライブラリはHTMLやCSSをサポートしておらず、ウェブページを直接レンダリングすることはできません。 XSL-FOは、今日の技術状況では時代遅れと考えられており、HTML/CSSを知っている98%以上の開発者に比べて、XSL-FOの専門知識を持っている開発者は1%未満です。

オリジナルのCodePlexリポジトリは廃止され、GitHubのフォークもアクティブにメンテナンスされていません。 FO.NETはSystem.Drawingに内部依存しているため、Linux/macOSでは動作せず、Windowsのみの展開に制限されています。

IronPDFの理解

IronPDFは.NET PDFライブラリで、ドキュメントのスタイリングとレイアウトにHTML/CSSを使用し、開発で広く使われているWeb標準を活用しています。 このライブラリはChromiumレンダリングエンジンを使用しており、FlexboxやGridレイアウトを含むCSS3のフルサポートに加え、JavaScriptの実行も可能です。

IronPDFはChromePdfRendererを主要なレンダリングクラスとして使用し、RenderingOptionsはページサイズ、マージン、ヘッダー、フッター、その他のPDFの設定をプログラムで行います。 このライブラリは、URL の直接レンダリング、HTML 文字列のレンダリング、HTML ファイルのレンダリングをサポートし、保存、マージ、セキュリティ保護、その他の操作が可能な PdfDocument<//code> オブジェクトを生成します。

IronPdfは毎月リリースされ、積極的にメンテナンスされ、真のクロスプラットフォーム(Windows, Linux, macOS)をサポートし、包括的なドキュメントとチュートリアルを提供します。

アーキテクチャとテクノロジーの比較

これらの.NET PDFライブラリの基本的な違いは、入力形式と技術基盤にあります。

アスペクトFO.NETIronPDF
入力フォーマットXSL-FO(時代遅れのXML)HTML/CSS(最新のウェブ標準)
ラーニングカーブスティープ(XSL-FOの専門知識)ジェントル(HTML/CSSの知識)
メンテナンス中止毎月積極的にメンテナンス
プラットフォームサポートWindowsのみ真のクロスプラットフォーム
CSSサポートなしフルCSS3(フレックスボックス、グリッド)
JavaScript(ジャバスクリプトなしJavaScriptフルサポート
URLレンダリングサポートされていません内蔵
最新の機能制限的ヘッダー、フッター、透かし、セキュリティ
ドキュメント古い包括的なチュートリアル

FO.NETは、XSL-FOが文書フォーマットの標準になると予想されたときに設計されました。 それが実現しなかったのです。TTML/CSSが普遍的な文書フォーマットになったのです。 ほとんどのXSL-FOリソースは2005年から2010年のものであり、最新の情報やコミュニティサポートを見つけることはますます難しくなっています。

コードの比較:一般的なPDF操作

HTMLからPDFへの変換

最も基本的な操作は、XSL-FOとHTMLアプローチの間のパラダイムの違いを示しています。

FO.NET:(英語

// NuGet: Install-Package Fonet
using Fonet;
using Fonet.Render.Pdf;
using System.IO;
using System.Xml;

class Program
{
    static void Main()
    {
        // FoNet requires XSL-FO format, not HTML
        // First convert HTML to XSL-FO (manual process)
        string xslFo = @"<?xml version='1.0' encoding='utf-8'?>
            <fo:root xmlns:fo='http://www.w3.org/1999/XSL/Format'>
                <fo:layout-master-set>
                    <fo:simple-page-master master-name='page'>
                        <fo:region-body/>
                    </fo:simple-page-master>
                </fo:layout-master-set>
                <fo:page-sequence master-reference='page'>
                    <fo:flow flow-name='xsl-region-body'>
                        <fo:block>Hello World</fo:block>
                    </fo:flow>
                </fo:page-sequence>
            </fo:root>";

        FonetDriver driver = FonetDriver.Make();
        driver.Render(new StringReader(xslFo), 
            new FileStream("output.pdf", FileMode.Create));
    }
}
// NuGet: Install-Package Fonet
using Fonet;
using Fonet.Render.Pdf;
using System.IO;
using System.Xml;

class Program
{
    static void Main()
    {
        // FoNet requires XSL-FO format, not HTML
        // First convert HTML to XSL-FO (manual process)
        string xslFo = @"<?xml version='1.0' encoding='utf-8'?>
            <fo:root xmlns:fo='http://www.w3.org/1999/XSL/Format'>
                <fo:layout-master-set>
                    <fo:simple-page-master master-name='page'>
                        <fo:region-body/>
                    </fo:simple-page-master>
                </fo:layout-master-set>
                <fo:page-sequence master-reference='page'>
                    <fo:flow flow-name='xsl-region-body'>
                        <fo:block>Hello World</fo:block>
                    </fo:flow>
                </fo:page-sequence>
            </fo:root>";

        FonetDriver driver = FonetDriver.Make();
        driver.Render(new StringReader(xslFo), 
            new FileStream("output.pdf", FileMode.Create));
    }
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
$vbLabelText   $csharpLabel

IronPDF:

// NuGet: Install-Package IronPdf
using IronPdf;

class Program
{
    static void Main()
    {
        var renderer = new ChromePdfRenderer();
        string html = "<h1>Hello World</h1><p>This is HTML content.</p>";
        var pdf = renderer.RenderHtmlAsPdf(html);
        pdf.SaveAs("output.pdf");
    }
}
// NuGet: Install-Package IronPdf
using IronPdf;

class Program
{
    static void Main()
    {
        var renderer = new ChromePdfRenderer();
        string html = "<h1>Hello World</h1><p>This is HTML content.</p>";
        var pdf = renderer.RenderHtmlAsPdf(html);
        pdf.SaveAs("output.pdf");
    }
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
$vbLabelText   $csharpLabel

対照的ですね。 FO.NETは、XML名前空間宣言、fo:rootfo:layout-master-setfo:simple-page-masterfo:page-sequencefo:flowfo:block要素を含む冗長なXSL-FOマークアップを必要とします。 コードコメントには、次のように明確に記されています:"FoNetはHTMLではなくXSL-FO形式を必要とします。

IronPdfはレンダラーを作成し、標準的なHTMLを渡し、PDFにレンダリングし、開発者がすでに知っている構文を使って簡単な行をセーブします。

高度なHTMLレンダリングオプションについては、HTMLからPDFへの変換ガイドをご覧ください。

URLからPDFへの変換

ウェブページをPDFに変換すると、重大な能力差が明らかになります。

FO.NET:(英語

// NuGet: Install-Package Fonet
using Fonet;
using System.IO;
using System.Net;

class Program
{
    static void Main()
    {
        // FoNet does not support URL rendering directly
        // Must manually download, convert HTML to XSL-FO, then render
        string url = "https://example.com";
        string html = new WebClient().DownloadString(url);

        // Manual conversion from HTML to XSL-FO required (complex)
        string xslFo = ConvertHtmlToXslFo(html); // Not built-in

        FonetDriver driver = FonetDriver.Make();
        driver.Render(new StringReader(xslFo), 
            new FileStream("webpage.pdf", FileMode.Create));
    }

    static string ConvertHtmlToXslFo(string html)
    {
        // Custom implementation required
        throw new System.NotImplementedException();
    }
}
// NuGet: Install-Package Fonet
using Fonet;
using System.IO;
using System.Net;

class Program
{
    static void Main()
    {
        // FoNet does not support URL rendering directly
        // Must manually download, convert HTML to XSL-FO, then render
        string url = "https://example.com";
        string html = new WebClient().DownloadString(url);

        // Manual conversion from HTML to XSL-FO required (complex)
        string xslFo = ConvertHtmlToXslFo(html); // Not built-in

        FonetDriver driver = FonetDriver.Make();
        driver.Render(new StringReader(xslFo), 
            new FileStream("webpage.pdf", FileMode.Create));
    }

    static string ConvertHtmlToXslFo(string html)
    {
        // Custom implementation required
        throw new System.NotImplementedException();
    }
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
$vbLabelText   $csharpLabel

IronPDF:

// NuGet: Install-Package IronPdf
using IronPdf;

class Program
{
    static void Main()
    {
        var renderer = new ChromePdfRenderer();
        var pdf = renderer.RenderUrlAsPdf("https://example.com");
        pdf.SaveAs("webpage.pdf");
    }
}
// NuGet: Install-Package IronPdf
using IronPdf;

class Program
{
    static void Main()
    {
        var renderer = new ChromePdfRenderer();
        var pdf = renderer.RenderUrlAsPdf("https://example.com");
        pdf.SaveAs("webpage.pdf");
    }
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
$vbLabelText   $csharpLabel

FO.NETは明示的にURLレンダリングをサポートしていません。 コードコメントには"FoNetはURLレンダリングを直接サポートしていません"、"HTMLからXSL-FOへの手動変換が必要です(複雑)"。ConvertHtmlToXslFo()メソッドはNotImplementedExceptionをスローします。この変換はビルトインではなく、カスタム実装が必要だからです。

IronPdfはネイティブのRenderUrlAsPdf()機能を提供し、URLの取得、JavaScriptの実行、レンダリングを単一のメソッド呼び出しで処理します。

URL レンダリングの詳細については、URL to PDF documentationを参照してください。

カスタム設定の PDF

ページ寸法と余白の設定は、設定アプローチの違いを示しています。

FO.NET:(英語

// NuGet: Install-Package Fonet
using Fonet;
using Fonet.Render.Pdf;
using System.IO;

class Program
{
    static void Main()
    {
        // FoNet settings are configured in XSL-FO markup
        string xslFo = @"<?xml version='1.0' encoding='utf-8'?>
            <fo:root xmlns:fo='http://www.w3.org/1999/XSL/Format'>
                <fo:layout-master-set>
                    <fo:simple-page-master master-name='A4' 
                        page-height='297mm' page-width='210mm'
                        margin-top='20mm' margin-bottom='20mm'
                        margin-left='25mm' margin-right='25mm'>
                        <fo:region-body/>
                    </fo:simple-page-master>
                </fo:layout-master-set>
                <fo:page-sequence master-reference='A4'>
                    <fo:flow flow-name='xsl-region-body'>
                        <fo:block font-size='14pt'>Custom PDF</fo:block>
                    </fo:flow>
                </fo:page-sequence>
            </fo:root>";

        FonetDriver driver = FonetDriver.Make();
        driver.Render(new StringReader(xslFo), 
            new FileStream("custom.pdf", FileMode.Create));
    }
}
// NuGet: Install-Package Fonet
using Fonet;
using Fonet.Render.Pdf;
using System.IO;

class Program
{
    static void Main()
    {
        // FoNet settings are configured in XSL-FO markup
        string xslFo = @"<?xml version='1.0' encoding='utf-8'?>
            <fo:root xmlns:fo='http://www.w3.org/1999/XSL/Format'>
                <fo:layout-master-set>
                    <fo:simple-page-master master-name='A4' 
                        page-height='297mm' page-width='210mm'
                        margin-top='20mm' margin-bottom='20mm'
                        margin-left='25mm' margin-right='25mm'>
                        <fo:region-body/>
                    </fo:simple-page-master>
                </fo:layout-master-set>
                <fo:page-sequence master-reference='A4'>
                    <fo:flow flow-name='xsl-region-body'>
                        <fo:block font-size='14pt'>Custom PDF</fo:block>
                    </fo:flow>
                </fo:page-sequence>
            </fo:root>";

        FonetDriver driver = FonetDriver.Make();
        driver.Render(new StringReader(xslFo), 
            new FileStream("custom.pdf", FileMode.Create));
    }
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
$vbLabelText   $csharpLabel

IronPDF:

// NuGet: Install-Package IronPdf
using IronPdf;
using IronPdf.Engines.Chrome;

class Program
{
    static void Main()
    {
        var renderer = new ChromePdfRenderer();
        renderer.RenderingOptions.PaperSize = PdfPaperSize.A4;
        renderer.RenderingOptions.MarginTop = 20;
        renderer.RenderingOptions.MarginBottom = 20;
        renderer.RenderingOptions.MarginLeft = 25;
        renderer.RenderingOptions.MarginRight = 25;

        string html = "<h1 style='font-size:14pt'>Custom PDF</h1>";
        var pdf = renderer.RenderHtmlAsPdf(html);
        pdf.SaveAs("custom.pdf");
    }
}
// NuGet: Install-Package IronPdf
using IronPdf;
using IronPdf.Engines.Chrome;

class Program
{
    static void Main()
    {
        var renderer = new ChromePdfRenderer();
        renderer.RenderingOptions.PaperSize = PdfPaperSize.A4;
        renderer.RenderingOptions.MarginTop = 20;
        renderer.RenderingOptions.MarginBottom = 20;
        renderer.RenderingOptions.MarginLeft = 25;
        renderer.RenderingOptions.MarginRight = 25;

        string html = "<h1 style='font-size:14pt'>Custom PDF</h1>";
        var pdf = renderer.RenderHtmlAsPdf(html);
        pdf.SaveAs("custom.pdf");
    }
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
$vbLabelText   $csharpLabel

FO.NETのコードコメントには、次のように明記されています:"FoNetの設定はXSL-FOマークアップで構成されます。ページサイズ、マージン、フォーマットは、fo:simple-page-masterの属性としてXML構造内に埋め込まれています。 つまり、コンフィギュレーションは、冗長なXML形式のコンテンツと絡み合っています。

IronPdfはプログラム的なRenderingOptionsプロパティを使用して、コンテンツから設定を分離します。 PaperSizeMarginTopMarginBottomMarginLeftMarginRight などの設定はレンダラー オブジェクトに設定されますが、コンテンツはクリーンな HTML のままです。

APIマッピングリファレンス

FO.NETの移行を評価したり、機能を比較したりする開発者のために、このマッピングは同等の操作を示します:

コア クラス マッピング

FO.NETIronPDFノート
FonetDriver.Make()を使用してください。new ChromePdfRenderer().レンダラーの作成
driver.Render(inputStream, outputStream).renderer.RenderHtmlAsPdf(html).コアレンダリング
driver.Render(inputFile, outputStream).renderer.RenderHtmlFileAsPdf(path)のようにします。ファイルベース
ドライバー.ベースディレクトリ<コード>RenderingOptions.BaseUrl</コードリソースのベースパス
driver.OnError += handler.レンダリング周りのトライ/キャッチエラー処理

XSL-FOからRenderingOptionsへのマッピング

XSL-FO属性IronPDF レンダリングオプションノート
<コード>ページハイト</コード>/<コード>ページ幅</コード<コード>用紙サイズ</コード標準サイズまたはカスタムサイズ
<コード>マージントップ</コード<コード>マージントップ</コード単位:ミリメートル
<コード>マージンボトム</コード<コード>マージンボトム</コード単位:ミリメートル
<コード>マージンレフト</コード<コード>マージンレフト</コード単位:ミリメートル
margin-right<コード>マージンライト</コード単位:ミリメートル
<コード>リファレンス指向</コードペーパーオリエンテーションポートレート/風景

XSL-FO要素からHTMLへのマッピング

XSL-FO要素HTML相当ノート
<fo:root>のようにします。<html>ルート要素
<//code>CSS @pageルールページ設定
<fo:simple-page-master>CSS <コード>@ページ</コードページ定義
<//code><body> または <div> を使用してください。ページ内容
<fo:flow>のようにします。<main> または <div> を使用してください。主な内容
<//code><コード>HtmlHeaderFooter</コードヘッダー/フッター
<fo:block>のようにします。<p><div><h1>-<h6>ブロックコンテンツ
<//code><table>
<//code><ul><ol>リスト
<//code><img>画像
<fo:page-number/><コード>{ページ}</コード>プレースホルダページ数

機能比較の概要

フィーチャーFO.NETIronPDF
HTMLからPDFへ❌ (手作業によるXSL-FO変換が必要)
URLからPDFへ❌ (サポートされていません)
XSL-FOからPDFへ該当なし
CSS3 サポート✅ (フレックスボックス、グリッド)
JavaScript
ヘッダー/フッターXSL-FO 静的コンテンツHTMLベース
ページ番号<コード>fo:ページ番号</コード<コード>{ページ}</コード>プレースホルダ
クロスプラットフォーム❌ (Windowsのみ)
アクティブメンテナンス❌ (放棄)✅ (毎月)

チームがFO.NETからIronPDFへの移行を検討するとき

開発チームが.NETからIronPDFへの移行を評価する理由はいくつかあります:

時代遅れの技術: XSL-FOは2001年のW3C仕様で、2006年以降更新がなく、ほとんど時代遅れと見なされています。 ほとんどのリソースやドキュメントは2005年から2010年のものであり、最新の情報を見つけたり、XSL-FOの専門知識を持つ開発者を雇ったりすることはますます難しくなっています。

急な学習曲線:XSL-FOは、特殊なフォーマットオブジェクト(fo:blockfo:tablefo:page-sequenceなど)を持つ複雑なXMLベースのマークアップを学習する必要があります。 HTML/CSSを知っている開発者の98%以上がXSL-FOを知っているのに対し、XSL-FOを知っている開発者は1%未満です。

HTML/CSSサポートなし:FO.NETはHTMLやCSSをレンダリングできません。HTMLからXSL-FOマークアップに手動で変換する必要がありますが、ライブラリには組み込まれていません。 ウェブコンテンツやHTMLテンプレートを使用しているチームは、カスタム変換ロジックを実装する必要があります。

メンテナンスの放棄: オリジナルのCodePlexリポジトリは廃止され、GitHubのフォークもアクティブにメンテナンスされていません。 セキュリティパッチ、バグ修正、新機能の開発は行いません。

プラットフォームの制限:FO.NETにはSystem.Drawingへの内部依存があるため、Linux/macOSでは動作せず、Windowsのみの環境への展開に制限されます。 最近のアプリケーションでは、クロスプラットフォームのデプロイがますます必要になっています。

不足しているモダンな機能:JavaScriptをサポートしていない、CSS3の機能(Flexbox、Grid)がない、モダンなWebフォントがない、URLの直接レンダリング機能がない。

長所と考慮点

FO.NETの強み

  • 直接XSL-FO変換:XSL-FOからPDFへの変換のために特別に最適化されています。
  • オープンソース:Apache 2.0ライセンス(使用、変更、配布自由
  • 正確な制御:XSL-FOは、文書のレイアウトを詳細に制御します。

FO.NETについての考察

  • 時代遅れの技術: XSL-FO仕様は2006年以降更新されていません。
  • XSL-FOの知識が必要です:専門知識を持つ開発者は全体の1%未満です。
  • HTMLをサポートしていません:HTMLまたはCSSコンテンツをレンダリングできない
  • Abandoned: アクティブなメンテナンスまたはセキュリティアップデートはありません。
  • Windowsのみ: System.Drawingの依存関係がクロスプラットフォームでの使用を妨げます。
  • URLレンダリングはできません:ウェブページを直接変換できない
  • 限られたドキュメント:リソースが古い

IronPDFの強み

  • HTML/CSS標準:98%以上の開発者がすでに知っているウェブ技術を使用
  • モダンレンダリング:CSS3とJavaScriptをフルサポートしたChromiumエンジン
  • 積極的な開発:新機能とセキュリティパッチを含む毎月のリリース
  • クロスプラットフォーム:Windows、Linux、およびmacOSの真のサポート
  • 直接URLレンダリング: ネイティブのRenderUrlAsPdf()機能
  • プロフェッショナルな機能: ヘッダー、フッター、透かし、セキュリティ-すべて組み込みです。
  • 包括的なリソース: 豊富なチュートリアルドキュメント

IronPDFについての考察

  • 商用ライセンス:商用利用にはライセンスが必要です。
  • 異なるパラダイム:XSL-FOテンプレートはHTMLに変換する必要があります。

結論

FO.NETとIronPDFは.NETでPDFを生成するための根本的に異なるアプローチです。 FO.NETは、XSL-FOからPDFへの変換というニッチなユースケースに対応していますが、時代遅れの技術への依存、放棄されたメンテナンス、Windowsのみの制限、HTMLサポートの欠如により、新しいプロジェクトで正当化することがますます難しくなっています。

IronPDFはHTML/CSSウェブスタンダードを使用し、現在の開発者のスキルや技術に沿った最新のアプローチを提供します。 HTML、URLを直接レンダリングし、Chromiumエンジンで完全なCSS3を使用できるため、現代のPDF生成要件に適しています。

組織が.NET 10、C# 14、2026年までのアプリケーション開発を計画する中で、技術基盤は重要です。 レガシーなXSL-FOシステムを保守しているチームはFO.NETを使い続けるかもしれませんが、最新のPDF生成の道は明らかに既存のウェブ開発の専門知識を活用するIronPDFのようなHTMLベースのソリューションに向いています。

無料トライアルでIronPDFの評価を開始し、包括的なドキュメントを参照して、特定の要件への適合性を評価してください。