Search code examples
phpbase64file-put-contents

Base64Decode to file - whats missing?


I have in base64 encoded string in a $_POST field $_POST['nimage'] if I echo it directly as the src value in an img tag, i see the image just fine in browser: echo "<img src='".$_POST['nimage']."'>";

Now, I'm obviously missing a step, because when I base64_decode the string and write it to a file locally on the server, an attempt to view the created file in browser states error:

"The image 'xxxx://myserversomewhere.com/images/img1.jpg' cannot be displayed because it contains errors"

My decode and file put are:

$file = base64_decode($_POST['nimage']);
file_put_contents('images/'. $_POST['imgname'], $file);

which results in images/img1.jpg on the local server. What am I doing wrong in the decode here? Although the base64 output doesn't appear to be URLencoded I have tried urldecode() on it first before base64_decode() just for safe measure with same results.

First few lines of the base64 encode is:




Solution

  • The data you're decoding has a data URI header attached:

    ...
    

    The header is use by the browser to identify the file type and encoding, but isn't part of the encoded data.

    Strip the header (data:image/jpeg;base64,) from the data and base64 decode the rest before writing it to a file: you should be good to go.

    $b64 = '...';
    $dat = explode(',' $b64);
    
    // element 1 of array from explode() contains B64-encoded data
    if (($fileData = base64_decode($dat[1])) === false) { 
       exit('Base64 decoding error.');
    }
    file_put_contents($someFileName, $fileData);
    

    NB: Check the return value of your call to base64_decode() for false and abort somehow with a message. It will trap any problems with the decoding process (like not removing the header!).