我想创建一个验证码图片使用转换从ImageMagick。
我也这么做了,但是有一些问题。
在我的linux shell:
convert -background white -fill black -font FreeSerif-Bold -pointsize 36 label:'adfgh' ./test.png
错误是:
adfgh @ error/constitute.c/ReadImage/453
转换:缺少一个图像文件名。/test.png @
错误/ convert.c / ConvertImageCommand / 3015
我的ImageMagick:版本:6.7.2-7,我安装它yum install ImageMagick。
我笨。有什么建议吗?
我多次使用ImageMagic convert命令将*.tif文件转换为*.pdf文件。
我不知道为什么,但今天我开始收到以下错误:
convert: not authorized `a.pdf' @ error/constitute.c/WriteImage/1028.
发出命令后:
convert a.tif a.pdf
在阅读以上答案后,我编辑了文件/etc/ imagemagick -6/policy.xml
改了句台词:
policy domain="coder" rights="none" pattern="PDF"
to
policy domain="coder" rights="read|write" pattern="PDF"
现在一切正常。
我有“ImageMagick 6.8.9-9 Q16 x86_64 2018-09-28”
在Ubuntu 16.04.5 LTS上。
投票最高的答案(我没有足够的声誉在那里添加评论)建议注释掉MVG行,但请记住这一点:
CVE-2016-3714
ImageMagick supports ".svg/.mvg" files which means that attackers can
craft code in a scripting language, e.g. MSL (Magick Scripting
Language) and MVG (Magick Vector Graphics), upload it to a server
disguised as an image file and force the software to run malicious
commands on the server side as described above. For example adding the
following commands in a file and uploading it to a webserver that uses
a vulnerable ImageMagick version will result in running the command
"ls -la" on the server.
exploit.jpg:
push graphic-context viewbox 0 0 640 480 fill
'url(https://website.com/image.png"|ls "-la)' pop graphic-context
And
任何低于7.0.1-2或6.9.4-0的版本都有潜在的漏洞
受影响的各方应尽快升级到最新版本
ImageMagick版本。
源
注意:这个和其他答案中的解决方案涉及禁用用于修复任意代码执行漏洞的安全措施。例如,请看这个与ghostscript相关的公告和这个与ubuntu相关的公告。只有当要转换的输入来自可信来源时,才使用这些解决方案。
我使用ImageMagick在php (v.7.1)切片PDF文件的图像。
首先,我得到了如下错误:
异常类型:ImagickException
异常信息:未授权.....@错误/ constitute.c / ReadImage / 412
在/etc/ imagemagick -6/policy.xml中进行了一些更改后,我开始得到如下错误:
异常类型:ImagickException
异常信息:无法创建临时文件.....@ error/pdf.c/ReadPDFImage/465拒绝权限
我的解决办法:
文件/etc/ imagemagick -6/policy.xml(或/etc/ imagemagick /policy.xml)
注释行
<!——<policy domain="coder" rights="none" pattern="MVG" />——> .
改变行
<policy domain="coder" rights="none" pattern="PDF" />
来
<policy domain="coder" rights="read|write" pattern="PDF" />
添加一行
<policy domain="coder" rights="read|write" pattern="LABEL" />
然后重新启动web服务器(nginx, apache)。