web-dev-qa-db-fra.com

ImageMagick n'est pas autorisé à convertir PDF en image

J'ai un programme dans lequel j'ai besoin de convertir un PDF en une image à l'aide de Image Magick. Je le fais en utilisant le paquetage 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')

L'erreur que j'ai eu est:

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'

Le plus important est:

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

Je pense que c'est parce qu'ImageMagick n'est pas autorisé à accéder au PDF. Que devrait-on faire maintenant? Je suis sur un serveur Linux. Toute aide est appréciée.

28
Mooncrater

emcconville est correct. Éditez plus précisément le fichier policy.xml d’Imagemagick pour décommenter cette ligne:

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


Et passez de rights = "none" à rights = "read | write"

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


Il s’agissait d’un ajout récent au fichier policy.xml, je crois, en raison d’une faille de sécurité trouvée dans le délégué Ghostscript. Je pense que cette faille a maintenant été corrigée dans la version actuelle de Ghostscript, à savoir 9.25.

REMARQUE: Sur certains systèmes, la ligne de politique aura domain = "coder" plutôt que domain = "module".

47
fmw42

Solution rapide et facile:

$ Sudo rm /etc/ImageMagick-6/policy.xml
0
Jarda Pavlíček