System.Drawing.Com/mon 的替代方案(.NET 7 及非 Windows 環境)

This article was translated from English: Does it need improvement?
Translated
View the article in English

自 .NET 6 起,Microsoft 已停止在 Linux 和 macOS 上支援 System.Drawing.Com/mon。 此函式庫現僅支援 Windows 系統。 更多詳細資訊,請參閱官方文件

解決"System.Drawing.Com/mon 無法在此平台上使用"錯誤的替代方案

.NET 6

在非 Windows 作業系統上,會拋出 TypeInitializationException 異常,並以 PlatformNotSupportedException 作為內部異常。 平台分析器會針對非 Windows 平台發出編譯時警告。 除非您設定了配置選項,否則系統會拋出以下執行時例外:

System.TypeInitializationException:'Gdip' 的類型初始化程式拋出了例外。

    ---- System.PlatformNotSupportedException : System.Drawing.Com/mon 在非 Windows 平台上不受支援。

.NET 6 中的臨時解決方案:

請在 runtimeconfig.json 檔案中,將 System.Drawing.EnableUnixSupport 執行階段設定開關設為 true,以啟用對非 Windows 平台的支援:

{
    "runtimeOptions": {
        "configProperties": {
            "System.Drawing.EnableUnixSupport": true
        }
    }
}

此外,請在程式碼開頭加入以下這行,以透過程式化方式啟用此設定:

// Enable System.Drawing.Com/mon support on non-Windows platforms in .NET 6
System.AppContext.SetSwitch("System.Drawing.EnableUnixSupport", true);
// Enable System.Drawing.Com/mon support on non-Windows platforms in .NET 6
System.AppContext.SetSwitch("System.Drawing.EnableUnixSupport", true);
' Enable System.Drawing.Common support on non-Windows platforms in .NET 6
System.AppContext.SetSwitch("System.Drawing.EnableUnixSupport", True)
$vbLabelText   $csharpLabel

.NET 7 及以上版本

自 .NET 7 起,微軟已完全移除了 Linux 和 macOS 平台上對 System.Drawing.Com/mon 的支援,包括先前可用的替代方案。

Iron Software 已發布一款名為 IronSoftware.Drawing 的 System.Drawing.Com/mon 開源替代方案。

如需進一步了解,請參閱官方文件

Curtis Chau
技術撰稿人

Curtis Chau 擁有卡爾頓大學(Carleton University)的電腦科學學士學位,專精於前端開發,並精通 Node.js、TypeScript、JavaScript 及 React。他熱衷於打造直觀且美觀的用戶介面,喜歡運用現代框架,並創建結構完善、視覺上吸引人的手冊。

除了開發工作之外,Curtis 對物聯網(IoT)抱有濃厚興趣,致力於探索整合硬體與軟體的創新方法。閒暇時,他喜歡玩遊戲和開發 Discord 機器人,將對科技的熱愛與創意相結合。

準備開始了嗎?
Nuget 下載 19,014,616 | 版本: 2026.5 just released
Still Scrolling Icon

還在往下捲動嗎?

想要快速確認成果嗎? PM > Install-Package IronPdf
執行範例 觀看您的 HTML 轉為 PDF。