ImageMagick无权将PDF转换为图像

Moo*_*ter 31 python linux subprocess imagemagick

我有一个程序,我需要使用Image Magick将PDF转换为图像.我这样做是使用subprocess包:

        cmd = 'magick convert -density 300 '+pdfFile+'['+str(rangeTuple[0])+'-'+str(rangeTuple[1])+'] -depth 8 '+'temp.tiff' #WINDOWS
        if(os.path.isfile('temp.tiff')):
            os.remove('temp.tiff')
        subprocess.call(cmd,shell=True)
        im = Image.open('temp.tiff')
Run Code Online (Sandbox Code Playgroud)

我得到的错误是:

convert-im6.q16: not authorized `temp2.pdf' @ error/constitute.c/ReadImage/412.
convert-im6.q16: no images defined `temp.tiff' @ error/convert.c/ConvertImageCommand/3258.
Traceback (most recent call last):
  File "UKExtraction2.py", line 855, in <module>
    doItAllUpper("A0","UK5.csv","temp",59,70,"box",2,1000,firstPageCoordsUK,boxCoordUK,voterBoxCoordUK,internalBoxNumberCoordUK,externalBoxNumberCoordUK,addListInfoUK)
  File "UKExtraction2.py", line 776, in doItAllUpper
    doItAll(tempPDFName,outputCSV,2,pdfs,formatType,n_blocks,writeBlockSize,firstPageCoords,boxCoord,voterBoxCoord,internalBoxNumberCoord,externalBoxNumberCoord,addListInfo,pdfName)
  File "UKExtraction2.py", line 617, in doItAll
    mainProcess(pdfName,(0,noOfPages-1),formatType,n_blocks,outputCSV,writeBlockSize,firstPageCoords,boxCoord,voterBoxCoord,internalBoxNumberCoord,externalBoxNumberCoord,addListInfo,bigPDFName,basePages)
  File "UKExtraction2.py", line 542, in mainProcess
    im = Image.open('temp.tiff')
  File "/home/rohit/.local/lib/python3.6/site-packages/PIL/Image.py", line 2609, in open
    fp = builtins.open(filename, "rb")
FileNotFoundError: [Errno 2] No such file or directory: 'temp.tiff'
Run Code Online (Sandbox Code Playgroud)

其中最重要的是:

convert-im6.q16: not authorized `temp2.pdf' @ error/constitute.c/ReadImage/412.
Run Code Online (Sandbox Code Playgroud)

我认为这是因为ImageMagick无权访问PDF.现在该怎么办?我在Linux服务器上.任何帮助表示赞赏.

fmw*_*w42 48

emcconville是对的.更具体地说,编辑Imagemagick policy.xml文件以取消注释该行:

  <!-- <policy domain="module" rights="none" pattern="{PS,PDF,XPS}" /> -->
Run Code Online (Sandbox Code Playgroud)


并将其从rights ="none"更改为rights ="read | write"

  <policy domain="module" rights="read|write" pattern="{PS,PDF,XPS}" />
Run Code Online (Sandbox Code Playgroud)


由于Ghostscript代表中发现了安全漏洞,我认为这是对policy.xml文件的最新补充.我认为这个漏洞现在已经修复了当前版本的Ghostscript,即9.25.

  • 在关于`/ etc/ImageMagick-6/policy.xml`的Ubuntu 18.04附近,我不得不将权限从none更改为`domain ="coder"rights ="read | write"pattern ="PDF"`. (11认同)
  • 在Mac Homebrew上我不得不从`<policy domain ="coder"rights ="none"pattern ="{EPS,PS2,PS3,PS,PDF,XPS}"中删除PDF"/> (3认同)

Mat*_* J. 9

我正在使用 Dockerfile 更新图像,突然间我遇到了 policy.xml 文件。虽然 Ubuntu (xenial) 的版本和 ImageMagick 是一样的。

我最终删除了导致我的问题的单行。

RUN sed -i 's/^.*policy.*coder.*none.*PDF.*//' /etc/ImageMagick-6/policy.xml

希望这有助于某人

  • 谢谢你,这正是我需要的修复! (2认同)

Jar*_*ček 6

快速简便的解决方案:

sudo mv /etc/ImageMagick-6/policy.xml /etc/ImageMagick-6/policy.xml.off
Run Code Online (Sandbox Code Playgroud)

完成后,您可以使用

sudo mv /etc/ImageMagick-6/policy.xml.off /etc/ImageMagick-6/policy.xml
Run Code Online (Sandbox Code Playgroud)

  • 这很好用。谢谢。但是,我建议用“mv”替换“rm”,并尝试编辑您的答案。 (4认同)