我有一个程序,需要使用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服务器上。感谢您的帮助。

评论

请查看文档中的安全策略。您需要通过编辑policy.xml文件来启用支持。

PHP ImagickException的可能重复:未经授权

它看起来像是临时补丁来防御此安全漏洞:bugs.gentoo.org/664236,因此它应在某个时候“消失”并再次“正常工作”。同时,您可以选择无法对某些格式使用imagemagick或存在漏洞(通过遵循以下建议可以得到此漏洞)。

还有一件事,如果可能的话,人们应该研究直接使用GhostScript而不是ImageMagick,因为它可以完成PDF转换的同一任务,比IM快得多。

参见stackoverflow.com/questions/52861946/…

#1 楼

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

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



并将其从rights =“ none”更改为rights =“ read |我相信,由于Ghostscript委托中发现了安全漏洞,我认为这是对policy.xml文件的最新添加。我认为该缺陷已在Ghostscript的当前版本9.25中得到修复。

注意:在某些系统上,策略行将使用domain =“ coder”而不是domain =“ module”

评论


在Mac Homebrew上,我必须从中删除PDF

– OneCricketeer
18-10-26在7:37



你为什么要这么做?取消注释并将权限更改为“读|写”是否不起作用?

–fmw42
18-10-30在1:09

我没有像您这样的评论专栏。我在整个文件中搜索了PDF,它在我提到的那一行中

– OneCricketeer
18-10-30在3:43

这应该起作用了。 。注意我将domain =“ coder”更改为domain =“ module”。也许Homebrew用错误的术语将其错误编码了?

–fmw42
18-10-30在3:53



在即将结束的/etc/ImageMagick-6/policy.xml上的Ubuntu 18.04上,我不得不将权限从无更改为domain =“ coder” rights =“ read | write” pattern =“ PDF”。

–巴勃罗·比安奇(Pablo Bianchi)
18/12/10在21:37

#2 楼

快速简便的解决方案:

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

恢复原始文件

评论


这很好。谢谢。但是,我建议用mv代替rm,并将尝试编辑答案。

– mivk
19/09/17在14:52

这个MV出来再回来的解决方案很棒!我现在在涉及pdf文件的脚本中的所有众多转换命令周围使用此撤消还原。绝望后再次可靠。谢谢!

–罗伯·鲁滕
11月7日20:18

#3 楼

我正在使用Dockerfile更新映像,突然我以自己的方式得到了policy.xml文件。尽管Ubuntu(xenial)的版本与ImageMagick的版本相同。

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

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

希望这对某人有帮助

评论


谢谢,这是我需要的确切解决方法!

–justcompile
7月31日10:51

#4 楼

使用以下命令删除策略文件以对其进行修复,如果需要,您也可以备份此策略文件。

rm /etc/<ImageMagick_PATH>/policy.xml


对我来说,这是ImageMagick6和命令原为:

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


评论


有点过分。

– reinierpost
3月5日21:03