微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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库扩展就好了。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐