将 PDF 转换为图像字节数组以保存到数据库

Convert PDF to Image Byte array to save to database

我想要完成的是允许我的用户上传 PDF。然后我会将其转换为图像并获取图像字节数组。以下是我目前所拥有的。

PdfDocumentProcessor pdfDocumentProcessor = new PdfDocumentProcessor();
using (MemoryStream ms = new MemoryStream(e.UploadedFile.FileBytes))
{

    pdfDocumentProcessor.LoadDocument(ms);

    for (int i = 1; i <= pdfDocumentProcessor.Document.Pages.Count; i++)
    {
        Bitmap image = pdfDocumentProcessor.CreateBitmap(i, 1000);

        try
        {
            image.Save(ms, System.Drawing.Imaging.ImageFormat.Bmp);
        }
        catch (Exception error)
        {
            string message = error.Message;
        }
 }

当我尝试将图像保存到内存流时出现错误“GDI+ 中发生一般错误”我相信这与我没有指定有关保存图片的路径,但我可能弄错了。

我想将PDF转为图片,然后获取图片的字节数组,保存到数据库中。我真的不想把图片保存到指定路径

PDFDocumentProcessor 是一个 DevExpress class,它可以提取 PDF 并且还会给我 PDF 的字节数组,但我似乎无法找到通过保存错误来检索图像字节数组的方法

感谢任何帮助,谢谢

此问题可能是由于您尝试重新使用保存输入文件字节的同一个 MemoryStream 引起的。您应该创建一个新的内存流来保存。

我无法访问 devexpress,但我获取了另一个与 https://www.nuget.org/packages/Leadtools.Pdf/ 关联的 Nuget 包并对其进行了测试,此代码可将 PDF 保存到 PNG 内存流:

using (var ms = new MemoryStream(fileBytes))
using (var codecs = new RasterCodecs())
{
   codecs.Options.Load.AllPages = true;
   using (var rasterImage = codecs.Load(ms))
   using (var outputStream = new MemoryStream())
      codecs.Save(rasterImage, outputStream, RasterImageFormat.Png, 0);
}