ABCpdf for .NETからIronPDFへの移行方法
ABCpdf for .NETからIronPDFへの切り替えは、ライセンスの簡素化、最新のドキュメント、ネイティブのクロスプラットフォーム サポートを目指す開発チームにとって戦略的なアップグレードです。 この徹底的なガイドでは、実際のシナリオからの API マッピングとコード変換の例を含む、ステップバイステップの移行パスが提供されます。
.NET Framework 4.6.2 を使用している場合でも、2026 年以降 for .NET 9 以降をターゲットにしている場合でも、この ABCpdf 移行ガイドを使用すると、IronPDF の Chrome ベースのレンダリング エンジンに簡単に移行できます。
なぜABCpdfへの移行を検討するのですか?
WebSupergoo の ABCpdf は、長年にわたって優れた.NET PDF ライブラリとして機能してきました。 ただし、2025 年と 2026 年に向けてプロジェクトを計画している現代の開発チームにとって、IronPDFが魅力的な選択肢となる要因はいくつかあります。
複雑なライセンス
ABCpdf は、扱いがわかりにくい可能性のある階層型ライセンス モデルを使用します。 価格は 349 ドルから始まり、機能、サーバーの展開、ユースケースに応じて増加します。 多くの開発者は、プロジェクトの予算を立てる際に、このライセンスの迷路が管理上の大きな負担になっていると報告しています。
Windows-ファーストアーキテクチャ
ABCpdfはクロスプラットフォームのサポートを追加しましたが、Windows中心の歴史的な設計がワークフローで時折表面化します。 Linuxコンテナ、Docker環境、またはmacOSの開発セットアップをターゲットとする開発者は、プロジェクト計画中に予期しなかった摩擦に遭遇する可能性があります。
ドキュメントのスタイル
ABCpdfのドキュメンテーションは徹底していますが、古いスタイルに従っているため、最新のAPIドキュメンテーションの標準と比較すると古く感じることがあります。 新しいユーザーは、特に新しい.NETバージョンで作業するときに、必要な正確な例を見つけるのに苦労することがよくあります。
エンジン構成オーバーヘッド
ABCpdf では、明示的なエンジン選択 (Gecko、Trident、または Chrome) と、Clear() 呼び出しによる手動のリソース管理が必要です。 これは、現代の開発者が避けたい定型コードをすべてのPDF操作に追加します。
IronPDFとABCpdfの比較:機能比較
次の比較表は、2つ for .NET PDFライブラリの主な違いを示しています:
| フィーチャー | ABCpdf for .NET | IronPDF |
|---|---|---|
| レンダリングエンジン | Gecko/Trident/Chrome (設定可能) | フルChromium(CSS3、JavaScript) |
| クロスプラットフォーム。 | 後日追記、Windowsファースト | ネイティブWindows、Linux、macOS、Docker |
| ライセンスモデル | 349ドル以上からの複雑な段階的価格設定 | シンプルで透明性のある価格設定。 |
| .NETサポート | .NET Frameworkフォーカス | .NET Framework 4.6.2 から .NET 9+ へ |
| リソース管理。 | マニュアルdoc.Clear()が必要です |
using ステートメントを含む IDisposable |
| ライセンスセットアップ | レジストリの使用例 | シンプルなコードベースのライセンスキー |
| ドキュメント | 時代遅れのスタイル | 豊富な例を含む最新のドキュメント。 |
移行を始める前に
前提条件
開発環境がこれらの要件を満たしていることを確認してください:
- .NET Framework 4.6.2+または.NET Core 3.1+ / .NET 5-9
- Visual Studio 2019+またはJetBrains Rider
- NuGetパッケージマネージャへのアクセス
- IronPDFライセンスキー (無料トライアルあり)
すべてのABCpdfリファレンスを検索する
ソリューションディレクトリでこれらのコマンドを実行し、ABCpdf for .NETを使用するすべてのファイルを検索してください:
grep -r "using WebSupergoo" --include="*.cs" .
grep -r "ABCpdf" --include="*.csproj" .
grep -r "using WebSupergoo" --include="*.cs" .
grep -r "ABCpdf" --include="*.csproj" .
この監査では、変更が必要なすべてのファイルを特定し、完全な移行カバレッジを確保します。
予想される画期的な変更
ABCpdf for .NETとIronPDFのアーキテクチャの違いを理解することで、移行時の驚きを防ぐことができます:
| カテゴリ | ABCpdf の動作 | IronPDF の動作 | 移行作業 |
|---|---|---|---|
| オブジェクトモデル | Doc クラスは中央です |
ChromePdfRenderer + PdfDocument |
レンダリングとドキュメントの分離 |
| リソースのクリーンアップ | マニュアル doc.Clear() |
IDisposableパターン | using ステートメントを使用する |
| エンジンの選択 | doc.HtmlOptions.Engine = EngineType.Chrome |
ビルトインChrome | エンジン設定の削除 |
| ページインデックス | 1から始まる (doc.Page = 1) |
0から始まる (pdf.Pages[0]) |
索引参照の調整 |
| コーディネート | ポイントベース doc.Rect |
CSSベースのマージン | CSSまたはRenderingOptionsを使用する |
クイックスタート:5分でできる移行
ステップ 1: NuGet パッケージを更新する
# Remove ABCpdf
dotnet remove package ABCpdf
# Install IronPDF
dotnet add package IronPdf
# Remove ABCpdf
dotnet remove package ABCpdf
# Install IronPDF
dotnet add package IronPdf
ステップ 2: ライセンスキーの設定
アプリケーション起動時、IronPDF操作の前に追加してください:
// Add at application startup (Program.cs or Startup.cs)
IronPdf.License.LicenseKey = "YOUR-LICENSE-KEY";
// Add at application startup (Program.cs or Startup.cs)
IronPdf.License.LicenseKey = "YOUR-LICENSE-KEY";
' Add at application startup (Program.vb or Startup.vb)
IronPdf.License.LicenseKey = "YOUR-LICENSE-KEY"
ステップ 3: グローバル検索と置換
コードベース全体のすべての名前空間参照を更新します:
| 検索 | 置換対象 |
|---|---|
using WebSupergoo.ABCpdf13; |
using IronPdf; |
using WebSupergoo.ABCpdf13.Objects; |
using IronPdf; |
using WebSupergoo.ABCpdf12; |
using IronPdf; |
using WebSupergoo.ABCpdf11; |
using IronPdf; |
完全な API リファレンス
ドキュメント作成方法
以下の表はABCPDF for .NETのメソッドとIronPDFのメソッドの対応表です:
| ABCpdf メソッド | IronPDF メソッド |
|---|---|
new Doc() |
new ChromePdfRenderer() |
doc.AddImageUrl(url) |
renderer.RenderUrlAsPdf(url) |
doc.AddImageHtml(html) |
renderer.RenderHtmlAsPdf(html) |
doc.AddImageFile(path) |
renderer.RenderHtmlFileAsPdf(path) |
doc.Read(path) |
PdfDocument.FromFile(path) |
doc.Save(path) |
pdf.SaveAs(path) |
doc.GetData() |
pdf.BinaryData |
doc.Clear() |
using ステートメントを使用する |
ページ操作方法
| ABCpdf メソッド | IronPDF メソッド |
|---|---|
doc.PageCount |
pdf.PageCount |
doc.Page = n |
pdf.Pages[n-1] |
doc.Delete(pageId) |
pdf.RemovePages(index) |
doc.Append(otherDoc) |
PdfDocument.Merge(pdf1, pdf2) |
doc.Rect.Inset(x, y) |
RenderingOptions.MarginTop/Bottom/Left/Right |
セキュリティと暗号化方法
| ABCpdf メソッド | IronPDF メソッド |
|---|---|
doc.Encryption.Password |
pdf.SecuritySettings.OwnerPassword |
doc.Encryption.CanPrint |
pdf.SecuritySettings.AllowUserPrinting |
doc.Encryption.CanCopy |
pdf.SecuritySettings.AllowUserCopyPasteContent |
doc.SetInfo("Title", value) |
pdf.MetaData.Title |
コード移行の例
例1: URLからHTMLをPDFに変換する
この例では、最も一般的なPDF生成タスクの1つである、WebページのPDFへの変換を示しています。
ABCpdf for .NET実装:
// NuGet: Install-Package ABCpdf
using System;
using WebSupergoo.ABCpdf13;
using WebSupergoo.ABCpdf13.Objects;
class Program
{
static void Main()
{
Doc doc = new Doc();
doc.HtmlOptions.Engine = EngineType.Chrome;
doc.AddImageUrl("https://www.example.com");
doc.Save("output.pdf");
doc.Clear();
}
}
// NuGet: Install-Package ABCpdf
using System;
using WebSupergoo.ABCpdf13;
using WebSupergoo.ABCpdf13.Objects;
class Program
{
static void Main()
{
Doc doc = new Doc();
doc.HtmlOptions.Engine = EngineType.Chrome;
doc.AddImageUrl("https://www.example.com");
doc.Save("output.pdf");
doc.Clear();
}
}
Imports System
Imports WebSupergoo.ABCpdf13
Imports WebSupergoo.ABCpdf13.Objects
Class Program
Shared Sub Main()
Dim doc As New Doc()
doc.HtmlOptions.Engine = EngineType.Chrome
doc.AddImageUrl("https://www.example.com")
doc.Save("output.pdf")
doc.Clear()
End Sub
End Class
IronPDFの実装:。
// NuGet: Install-Package IronPdf
using System;
using IronPdf;
class Program
{
static void Main()
{
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderUrlAsPdf("https://www.example.com");
pdf.SaveAs("output.pdf");
}
}
// NuGet: Install-Package IronPdf
using System;
using IronPdf;
class Program
{
static void Main()
{
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderUrlAsPdf("https://www.example.com");
pdf.SaveAs("output.pdf");
}
}
Imports System
Imports IronPdf
Class Program
Shared Sub Main()
Dim renderer = New ChromePdfRenderer()
Dim pdf = renderer.RenderUrlAsPdf("https://www.example.com")
pdf.SaveAs("output.pdf")
End Sub
End Class
IronPdfのアプローチでは、エンジンの明示的な設定や手作業によるクリーンアップの必要性を排除し、Chromeの完全なレンダリング機能を維持しながらコードの複雑さを軽減します。
例2: HTML文字列からPDFへ
HTML文字列をPDFに変換することは、動的なレポートやドキュメントを作成するために不可欠です。
ABCpdf for .NET実装:
// NuGet: Install-Package ABCpdf
using System;
using WebSupergoo.ABCpdf13;
using WebSupergoo.ABCpdf13.Objects;
class Program
{
static void Main()
{
string html = "<html><body><h1>Hello World</h1><p>This is a PDF document.</p></body></html>";
Doc doc = new Doc();
doc.HtmlOptions.Engine = EngineType.Chrome;
doc.AddImageHtml(html);
doc.Save("output.pdf");
doc.Clear();
}
}
// NuGet: Install-Package ABCpdf
using System;
using WebSupergoo.ABCpdf13;
using WebSupergoo.ABCpdf13.Objects;
class Program
{
static void Main()
{
string html = "<html><body><h1>Hello World</h1><p>This is a PDF document.</p></body></html>";
Doc doc = new Doc();
doc.HtmlOptions.Engine = EngineType.Chrome;
doc.AddImageHtml(html);
doc.Save("output.pdf");
doc.Clear();
}
}
Imports System
Imports WebSupergoo.ABCpdf13
Imports WebSupergoo.ABCpdf13.Objects
Class Program
Shared Sub Main()
Dim html As String = "<html><body><h1>Hello World</h1><p>This is a PDF document.</p></body></html>"
Dim doc As New Doc()
doc.HtmlOptions.Engine = EngineType.Chrome
doc.AddImageHtml(html)
doc.Save("output.pdf")
doc.Clear()
End Sub
End Class
IronPDFの実装:。
// NuGet: Install-Package IronPdf
using System;
using IronPdf;
class Program
{
static void Main()
{
string html = "<html><body><h1>Hello World</h1><p>This is a PDF document.</p></body></html>";
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SaveAs("output.pdf");
}
}
// NuGet: Install-Package IronPdf
using System;
using IronPdf;
class Program
{
static void Main()
{
string html = "<html><body><h1>Hello World</h1><p>This is a PDF document.</p></body></html>";
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SaveAs("output.pdf");
}
}
Imports System
Imports IronPdf
Module Program
Sub Main()
Dim html As String = "<html><body><h1>Hello World</h1><p>This is a PDF document.</p></body></html>"
Dim renderer As New ChromePdfRenderer()
Dim pdf = renderer.RenderHtmlAsPdf(html)
pdf.SaveAs("output.pdf")
End Sub
End Module
IronPDFバージョンはより少ないコード行数で、デフォルトでChromeレンダリングを使用し、すべてのプラットフォームで一貫した出力を保証します。
例3: 複数のPDFをマージする
複数のPDF文書を結合することは、文書処理ワークフローにおいて頻繁に必要とされる要件です。
ABCpdf for .NET実装:
// NuGet: Install-Package ABCpdf
using System;
using WebSupergoo.ABCpdf13;
using WebSupergoo.ABCpdf13.Objects;
class Program
{
static void Main()
{
Doc doc1 = new Doc();
doc1.Read("document1.pdf");
Doc doc2 = new Doc();
doc2.Read("document2.pdf");
doc1.Append(doc2);
doc1.Save("merged.pdf");
doc1.Clear();
doc2.Clear();
}
}
// NuGet: Install-Package ABCpdf
using System;
using WebSupergoo.ABCpdf13;
using WebSupergoo.ABCpdf13.Objects;
class Program
{
static void Main()
{
Doc doc1 = new Doc();
doc1.Read("document1.pdf");
Doc doc2 = new Doc();
doc2.Read("document2.pdf");
doc1.Append(doc2);
doc1.Save("merged.pdf");
doc1.Clear();
doc2.Clear();
}
}
Imports System
Imports WebSupergoo.ABCpdf13
Imports WebSupergoo.ABCpdf13.Objects
Class Program
Shared Sub Main()
Dim doc1 As New Doc()
doc1.Read("document1.pdf")
Dim doc2 As New Doc()
doc2.Read("document2.pdf")
doc1.Append(doc2)
doc1.Save("merged.pdf")
doc1.Clear()
doc2.Clear()
End Sub
End Class
IronPDFの実装:。
// NuGet: Install-Package IronPdf
using System;
using System.Collections.Generic;
using IronPdf;
class Program
{
static void Main()
{
var pdf1 = PdfDocument.FromFile("document1.pdf");
var pdf2 = PdfDocument.FromFile("document2.pdf");
var merged = PdfDocument.Merge(pdf1, pdf2);
merged.SaveAs("merged.pdf");
}
}
// NuGet: Install-Package IronPdf
using System;
using System.Collections.Generic;
using IronPdf;
class Program
{
static void Main()
{
var pdf1 = PdfDocument.FromFile("document1.pdf");
var pdf2 = PdfDocument.FromFile("document2.pdf");
var merged = PdfDocument.Merge(pdf1, pdf2);
merged.SaveAs("merged.pdf");
}
}
Imports System
Imports System.Collections.Generic
Imports IronPdf
Class Program
Shared Sub Main()
Dim pdf1 = PdfDocument.FromFile("document1.pdf")
Dim pdf2 = PdfDocument.FromFile("document2.pdf")
Dim merged = PdfDocument.Merge(pdf1, pdf2)
merged.SaveAs("merged.pdf")
End Sub
End Class
IronPDF の静的 Merge メソッドは、複数のドキュメントを受け入れるよりクリーンな API を提供し、個々の Doc インスタンスを追跡してクリアする必要がなくなります。
例4: 余白のある完全な移行パターン
この例では、カスタムの余白を持つPDFを生成するための完全な移行前/移行後を示しています。
導入前 (ABCpdf for .NET):
using WebSupergoo.ABCpdf13;
using WebSupergoo.ABCpdf13.Objects;
public byte[] GeneratePdf(string html)
{
Doc doc = new Doc();
doc.HtmlOptions.Engine = EngineType.Chrome;
doc.Rect.Inset(20, 20);
doc.AddImageHtml(html);
byte[] data = doc.GetData();
doc.Clear(); // Manual cleanup required
return data;
}
using WebSupergoo.ABCpdf13;
using WebSupergoo.ABCpdf13.Objects;
public byte[] GeneratePdf(string html)
{
Doc doc = new Doc();
doc.HtmlOptions.Engine = EngineType.Chrome;
doc.Rect.Inset(20, 20);
doc.AddImageHtml(html);
byte[] data = doc.GetData();
doc.Clear(); // Manual cleanup required
return data;
}
Imports WebSupergoo.ABCpdf13
Imports WebSupergoo.ABCpdf13.Objects
Public Function GeneratePdf(html As String) As Byte()
Dim doc As New Doc()
doc.HtmlOptions.Engine = EngineType.Chrome
doc.Rect.Inset(20, 20)
doc.AddImageHtml(html)
Dim data As Byte() = doc.GetData()
doc.Clear() ' Manual cleanup required
Return data
End Function
翻訳後(IronPDF):。
using IronPdf;
public byte[] GeneratePdf(string html)
{
var renderer = new ChromePdfRenderer();
renderer.RenderingOptions.MarginTop = 20;
renderer.RenderingOptions.MarginBottom = 20;
renderer.RenderingOptions.MarginLeft = 20;
renderer.RenderingOptions.MarginRight = 20;
using var pdf = renderer.RenderHtmlAsPdf(html);
return pdf.BinaryData; // Automatic cleanup with 'using'
}
using IronPdf;
public byte[] GeneratePdf(string html)
{
var renderer = new ChromePdfRenderer();
renderer.RenderingOptions.MarginTop = 20;
renderer.RenderingOptions.MarginBottom = 20;
renderer.RenderingOptions.MarginLeft = 20;
renderer.RenderingOptions.MarginRight = 20;
using var pdf = renderer.RenderHtmlAsPdf(html);
return pdf.BinaryData; // Automatic cleanup with 'using'
}
Imports IronPdf
Public Function GeneratePdf(html As String) As Byte()
Dim renderer As New ChromePdfRenderer()
renderer.RenderingOptions.MarginTop = 20
renderer.RenderingOptions.MarginBottom = 20
renderer.RenderingOptions.MarginLeft = 20
renderer.RenderingOptions.MarginRight = 20
Using pdf = renderer.RenderHtmlAsPdf(html)
Return pdf.BinaryData ' Automatic cleanup with 'Using'
End Using
End Function
高度な移行シナリオ
.NETコアWebアプリケーション
.NET 6+でWebアプリケーションを構築しているチームや、2025~2026年 for .NET 10リリースを計画しているチームには、以下のパターンが推奨されます:
ABCpdfのパターン:
[HttpPost]
public IActionResult GeneratePdf([FromBody] ReportRequest request)
{
Doc doc = new Doc();
doc.HtmlOptions.Engine = EngineType.Chrome;
doc.AddImageHtml(request.Html);
byte[] pdfBytes = doc.GetData();
doc.Clear();
return File(pdfBytes, "application/pdf", "report.pdf");
}
[HttpPost]
public IActionResult GeneratePdf([FromBody] ReportRequest request)
{
Doc doc = new Doc();
doc.HtmlOptions.Engine = EngineType.Chrome;
doc.AddImageHtml(request.Html);
byte[] pdfBytes = doc.GetData();
doc.Clear();
return File(pdfBytes, "application/pdf", "report.pdf");
}
<HttpPost>
Public Function GeneratePdf(<FromBody> request As ReportRequest) As IActionResult
Dim doc As New Doc()
doc.HtmlOptions.Engine = EngineType.Chrome
doc.AddImageHtml(request.Html)
Dim pdfBytes As Byte() = doc.GetData()
doc.Clear()
Return File(pdfBytes, "application/pdf", "report.pdf")
End Function
IronPDFパターン:
[HttpPost]
public IActionResult GeneratePdf([FromBody] ReportRequest request)
{
var renderer = new ChromePdfRenderer();
using var pdf = renderer.RenderHtmlAsPdf(request.Html);
return File(pdf.BinaryData, "application/pdf", "report.pdf");
}
[HttpPost]
public IActionResult GeneratePdf([FromBody] ReportRequest request)
{
var renderer = new ChromePdfRenderer();
using var pdf = renderer.RenderHtmlAsPdf(request.Html);
return File(pdf.BinaryData, "application/pdf", "report.pdf");
}
<HttpPost>
Public Function GeneratePdf(<FromBody> request As ReportRequest) As IActionResult
Dim renderer As New ChromePdfRenderer()
Using pdf = renderer.RenderHtmlAsPdf(request.Html)
Return File(pdf.BinaryData, "application/pdf", "report.pdf")
End Using
End Function
現代のアプリケーションはノンブロッキングオペレーションを必要とします。
ABCpdfはネイティブの非同期をサポートしていません。 IronPdfはasyncメソッドを提供し、ウェブアプリケーションのパフォーマンスを向上させます:
using IronPdf;
public async Task<byte[]> GeneratePdfAsync(string html)
{
var renderer = new ChromePdfRenderer();
using var pdf = await renderer.RenderHtmlAsPdfAsync(html);
return pdf.BinaryData;
}
using IronPdf;
public async Task<byte[]> GeneratePdfAsync(string html)
{
var renderer = new ChromePdfRenderer();
using var pdf = await renderer.RenderHtmlAsPdfAsync(html);
return pdf.BinaryData;
}
Imports IronPdf
Public Async Function GeneratePdfAsync(html As String) As Task(Of Byte())
Dim renderer As New ChromePdfRenderer()
Using pdf = Await renderer.RenderHtmlAsPdfAsync(html)
Return pdf.BinaryData
End Using
End Function
依存性注入のセットアップ
将来のC# 14リリースと互換性のあるC# 12+パターンを使用して、最新 for .NETアプリケーションにIronPDFを登録してください:
// Program.cs (.NET 6+)
builder.Services.AddSingleton<ChromePdfRenderer>();
// Or create a service wrapper
public interface IPdfService
{
Task<byte[]> GeneratePdfAsync(string html);
}
public class IronPdfService : IPdfService
{
private readonly ChromePdfRenderer _renderer;
public IronPdfService()
{
_renderer = new ChromePdfRenderer();
_renderer.RenderingOptions.PaperSize = PdfPaperSize.A4;
}
public async Task<byte[]> GeneratePdfAsync(string html)
{
using var pdf = await _renderer.RenderHtmlAsPdfAsync(html);
return pdf.BinaryData;
}
}
// Register: builder.Services.AddSingleton<IPdfService, IronPdfService>();
// Program.cs (.NET 6+)
builder.Services.AddSingleton<ChromePdfRenderer>();
// Or create a service wrapper
public interface IPdfService
{
Task<byte[]> GeneratePdfAsync(string html);
}
public class IronPdfService : IPdfService
{
private readonly ChromePdfRenderer _renderer;
public IronPdfService()
{
_renderer = new ChromePdfRenderer();
_renderer.RenderingOptions.PaperSize = PdfPaperSize.A4;
}
public async Task<byte[]> GeneratePdfAsync(string html)
{
using var pdf = await _renderer.RenderHtmlAsPdfAsync(html);
return pdf.BinaryData;
}
}
// Register: builder.Services.AddSingleton<IPdfService, IronPdfService>();
Imports Microsoft.Extensions.DependencyInjection
Imports System.Threading.Tasks
' Program.vb (.NET 6+)
builder.Services.AddSingleton(Of ChromePdfRenderer)()
' Or create a service wrapper
Public Interface IPdfService
Function GeneratePdfAsync(html As String) As Task(Of Byte())
End Interface
Public Class IronPdfService
Implements IPdfService
Private ReadOnly _renderer As ChromePdfRenderer
Public Sub New()
_renderer = New ChromePdfRenderer()
_renderer.RenderingOptions.PaperSize = PdfPaperSize.A4
End Sub
Public Async Function GeneratePdfAsync(html As String) As Task(Of Byte()) Implements IPdfService.GeneratePdfAsync
Using pdf = Await _renderer.RenderHtmlAsPdfAsync(html)
Return pdf.BinaryData
End Using
End Function
End Class
' Register: builder.Services.AddSingleton(Of IPdfService, IronPdfService)()
パフォーマンス最適化のヒント
バッチ操作のためにレンダラを再利用する
// Good: Single renderer instance
var renderer = new ChromePdfRenderer();
foreach (var html in htmlList)
{
using var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SaveAs($"output_{i}.pdf");
}
// Bad: New renderer each time (slower startup)
foreach (var html in htmlList)
{
var renderer = new ChromePdfRenderer(); // Overhead!
using var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SaveAs($"output_{i}.pdf");
}
// Good: Single renderer instance
var renderer = new ChromePdfRenderer();
foreach (var html in htmlList)
{
using var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SaveAs($"output_{i}.pdf");
}
// Bad: New renderer each time (slower startup)
foreach (var html in htmlList)
{
var renderer = new ChromePdfRenderer(); // Overhead!
using var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SaveAs($"output_{i}.pdf");
}
Imports System
' Good: Single renderer instance
Dim renderer As New ChromePdfRenderer()
For Each html In htmlList
Using pdf = renderer.RenderHtmlAsPdf(html)
pdf.SaveAs($"output_{i}.pdf")
End Using
Next
' Bad: New renderer each time (slower startup)
For Each html In htmlList
Dim renderer As New ChromePdfRenderer() ' Overhead!
Using pdf = renderer.RenderHtmlAsPdf(html)
pdf.SaveAs($"output_{i}.pdf")
End Using
Next
メモリ使用量の比較
| シナリオ | ABCpdf for .NET | IronPDF |
|---|---|---|
| 10ページのPDF | ~80 MB | ~50 MB |
| バッチ 100 PDF | 高(手動クリーンアップ) | ~100 MB |
| 大きなHTML(5MB以上) | 変数 | ~150 MB |
よくある移行の問題のトラブルシューティング
PDFが空白のままレンダリングされます
症状: 移行後の出力PDFに空のページがあります。
解決策:JavaScriptコンテンツは、レンダリング前に完全に読み込まれない可能性があります:
var renderer = new ChromePdfRenderer();
renderer.RenderingOptions.WaitFor.RenderDelay(2000); // Wait 2 seconds
// Or wait for specific element:
renderer.RenderingOptions.WaitFor.HtmlElementById("content-loaded");
var renderer = new ChromePdfRenderer();
renderer.RenderingOptions.WaitFor.RenderDelay(2000); // Wait 2 seconds
// Or wait for specific element:
renderer.RenderingOptions.WaitFor.HtmlElementById("content-loaded");
Dim renderer = New ChromePdfRenderer()
renderer.RenderingOptions.WaitFor.RenderDelay(2000) ' Wait 2 seconds
' Or wait for specific element:
renderer.RenderingOptions.WaitFor.HtmlElementById("content-loaded")
ヘッダー/フッターが表示されません
症状: TextHeader/TextFooter が出力に表示されません。
解決策:余白にヘッダー/フッターコンテンツのためのスペースを確保する:
var renderer = new ChromePdfRenderer();
renderer.RenderingOptions.MarginTop = 40; // mm - leave room for header
renderer.RenderingOptions.MarginBottom = 40; // mm - leave room for footer
renderer.RenderingOptions.TextHeader = new TextHeaderFooter
{
CenterText = "Header Text",
FontSize = 12
};
var renderer = new ChromePdfRenderer();
renderer.RenderingOptions.MarginTop = 40; // mm - leave room for header
renderer.RenderingOptions.MarginBottom = 40; // mm - leave room for footer
renderer.RenderingOptions.TextHeader = new TextHeaderFooter
{
CenterText = "Header Text",
FontSize = 12
};
Dim renderer = New ChromePdfRenderer()
renderer.RenderingOptions.MarginTop = 40 ' mm - leave room for header
renderer.RenderingOptions.MarginBottom = 40 ' mm - leave room for footer
renderer.RenderingOptions.TextHeader = New TextHeaderFooter With {
.CenterText = "Header Text",
.FontSize = 12
}
移行チェックリスト
移行前
grep -r "WebSupergoo" --include="*.cs" .を使用してすべての ABCpdf の使用状況を監査します- 現在のPDF出力要件を文書化する
- 比較のためにサンプルPDF出力を使用してテストケースを作成する
- IronPDFライセンスキーを取得する
- バックアップコードベース
移行について
- ABCpdf NuGetパッケージを削除する -IronPDFNuGetパッケージをインストールする
- アプリケーションの起動時にライセンスキーを追加する
- すべての
usingステートメントを更新します Docインスタンス化をChromePdfRendererに変換しますdoc.Clear()をusingステートメントに置き換えます- APIマッピングごとにメソッド呼び出しを更新
- 座標ベースのレイアウトをCSSマージンに変換する
移行後
- 既存のPDFテストをすべて実行
- PDF出力の視覚的な比較(ABCpdf vs IronPDF)
- ステージングですべてのPDFワークフローをテストする
- パフォーマンスベンチマーク比較
- ABCpdfライセンス設定を削除する
- CI/CDパイプラインの依存関係を更新する

