使用旧版本的 System.Drawing 和 IronOCR
.NET 4.6.1 到 .NET 4.8 项目内置了 System.Drawing 版本 4.0.0。此版本的 System.Drawing 已停止支持,并且可能包含易受攻击的代码。
尝试从System.Drawing.Image实例化OcrInput会抛出"IronOcr.Exceptions.IronOcrProductException: '无法将 Object [] 解析为有效的图像文件。'"。 这是因为 IronOcr 无法将System.Drawing.Image识别为有效的输入类型。
尝试指定图像输入类型,例如OcrInput(Image: image) ,将抛出"无法将 System.Drawing.Image 转换为 SixLabors.ImageSharp.Image"错误。
可能的解决方案
将System.Drawing.Common更新至 6.0.0 版本。旧版本的 System.Drawing 已停止支持,并且可能包含存在安全漏洞的代码。
- 使用SixLabors.ImageSharp版本 2.1.3。OcrInput 可以使用
SixLabors.ImageSharp.Image类型进行实例OcrInput。
using IronOcr;
using SixLabors.ImageSharp;
using SixLabors.ImageSharp.PixelFormats;
class Program
{
static void Main()
{
var Ocr = new IronTesseract();
// Load the image using SixLabors.ImageSharp
Image image = Image.Load<Rgba32>("image.jpg");
// Use the image as input for OCR
using (var Input = new OcrInput(image))
{
// Perform OCR on the input
var Result = Ocr.Read(Input);
// Print the recognized text
Console.WriteLine(Result.Text);
}
}
}using IronOcr;
using SixLabors.ImageSharp;
using SixLabors.ImageSharp.PixelFormats;
class Program
{
static void Main()
{
var Ocr = new IronTesseract();
// Load the image using SixLabors.ImageSharp
Image image = Image.Load<Rgba32>("image.jpg");
// Use the image as input for OCR
using (var Input = new OcrInput(image))
{
// Perform OCR on the input
var Result = Ocr.Read(Input);
// Print the recognized text
Console.WriteLine(Result.Text);
}
}
}- 上述代码初始化
IronTesseract实例,使用SixLabors.ImageSharp从文件中加载图像,然后使用 IronOCR 处理图像以提取文本。






