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

  • 相关阅读:
    hbase二级索引学习
    redis-cluster集群Mac部署
    http-flume-kafka.conf
    linux 替换文件中的字符串
    flumeDemo
    redis_exporter监控安装
    Hbase内存磁盘大致关系
    spring cloud 尚硅谷学习
    C10K问题
    navicat 远程链接Mysql问题
  • 原文地址:https://www.cnblogs.com/camg/p/16294769.html
Copyright © 2020-2023  润新知