C#でRotativaからIronPDFに移行する方法
RotativaからIronPDFへの移行:完全なC#移行ガイド
RotativaからIronPDFへの移行は、PDF生成のワークフローを近代化すると同時に、重要なセキュリティの脆弱性に対処します。 このガイドは、放棄されたwkhtmltopdf依存性を排除し、最新のCSSとJavaScriptのサポートを可能にし、ASP.NET MVCを超えるクロスプラットフォームの互換性を提供する、完全で段階的な移行パスを提供します。
なぜRotativaからIronPDFへ移行するのか
Rotativaについて
Rotativaは、C#でPDFを生成するための開発者の間で長い間人気のある選択肢です。 wkhtmltopdfツールを活用し、HTMLコンテンツをPDF形式に変換します。 Rotativaは、ASP.NET MVCアプリケーションのために特別に設計されたオープンソースのライブラリです。 しかし、Rotativaは多くの読者を惹きつける一方で、時代遅れの技術スタックに依存しているため、すべての開発者がすぐに理解できるとは限らないという課題があります。
Rotativaは、ASP.NET MVCプロジェクトにPDF生成を統合する簡単な方法を提供し、そのバックエンド機能にはwkhtmltopdfを利用しています。
重要なセキュリティ勧告
Rotativaはwkhtmltopdfをラップしていますが、これはCRITICAL UNPATCHED SECURITY VULNERABILITIES.を持っています。
| 属性 | 価値 |
|---|---|
| CVE ID | CVE-2022-35583 |
| 厳しさ | クリティカル (9.8/10) |
| アタックベクター | ネットワーク |
| <ステータス | パッチが適用されることはありません |
| 影響を受ける言語 | すべてのRotativaバージョン |
wkhtmltopdfは、2022年12月に正式に放棄されました。メンテナンス担当者は、セキュリティの脆弱性を修正しないと明言しています。 Rotativaを使用するすべてのアプリケーションは、永久に公開されます。
攻撃の仕組み
<!-- Attacker submits this content via your MVC model -->
<iframe src="http://169.254.169.254/latest/meta-data/iam/security-credentials/"></iframe>
<img src="http://internal-database:5432/admin" /><!-- Attacker submits this content via your MVC model -->
<iframe src="http://169.254.169.254/latest/meta-data/iam/security-credentials/"></iframe>
<img src="http://internal-database:5432/admin" />インパクト:
- AWS/Azure/GCPクラウドメタデータエンドポイントへのアクセス
- 内部APIデータと認証情報を盗む
- 内部ネットワークのポートスキャン
- 機密設定の流出
テクノロジーの危機
Rotativaは、wkhtmltopdfをラップしています:
- Qt WebKit 4.8 (2012年から)
- Flexboxをサポートしていません
- CSSグリッドのサポートなし
- 壊れたJavaScriptの実行
- ES6+はサポートしません。
RotativaとIronPDFの比較
| フィーチャー | ロータティバ | IronPDF |
|---|---|---|
| プロジェクトの互換性 | ASP.NET MVCのみ | あらゆる.NETプロジェクトタイプ(MVC、Blazor Pages、Blazorなど) |
| メンテナンス | 中止 | 積極的にメンテナンス |
| セキュリティ。 | wkhtmltopdfの依存関係による脆弱性 (CVE-2022-35583) | 定期的なアップデートとセキュリティパッチ |
| HTMLレンダリング。 | 時代遅れのWebKit | モダンChromium |
| CSS3について | 部分的 | フルサポート |
| フレックスボックス/グリッド | サポートされていません | フルサポート |
| JavaScript(ジャバスクリプト | 信頼できない | 完全なES6 |
| レイザーページ | サポートされていません | フルサポート |
| Blazor。 | サポートされていません | フルサポート |
| PDF操作 | 不可 | フル |
| デジタル署名。 | 不可 | フル |
| PDF/Aコンプライアンス | 不可 | フル |
| 非同期/待機 | 同期のみ | 完全な非同期 |
| オープンソース。 | はい、MITライセンス | いいえ、商用ライセンス |
2025年と2026年まで.NET 10とC# 14の採用を計画しているチームにとって、IronPDFはRotativaでは提供できない最新のChromiumレンダリングとクロスプラットフォームのサポートを提供します。
始める前に
前提条件
1..NET環境: .NET Framework 4.6.2+ または .NET Core 3.1+ / .NET 5/6/7/8/9+. 2.NuGetアクセス:NuGetパッケージをインストールする能力。 3.IronPDFライセンス:ironPdf.comからライセンスキーを取得してください。
NuGetパッケージの変更
# Remove Rotativa
dotnet remove package Rotativa
dotnet remove package Rotativa.AspNetCore
# Install IronPDF
dotnet add package IronPdf# Remove Rotativa
dotnet remove package Rotativa
dotnet remove package Rotativa.AspNetCore
# Install IronPDF
dotnet add package IronPdfwkhtmltopdfバイナリの削除
プロジェクトからこれらのファイルを削除してください:
- <コード>wkhtmltopdf.exe</コード
- <コード>wkhtmltox.dll</コード
- すべての
Rotativa/<//code> フォルダー
これらはCVE-2022-35583のソースです。IronPDFはネイティブバイナリを必要としません。
ライセンス構成
// Add in Program.cs or Startup.cs
IronPdf.License.LicenseKey = "YOUR-LICENSE-KEY";// Add in Program.cs or Startup.cs
IronPdf.License.LicenseKey = "YOUR-LICENSE-KEY";IRON VB CONVERTER ERROR developers@ironsoftware.com完全な API リファレンス
名前空間の変更
// Before: Rotativa
using Rotativa;
using Rotativa.Options;
using Rotativa.AspNetCore;
// After: IronPDF
using IronPdf;
using IronPdf.Rendering;// Before: Rotativa
using Rotativa;
using Rotativa.Options;
using Rotativa.AspNetCore;
// After: IronPDF
using IronPdf;
using IronPdf.Rendering;IRON VB CONVERTER ERROR developers@ironsoftware.comコア クラス マッピング
| Rotativa クラス | IronPDF 同等物 | ノート |
|---|---|---|
| <コード>ViewAsPdf</コード | <コード>ChromePdfRenderer</コード | HTMLのレンダリング |
| <コード>ActionAsPdf</コード | ChromePdfRenderer.RenderUrlAsPdf()のようにします。 | レンダリングURL |
| <コード>UrlAsPdf</コード | ChromePdfRenderer.RenderUrlAsPdf()のようにします。 | レンダリングURL |
オリエンテーション enum | PdfPaperOrientation列挙型 | オリエンテーション |
サイズ列挙型 | PdfPaperSize列挙型 | 用紙サイズ |
ページのプレースホルダーの変換
| Rotativa プレースホルダ | IronPDF プレースホルダー |
|---|---|
| <コード>[ページ]</コード | <コード>{ページ}</コード |
| <コード>[トップページ]</コード | <コード>{総ページ数}</コード |
| <コード>[日付]</コード | {date}<//code> |
| <コード>[時間]</コード | <コード>{時間}</コード |
| <コード>[タイトル]</コード | {html-title}<//code> |
| <コード>[サイトページ]</コード | {url}<//code> |
コード移行の例
例1: HTMLからPDFへの変換
翻訳前(Rotativa):
// NuGet: Install-Package Rotativa.Core
using Microsoft.AspNetCore.Mvc;
using Rotativa.AspNetCore;
using System.Threading.Tasks;
namespace RotativaExample
{
public class PdfController : Controller
{
public async Task<IActionResult> GeneratePdf()
{
var htmlContent = "<h1>Hello World</h1><p>This is a PDF document.</p>";
//ロータティバrequires returning a ViewAsPdf result from MVC controller
return new ViewAsPdf()
{
ViewName = "PdfView",
PageSize = Rotativa.AspNetCore.Options.Size.A4
};
}
}
}// NuGet: Install-Package Rotativa.Core
using Microsoft.AspNetCore.Mvc;
using Rotativa.AspNetCore;
using System.Threading.Tasks;
namespace RotativaExample
{
public class PdfController : Controller
{
public async Task<IActionResult> GeneratePdf()
{
var htmlContent = "<h1>Hello World</h1><p>This is a PDF document.</p>";
//ロータティバrequires returning a ViewAsPdf result from MVC controller
return new ViewAsPdf()
{
ViewName = "PdfView",
PageSize = Rotativa.AspNetCore.Options.Size.A4
};
}
}
}IRON VB CONVERTER ERROR developers@ironsoftware.com翻訳後(IronPDF):。
// NuGet: Install-Package IronPdf
using IronPdf;
using System;
namespace IronPdfExample
{
class Program
{
static void Main(string[] args)
{
var renderer = new ChromePdfRenderer();
var htmlContent = "<h1>Hello World</h1><p>This is a PDF document.</p>";
var pdf = renderer.RenderHtmlAsPdf(htmlContent);
pdf.SaveAs("output.pdf");
Console.WriteLine("PDF generated successfully!");
}
}
}// NuGet: Install-Package IronPdf
using IronPdf;
using System;
namespace IronPdfExample
{
class Program
{
static void Main(string[] args)
{
var renderer = new ChromePdfRenderer();
var htmlContent = "<h1>Hello World</h1><p>This is a PDF document.</p>";
var pdf = renderer.RenderHtmlAsPdf(htmlContent);
pdf.SaveAs("output.pdf");
Console.WriteLine("PDF generated successfully!");
}
}
}IRON VB CONVERTER ERROR developers@ironsoftware.comこの例は、基本的なアーキテクチャの違いを示しています。 Rotativaは、MVCコントローラのアクションからViewAsPdfの結果を返す必要があり、ASP.NET MVCフレームワークと結びついています。 このパターンはMVCリクエストパイプライン内でのみ動作し、レンダリングにはRazorビューが必要です。
IronPDFはコンソールアプリケーション、ウェブAPI、Blazor、Razor Pages、.NETプロジェクトのどのタイプでも動作します。 HTML文字列でRenderHtmlAsPdf()を呼び出し、結果を保存します。 MVCコントローラ不要、ビュー依存なし。 包括的な例については、HTML to PDF documentationを参照してください。
例2: URLからPDFへの変換
翻訳前(Rotativa):
// NuGet: Install-Package Rotativa.Core
using Microsoft.AspNetCore.Mvc;
using Rotativa.AspNetCore;
using System.Threading.Tasks;
namespace RotativaExample
{
public class UrlPdfController : Controller
{
public async Task<IActionResult> ConvertUrlToPdf()
{
//ロータティバworks within MVC framework and returns ActionResult
return new UrlAsPdf("https://www.example.com")
{
FileName = "webpage.pdf",
PageSize = Rotativa.AspNetCore.Options.Size.A4,
PageOrientation = Rotativa.AspNetCore.Options.Orientation.Portrait
};
}
}
}// NuGet: Install-Package Rotativa.Core
using Microsoft.AspNetCore.Mvc;
using Rotativa.AspNetCore;
using System.Threading.Tasks;
namespace RotativaExample
{
public class UrlPdfController : Controller
{
public async Task<IActionResult> ConvertUrlToPdf()
{
//ロータティバworks within MVC framework and returns ActionResult
return new UrlAsPdf("https://www.example.com")
{
FileName = "webpage.pdf",
PageSize = Rotativa.AspNetCore.Options.Size.A4,
PageOrientation = Rotativa.AspNetCore.Options.Orientation.Portrait
};
}
}
}IRON VB CONVERTER ERROR developers@ironsoftware.com翻訳後(IronPDF):。
// NuGet: Install-Package IronPdf
using IronPdf;
using System;
namespace IronPdfExample
{
class Program
{
static void Main(string[] args)
{
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderUrlAsPdf("https://www.example.com");
pdf.SaveAs("webpage.pdf");
Console.WriteLine("URL converted to PDF successfully!");
}
}
}// NuGet: Install-Package IronPdf
using IronPdf;
using System;
namespace IronPdfExample
{
class Program
{
static void Main(string[] args)
{
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderUrlAsPdf("https://www.example.com");
pdf.SaveAs("webpage.pdf");
Console.WriteLine("URL converted to PDF successfully!");
}
}
}IRON VB CONVERTER ERROR developers@ironsoftware.comRotativaのUrlAsPdfクラスは、MVCコントローラからActionResultを返す必要があります。 IronPDFのRenderUrlAsPdf()メソッドはどのようなコンテキストからでも呼び出すことができ、PdfDocumentオブジェクトを直接返します。 URLレンダリングには、wkhtmltopdfの脆弱で時代遅れのWebKitエンジンではなく、最新のChromiumを使用しています。詳しくはチュートリアルをご覧ください。
例3:ページ番号を含むヘッダーとフッター
翻訳前(Rotativa):
// NuGet: Install-Package Rotativa.Core
using Microsoft.AspNetCore.Mvc;
using Rotativa.AspNetCore;
using Rotativa.AspNetCore.Options;
using System.Threading.Tasks;
namespace RotativaExample
{
public class HeaderFooterController : Controller
{
public async Task<IActionResult> GeneratePdfWithHeaderFooter()
{
return new ViewAsPdf("Report")
{
PageSize = Size.A4,
PageMargins = new Margins(20, 10, 20, 10),
CustomSwitches = "--header-center \"Page Header\" --footer-center \"Page [page] of [toPage]\""
};
}
}
}// NuGet: Install-Package Rotativa.Core
using Microsoft.AspNetCore.Mvc;
using Rotativa.AspNetCore;
using Rotativa.AspNetCore.Options;
using System.Threading.Tasks;
namespace RotativaExample
{
public class HeaderFooterController : Controller
{
public async Task<IActionResult> GeneratePdfWithHeaderFooter()
{
return new ViewAsPdf("Report")
{
PageSize = Size.A4,
PageMargins = new Margins(20, 10, 20, 10),
CustomSwitches = "--header-center \"Page Header\" --footer-center \"Page [page] of [toPage]\""
};
}
}
}IRON VB CONVERTER ERROR developers@ironsoftware.com翻訳後(IronPDF):。
// NuGet: Install-Package IronPdf
using IronPdf;
using IronPdf.Rendering;
using System;
namespace IronPdfExample
{
class Program
{
static void Main(string[] args)
{
var renderer = new ChromePdfRenderer();
renderer.RenderingOptions.TextHeader = new TextHeaderFooter()
{
CenterText = "Page Header",
DrawDividerLine = true
};
renderer.RenderingOptions.TextFooter = new TextHeaderFooter()
{
CenterText = "Page {page} of {total-pages}",
DrawDividerLine = true
};
var htmlContent = "<h1>Report Title</h1><p>Report content goes here.</p>";
var pdf = renderer.RenderHtmlAsPdf(htmlContent);
pdf.SaveAs("report.pdf");
Console.WriteLine("PDF with headers and footers created successfully!");
}
}
}// NuGet: Install-Package IronPdf
using IronPdf;
using IronPdf.Rendering;
using System;
namespace IronPdfExample
{
class Program
{
static void Main(string[] args)
{
var renderer = new ChromePdfRenderer();
renderer.RenderingOptions.TextHeader = new TextHeaderFooter()
{
CenterText = "Page Header",
DrawDividerLine = true
};
renderer.RenderingOptions.TextFooter = new TextHeaderFooter()
{
CenterText = "Page {page} of {total-pages}",
DrawDividerLine = true
};
var htmlContent = "<h1>Report Title</h1><p>Report content goes here.</p>";
var pdf = renderer.RenderHtmlAsPdf(htmlContent);
pdf.SaveAs("report.pdf");
Console.WriteLine("PDF with headers and footers created successfully!");
}
}
}IRON VB CONVERTER ERROR developers@ironsoftware.comRotativaは、[page]や[toPage]のようなプレースホルダーによるヘッダーやフッターの設定を含め、CustomSwitches<//code>を使ってコマンドライン引数をwkhtmltopdfに渡します。 この文字列ベースのアプローチは、エラーが発生しやすく、コンパイル時に検証するのが困難です。
IronPDFはCenterTextやDrawDividerLineのようなプロパティを持つ強い型付けのTextHeaderFooterオブジェクトを使用します。 プレースホルダの構文は、[page]から{page}に、[toPage]から{total-pages}に変更されます。 型付きプロパティはインテリセンス、コンパイル時チェックを提供し、タイプミスのリスクはありません。
MVCのみのアーキテクチャ問題
Rotativaは、ASP.NET MVC 5以前向けに設計されています:
// ❌ロータティバ- Only works with classic MVC pattern
public class InvoiceController : Controller
{
public ActionResult InvoicePdf(int id)
{
var model = GetInvoice(id);
return new ViewAsPdf("Invoice", model); // Tied to MVC Views
}
}
// Problems:
// - No Razor Pages support
// - No Blazor support
// - No minimal APIs support
// - No ASP.NET Core native integration// ❌ロータティバ- Only works with classic MVC pattern
public class InvoiceController : Controller
{
public ActionResult InvoicePdf(int id)
{
var model = GetInvoice(id);
return new ViewAsPdf("Invoice", model); // Tied to MVC Views
}
}
// Problems:
// - No Razor Pages support
// - No Blazor support
// - No minimal APIs support
// - No ASP.NET Core native integrationIRON VB CONVERTER ERROR developers@ironsoftware.comIronPdfはビューのレンダリングとPDFの生成を分離しており、MVCビューだけでなくあらゆるHTMLをレンダリングすることができます。
非同期パターンの移行
Rotativa はスレッドをブロックします; IronPdfは完全なasync/awaitをサポートしています:
// ❌ロータティバ- Blocks the thread
public ActionResult GeneratePdf()
{
return new ViewAsPdf("Report");
// This blocks the request thread until PDF is complete
// Poor scalability under load
}
// ✅IronPDF-完全な非同期support
public async Task<IActionResult> GeneratePdf()
{
var renderer = new ChromePdfRenderer();
var pdf = await renderer.RenderHtmlAsPdfAsync(html);
return File(pdf.BinaryData, "application/pdf");
// Non-blocking, better scalability
}// ❌ロータティバ- Blocks the thread
public ActionResult GeneratePdf()
{
return new ViewAsPdf("Report");
// This blocks the request thread until PDF is complete
// Poor scalability under load
}
// ✅IronPDF-完全な非同期support
public async Task<IActionResult> GeneratePdf()
{
var renderer = new ChromePdfRenderer();
var pdf = await renderer.RenderHtmlAsPdfAsync(html);
return File(pdf.BinaryData, "application/pdf");
// Non-blocking, better scalability
}IRON VB CONVERTER ERROR developers@ironsoftware.com移行後の新機能
IronPDFに移行した後、Rotativaでは提供できない機能を得ることができます:
PDFマージ
var merged = PdfDocument.Merge(pdf1, pdf2, pdf3);
merged.SaveAs("complete.pdf");var merged = PdfDocument.Merge(pdf1, pdf2, pdf3);
merged.SaveAs("complete.pdf");IRON VB CONVERTER ERROR developers@ironsoftware.comデジタル署名
var signature = new PdfSignature("certificate.pfx", "password");
pdf.Sign(signature);var signature = new PdfSignature("certificate.pfx", "password");
pdf.Sign(signature);IRON VB CONVERTER ERROR developers@ironsoftware.comパスワード保護
pdf.SecuritySettings.UserPassword = "secret";pdf.SecuritySettings.UserPassword = "secret";IRON VB CONVERTER ERROR developers@ironsoftware.comウォーターマーク
pdf.ApplyWatermark("<h1 style='color:red; opacity:0.3;'>DRAFT</h1>");pdf.ApplyWatermark("<h1 style='color:red; opacity:0.3;'>DRAFT</h1>");IRON VB CONVERTER ERROR developers@ironsoftware.comPDF/Aアーカイブ準拠
pdf.SaveAsPdfA("archive.pdf", PdfAVersions.PdfA3b);pdf.SaveAsPdfA("archive.pdf", PdfAVersions.PdfA3b);IRON VB CONVERTER ERROR developers@ironsoftware.com最新の CSS サポート
// This now works (broke in Rotativa)
var html = @"
<div style='display: flex; justify-content: space-between;'>
<div>Left</div>
<div>Right</div>
</div>
<div style='display: grid; grid-template-columns: 1fr 1fr 1fr;'>
<div>Col 1</div><div>Col 2</div><div>Col 3</div>
</div>";
var pdf = renderer.RenderHtmlAsPdf(html); // Works!// This now works (broke in Rotativa)
var html = @"
<div style='display: flex; justify-content: space-between;'>
<div>Left</div>
<div>Right</div>
</div>
<div style='display: grid; grid-template-columns: 1fr 1fr 1fr;'>
<div>Col 1</div><div>Col 2</div><div>Col 3</div>
</div>";
var pdf = renderer.RenderHtmlAsPdf(html); // Works!IRON VB CONVERTER ERROR developers@ironsoftware.com移行チェックリスト
移行前
- [コードベース内のすべてのロータティバの使用法を特定する。
- [ ] Document CustomSwitchesは、RenderingOptionsへの変換に使用されます。
- [
[page]→{page})。 - [ironpdf.comからIronPDFライセンスキーを入手してください。
パッケージの変更
- [ ]
RotativaとRotativa.AspNetCoreNuGetパッケージを削除する。 - [ ]wkhtmltopdfバイナリ(
wkhtmltopdf.exe、wkhtmltox.dll)を削除する。 - [ ]
IronPdfNuGetパッケージをインストールしてください。
コードの変更
- [ ] 名前空間のインポートを更新する (
using Rotativa;→using IronPdf;) - [
ViewAsPdfを<コード>ChromePdfRenderer</コード+RenderHtmlAsPdf()に置き換えてください。 - [ ]
UrlAsPdfをRenderUrlAsPdf()に置き換えてください。 - [ ]
CustomSwitchesをRenderingOptionsプロパティに変換してください。 - [ ] プレースホルダーの構文を更新 (
[page]→{page},<コード>[トップページ]</コード→{total-pages}) - [ ]
PageMarginsを個々のMarginTop/MarginBottom/MarginLeft/MarginRightに置き換えてください。 - [適宜、asyncパターンに変更してください。
- [アプリケーション起動時のライセンス初期化機能の追加
移行後
- [すべての PDF 生成が正しく動作することを確認してください。
- [PDF出力品質の比較(Chromiumの方が正確にレンダリングされる)
- [ ] CSSレンダリングの改善を確認する(Flexbox/Gridが動作するようになった)
- [JavaScript の実行をテストする(Chromium で信頼できるようになりました)。
- [ ] セキュリティ・スキャンがパスしたことを確認する(CVE-2022-35583 フラグがなくなったこと)。
- [ ] Docker設定を更新してwkhtmltopdfのインストールを削除する
結論
Rotativaはこれまで、ASP.NET MVCアプリケーションでPDFを生成するための簡単なソリューションを提供してきましたが、時代遅れの技術スタックに依存し、メンテナンスの面で放棄されていることが大きな課題となっています。 重大なセキュリティ脆弱性CVE-2022-35583は、パッチが適用されることはなく、すべてのRotativaアプリケーションが永久に暴露されます。
この移行における主な変更点は以下のとおりです: 1.セキュリティ:クリティカルな SSRF の脆弱性 (CVE-2022-35583) → 保護されています。 2.アーキテクチャ:MVCのみ → 任意の.NETプロジェクトタイプ 3.レンダリングエンジン:時代遅れの WebKit (2012) → 最新の Chromium 4.CSSサポート:部分的(Flexbox/Gridなし) → 完全なCSS3サポート 5.JavaScript:信頼できない → ES6+をフルサポート 6.パターン:ViewAsPdf return type →<コード>ChromePdfRenderer</コード+ RenderHtmlAsPdf(). 7.URLレンダリング:UrlAsPdf → RenderUrlAsPdf() です。 8.ヘッダー/フッター:CustomSwitches 文字列 → 型付き TextHeaderFooter オブジェクト 9.プレースホルダ:[page],<コード>[トップページ]</コード→ {page}, {total-pages}。 10.非同期サポート: 同期のみ → 完全な非同期/待機 11.メンテナンス:放置 → 毎週更新
多様な.NETアプリケーションにまたがる多機能で安全なPDF生成に関心のある開発者は、IronPDFがより説得力のある選択肢であることに気づくでしょう。IronPDFは幅広いアプリケーションとの互換性を保証するだけでなく、継続的なサポートとアップデートも提供します。
IronPDFドキュメント、チュートリアル、APIリファレンスをご覧いただき、Rotativaへの移行を加速させてください。






