linux ImageMagick无权将PDF转换为图像

e5nqia27  于 2023-01-20  发布在  Linux
关注(0)|答案(4)|浏览(169)

我有一个程序,需要使用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')

我得到的错误是:

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'

其中最重要的是:

convert-im6.q16: not authorized `temp2.pdf' @ error/constitute.c/ReadImage/412.

我想这是因为ImageMagick没有被授权访问PDF。现在该怎么办?我在Linux服务器上。任何帮助都是感激的。

wz3gfoph

wz3gfoph1#

emcconville是正确的。更具体地说,请编辑Imagemagick policy.xml文件以取消注解此行:

<!-- <policy domain="module" rights="none" pattern="{PS,PDF,XPS}" /> -->

并将其从权限=“none”更改为权限=“read|写上”

<policy domain="module" rights="read|write" pattern="{PS,PDF,XPS}" />

这是最近添加到policy.xml文件中的,我相信是由于在Ghostscript委托中发现了一个安全缺陷。我认为该缺陷现在已经在Ghostscript的当前版本(9.25)中得到了修复。
注意:在某些系统上,策略行将具有domain=“coder”,而不是domain=“module”

zlhcx6iw

zlhcx6iw2#

快速简便的解决方案:

sudo mv /etc/ImageMagick-6/policy.xml /etc/ImageMagick-6/policy.xml.off

完成后,您可以使用恢复原始文件

sudo mv /etc/ImageMagick-6/policy.xml.off /etc/ImageMagick-6/policy.xml
q1qsirdb

q1qsirdb3#

我正在使用Dockerfile更新一个映像,突然我得到了policy.xml文件,虽然Ubuntu(xenial)的版本是相同的,ImageMagick也是如此。
我最终删除了导致我的问题的单行。
RUN sed -i 's/^.*policy.*coder.*none.*PDF.*//' /etc/ImageMagick-6/policy.xml
希望这对某人有帮助

plicqrtu

plicqrtu4#

使用以下命令删除策略文件以修复它,如果需要,您还可以备份此策略文件。

rm /etc/<ImageMagick_PATH>/policy.xml

对我来说,它是ImageMagick6,命令是:

sudo rm /etc/ImageMagick-6/policy.xml

相关问题