Python ImageMagick无权将PDF转换为图像
我有一个程序,在这个程序中,我需要使用image Magick将PDF转换为图像。我使用Python ImageMagick无权将PDF转换为图像,python,linux,subprocess,imagemagick,Python,Linux,Subprocess,Imagemagick,我有一个程序,在这个程序中,我需要使用image Magick将PDF转换为图像。我使用子流程包来实现这一点: cmd = 'magick convert -density 300 '+pdfFile+'['+str(rangeTuple[0])+'-'+str(rangeTuple[1])+'] -depth 8 '+'temp.tiff' #WINDOWS if(os.path.isfile('temp.tiff')): os.remo
子流程
包来实现这一点:
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'
我认为这是因为ImageMagick无权访问PDF。现在该怎么办?我在Linux服务器上。感谢您的帮助。emcconville是正确的。更具体地说,编辑Imagemagick policy.xml文件以取消对此行的注释:
<!-- <policy domain="module" rights="none" pattern="{PS,PDF,XPS}" /> -->
并将其从rights=“none”更改为rights=“read | write”
我相信这是policy.xml文件最近添加的一个文件,因为在Ghostscript委托中发现了一个安全缺陷。我认为这个缺陷现在已经在Ghostscript的当前版本(9.25)中修复
注意:在某些系统上,策略行将具有domain=“coder”而不是domain=“module”快速简便的解决方案:
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
使用以下命令删除策略文件以修复它,如果需要,还可以备份此策略文件
rm /etc/<ImageMagick_PATH>/policy.xml
我正在使用Dockerfile更新一个图像,突然我得到了policy.xml文件。虽然Ubuntu(xenial)的版本相同,但ImageMagick也一样 我最终删除了导致我的问题的单线
运行sed-i的/^.*policy.*coder.*none.*PDF.*/'/etc/ImageMagick-6/policy.xml
希望这对其他人有所帮助请查看文档中的内容。您需要通过编辑
policy.xml
文件来启用支持。该文件的可能副本看起来像是一个临时补丁,用于防范此安全漏洞:因此,它应该“消失”并在某个时候再次“工作”。同时,您可以选择无法对某些格式使用imagemagick,或者存在漏洞(您可以通过以下建议获得该漏洞)。还有一件事,如果可能,人们应该直接使用GhostScript,而不是imagemagick,因为它可以比IM更快地完成同样的PDF转换任务。在Mac Homebrew上,我必须从
中删除PDF,为什么要这样做?仅仅取消注释并将权限更改为“读写”不起作用吗?我没有像你那样的注释行。我在整个文件中搜索了PDF,它就在我提到的那一行,这应该是有效的<代码>。注意:我将domain=“coder”更改为domain=“module”。也许是自制软件把它错编码了?在Ubuntu18.04上的/etc/ImageMagick-6/policy.xml
快结束时,我不得不将权限从无更改为domain=“coder”rights=“read | write”pattern=“PDF”
。这非常有效。非常感谢。但是,我建议将rm
替换为mv
,并尝试编辑您的答案。此mv出入库解决方案非常棒!现在,我在涉及pdf文件的脚本中使用了大量的convert命令,并使用了这个undo restore。绝望之后,你又可以信赖了。谢谢这有点过激。谢谢你,这正是我需要的修复方法!
sudo mv /etc/ImageMagick-6/policy.xml.off /etc/ImageMagick-6/policy.xml
rm /etc/<ImageMagick_PATH>/policy.xml
sudo rm /etc/ImageMagick-6/policy.xml