dtkvlj5386 2019-03-20 21:15
浏览 818
已采纳

图像(Blob)在浏览器中只显示一次

I'm using Symfony2 and Twig:

In the Entity Class

/**
 * @ORM\Column(name="photo", type="blob", nullable=true)
 */
private $photo;

// ...

public function displayPhoto()
{
    return "data:image/png;base64," . base64_encode(stream_get_contents($this->getPhoto()));
}

In the view

<img src="{{ entity.displayPhoto }}">

But if I write

<img src="{{ entity.displayPhoto }}">
<img src="{{ entity.displayPhoto }}">

Then the browser display it only the first time. In the browser (Firefox) The DOM looks like this:

<img src="data:image/png;base64,/9j/4QS...//much more chars//...f7R+ooYz//Z">
<img src="data:image/png;base64,">

So the image content is not present in the second img tag.

Any idea how to show the image more than once?

  • 写回答

1条回答

  • douniao7308 2019-03-20 22:30
    关注

    You will need to either rewind your stream

    /**
     * @ORM\Column(name="photo", type="blob", nullable=true)
     */
    private $photo;
    
    public function displayPhoto()
    {
        rewind($this->getPhoto());
        return "data:image/png;base64," . base64_encode(stream_get_contents($this->getPhoto()));
    }
    

    Or maybe better for performance, have a property storing the raw content of the blob:

    /**
     * @ORM\Column(name="photo", type="blob", nullable=true)
     */
    private $photo;
    
    private $rawPhoto;
    
    public function displayPhoto()
    {
        if(null === $this->rawPhoto) {
            $this->rawPhoto = "data:image/png;base64," . base64_encode(stream_get_contents($this->getPhoto()));
        }
    
        return $this->rawPhoto;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 C++ yoloV5改写遇到的问题
  • ¥20 win11修改中文用户名路径
  • ¥15 win2012磁盘空间不足,c盘正常,d盘无法写入
  • ¥15 用土力学知识进行土坡稳定性分析与挡土墙设计
  • ¥70 PlayWright在Java上连接CDP关联本地Chrome启动失败,貌似是Windows端口转发问题
  • ¥15 帮我写一个c++工程
  • ¥30 Eclipse官网打不开,官网首页进不去,显示无法访问此页面,求解决方法
  • ¥15 关于smbclient 库的使用
  • ¥15 微信小程序协议怎么写
  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?