Nikocevic Stefan
Nikocevic Stefan

Reputation: 31

Updating WYSIWYG summernote content breaks the images

I am using summernote WYSIWYG editor and I don't have any trouble creating or viewing its content but I do get broken images when updating the content. As in not just a broken link but an image with 0 bytes gets saved.

When I try to update it I get the undefined offset 1 error because of the explode function, but when I tried to fix it I get the broken image problem.

Here's my text editor content parser:

/*
     * @param $content is request data from wysiwyg
     * @param $directory is where to save the images
     */
    public function parseTextEditorContent($content, $directory)
    {
        $dom = new \domdocument();
        $dom->loadHtml($content, LIBXML_HTML_NOIMPLIED | LIBXML_HTML_NODEFDTD);
        $images = $dom->getelementsbytagname('img');

        //loop over img elements, decode their base64 src and save them to public folder,
        //and then replace base64 src with stored image URL.
        foreach($images as $k => $img){
            $data = $img->getattribute('src');

            list($type, $data) = explode(';', $data);
            list(, $data)      = explode(',', $data);

            $data = base64_decode($data);
            $image_name= time().$k.'.png';
            $path = public_path().'/img/'.$directory.'/'.$image_name;
            $src = '/img/'.$directory.'/'.$image_name;

            file_put_contents($path, $data);

            $img->removeattribute('src');
            $img->setattribute('src', $src);
        }

        $content = $dom->savehtml();
        return $content;
    }

Also here's an example of my content sa a base64 string.

<p>Porro esse ipsa, ali.</p><p><img src="" data-filename="19598644_1899832350030685_6042892852142940235_n.jpg" style="width: 160px;"><br></p>

Upvotes: 1

Views: 804

Answers (2)

Balwinder Singh Sohi
Balwinder Singh Sohi

Reputation: 69

    $content=$Guide->input('MainContent');
    $dom = new \DomDocument('1.0', 'UTF-8');
    libxml_use_internal_errors(true);
    $dom->loadHtml($content);
    $images = $dom->getElementsByTagName('img');
    $bs64='base64';
    foreach ($images as $i => $img) {
            $data = $img->getAttribute('src');
            if (strpos($data,$bs64) == true)
             {
            $data = base64_decode(preg_replace('#^data:image/\w+;base64,#i', '', $data));
            $image_name = '/images/userguide/'. time() . $i . '.png';
            $path = public_path() . $image_name;
            file_put_contents($path, $data);
            $img->removeAttribute('src');
            $img->setAttribute('src', $image_name);
            }
            else
            {
                $image_name=$data;
                $img->setAttribute('src', $image_name);
            }
          }

    $content_save= $dom->saveHTML();

Upvotes: 1

Muhammed Musthafa KP
Muhammed Musthafa KP

Reputation: 53

You can check the image is base 64 or not ,inside the loop then update only if the image is Base64

 $editor_content=$request->editor_content;
$dom = new \DomDocument('1.0', 'UTF-8');
libxml_use_internal_errors(true);
$dom->loadHtml($editor_content);
$images = $dom->getElementsByTagName('img');
$bs64='base64';//variable to check the image is base64 or not
foreach ($images as $k => $img) {
        $data = $img->getAttribute('src');
        if (strpos($data,$bs64) == true)//if the Image is base 64
         {
        $data = base64_decode(preg_replace('#^data:image/\w+;base64,#i', '', $data));
        $image_name = "/storage/blog/". 'post_' . time() . $k . '.png';
        $path = public_path() . $image_name;
        file_put_contents($path, $data);
        $img->removeAttribute('src');
        $img->setAttribute('src', $image_name);
        }
        else//put '/' to prevent lossing image  actual path
        {
            $image_name="/".$data;
            $img->setAttribute('src', $image_name);
        }
      };
 
$editor_content_save= $dom->saveHTML();
// return $editor_content_save;
$slug = Str::slug($request->title,'-');
$blog = Blog::where('id', $request->blog_id)->first();
$blog->title = $request->title;
$blog->author = $request->author;
$blog->tags=collect($request->tags)->implode(',');
$blog->content = $editor_content_save;
$blog->slug = $slug;
$blog->date = $request->date;
$blog->save();

Upvotes: 2

Related Questions