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接口报错:Unable to init from given binary data

 

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

原创文章,作者:bd101bd101,如若转载,请注明出处:https://blog.ytso.com/tech/php/272270.html

(0)
上一篇 2022年7月9日 03:50
下一篇 2022年7月9日 03:50

相关推荐

发表回复

登录后才能评论