PHP接口报错:Unable to init from given binary data

前因:

  事情是这样的,前几天不是使用Laravel做了一个图片比对的功能么,因为需要安装Composer扩展,并且这个扩展的使用,需要开启PHP的GD库的扩展支持。

  所以本地以及都调试好了,于是今天就上线。然后问题就来了,上线后,请求测试方法,接口直接报 500了。

后果:

  因为是线上环境,所以没有开启 APP_DEBUG,所以任何错误都是直接 500,这个时候,只能靠猜了。

    猜测1:我认为是代码没有合到master上去,于是联系运维帮忙看了下,发现已经合上去了;

    猜测2:我认为是Composer扩展没有安装好,于是联系运维帮忙看了下,发现已经安装完毕了;

  经过上面的测试后,发现还是无法定位到问题所在,于是,让运维发了下 \storage\logs\laravel.log 日志文件,发现如下错误提示:

[2022-05-21 10:43:43] production.ERROR: Unable to init from given binary data. 
{"exception":"[object] (Intervention\\Image\\Exception\\NotReadableException(code: 0): Unable to init from given binary data. at /php/vendor/intervention/image/src/Intervention/Image/Gd/Decoder.php:131)
[stacktrace]
#0 /php/vendor/intervention/image/src/Intervention/Image/AbstractDecoder.php(82): Intervention\\Image\\Gd\\Decoder->initFromBinary()
#1 /php/vendor/intervention/image/src/Intervention/Image/AbstractDecoder.php(335): Intervention\\Image\\AbstractDecoder->initFromUrl()
#2 /php/vendor/intervention/image/src/Intervention/Image/AbstractDriver.php(66): Intervention\\Image\\AbstractDecoder->init()
#3 /php/vendor/intervention/image/src/Intervention/Image/ImageManager.php(54): Intervention\\Image\\AbstractDriver->init()
#4 /php/vendor/jenssegers/imagehash/src/ImageHash.php(35): Intervention\\Image\\ImageManager->make()

解决:

  Unable to init from given binary data

  无法从给定的二进制数据初始化,最开始,也很懵,但是看到第二行后面,有一个 Gd,意识到,可能是线上,运维PHP的扩展Gd库没有开好。

  于是,写了一个 echo phpinfo();提交了上去,打印输出一看。运维那狗日果然,没开好(上线的时候,给他说了,让运行下Composer指令,然后开启下PHP的Gd库扩展)。

 

   最后,线上开启了PHP的Gd库扩展就好了。

posted @ 2022-05-21 11:48  在斑马线上散布  阅读(697)  评论(0编辑  收藏  举报
夫人不言,言必有中。这是高级臣僚的一种可贵品质,言辞精炼,直抵要害。