ImageMagick no está autorizado a convertir PDF a una imagen
Tengo un programa en el que necesito convertir un PDF a una imagen usando Image Magick. Lo hago usando el subprocess
paquete:
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')
El error que me salió es:
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'
El más importante de los cuales es:
convert-im6.q16: not authorized `temp2.pdf' @ error/constitute.c/ReadImage/412.
Creo que esto se debe a que ImageMagick no está autorizado a acceder al PDF. ¿Qué debe hacerse ahora? Estoy en un servidor Linux. Se agradece cualquier ayuda.
Emconville tiene razón. Más específicamente, edite el archivo Imagemagick Policy.xml para descomentar esta línea:
<!-- <policy domain="module" rights="none" pattern="{PS,PDF,XPS}" /> -->
Y cámbielo de derechos="none" a derechos="leer|escribir"
<policy domain="module" rights="read|write" pattern="{PS,PDF,XPS}" />
Creo que esta fue una adición reciente al archivo Policy.xml debido a una falla de seguridad encontrada en el delegado de Ghostscript. Creo que ese defecto ya se ha solucionado en la versión actual de Ghostscript, que es la 9.25.
NOTA: En algunos sistemas, la línea de política tendrá dominio="codificador" en lugar de dominio="módulo"
Solución rápida y sencilla:
sudo mv /etc/ImageMagick-6/policy.xml /etc/ImageMagick-6/policy.xml.off
Cuando termine, puede restaurar el original con
sudo mv /etc/ImageMagick-6/policy.xml.off /etc/ImageMagick-6/policy.xml