PHP View Picture From Base64 String - php

I am connecting to Active-Directory and getting the thumbnailPhoto attribute successfully.
I have stored the file in the DB using Base64 encoding which makes the result look like:
/9j/4AAQSkZJRgABAQEAYABgAAD/4RHoRXhpZgAATU0AKgAAAAgABQEyAAIAAAAUAA ...
(Full Base64 encoded string: http://pastebin.com/zn2wDEmd)
Using a simple Base64 Decoder and decoding the string into a binary file and rename that to jpeg and open with an image viewer (here: Irfan View) I get the correct picture - see yourself:
How do I achieve this through PHP - I have tried using:
<?php
$data = '/9j/4A...'; //The entire base64 string - gives an error in dreamweaver
$data = base64_decode($data);
$fileTmp = imagecreatefromstring($data);
$newImage = imagecreatefromjpeg($fileTmp);
if (!$newImage) {
echo("<img src=".$newImage."/>");
}
?>
I'm just getting a blank page!

Your problem is that imagecreatefromstring() doesn't return a file, but rather an image in memory that should be output with the correct headers.
$data = base64_decode($data);
// Create image resource from your data string
$imgdata = imagecreatefromstring($data);
if ($imgdata) {
// Send JPEG headers
header("Content-type: image/jpeg");
// Output the image data
imagejpeg($imgdata);
// Clean up the resource
imagedestroy($imgdata);
exit();
}

Related

Save Google Chart image to file

I'm using the Google Charts API to generate some charts and am using an ajax request to send that data to an endpoint that will save the image to disk for use in a PDF. However, I'm not sure how to get the image string into a PHP image resource.
It looks something like this (I'll snip a bunch of the code to save some room):
<?php
$data = '{"image_data":""}';
$decoded = json_decode($data, true);
$resource = imagecreatefromstring($decoded['image_data']);
var_dump($resource);
This throws a warning at the imagecreatefromstring step: Warning: imagecreatefromstring(): Data is not in a recognized format.
What's the right handler for that image format?
This is because your need to get rid of leading data:image/png;base64,
Also your base64 string looks corrupted . I did the following
<?php
$data = '{"image_data":""}';
$decoded = json_decode($data, true);
$final = base64_decode(preg_replace('#^data:image/\w+;base64,#i', '', $decoded['image_data']));
$im = imagecreatefromstring($final);
if ($im !== false) {
ob_clean();
header('Content-type: image/png');
imagesavealpha($im, true);
imagepng($im);
imagedestroy($im);
}
?>
working fiddle
http://phpfiddle.org/main/code/7u1t-yfbe

Imagecreatefromwebp(): WebP decode: fail to decode input data

I am trying to convert a webp file to JPEG using imagecreatefromwebp() but unfortunately, it throws me a warning: Warning: imagecreatefromwebp(): WebP decode: fail to decode input data.
Here's my code
$filename = dirname(__FILE__)."\\".$keyword."1.webp"; // $keyword = 'xyz';
$im = imagecreatefromwebp($filename);
// Convert it to a jpeg file with 100% quality
imagejpeg($im, './example.jpeg', 100);
imagedestroy($im);
Please help.
i am using this code, it works fine for me. Here $data contains the base64encoded data
$im = imagecreatefromwebp($data);
$imageResult = imagejpeg($im, $destinationPath . $fileName, 100);
imagedestroy($im);
The imagecreatefromwebp() function accepts either a valid file or URL. You can also pass the your binary data in that function. You can check the function definition and example here http://php.net/manual/en/function.imagecreatefromwebp.php

How to get file information before saving it

I have file contents which I am receiving from my form in string form (base64), and now before using file_put_contents() function to save the file, I wanna know the information related to it, like it's size and mimetypes and so on.
So the question is how to retrieve a file's information just by it's data(base 64 string)
For ex, let's say I have this string:-
Object {files: "…Fb+kScAm4BFwC6yGB/w9uNEwUj3EmdQAAAABJRU5ErkJggg==", text: "hi"}files: "…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"text: "hi"__proto__: Object
54:783
$encoded_data = 'iVBORw0KGgoAAAANSUhEUgAAAvwA…Fb+kScAm4BFwC6yGB/w9uNEwUj3EmdQAAAABJRU ....';
$size = strlen(base64_decode($encoded_data));
remember base64 encoding increases the original data in size by about 33%
Now we can write a function -
function getFileSize($base64string){
$bytes = strlen(base64_decode($base64string));
$roughsize = (((int)$bytes) / 1024.0)* 0.67;
return round($roughsize,2);
}
this function will return filesize in Kb.
Now to know the Mime Type you can use Fileinfo
$imgdata = base64_decode($encoded_data);
$f = finfo_open();
$mime_type = finfo_buffer($f, $imgdata, FILEINFO_MIME_TYPE);

Laravel 4 - unserialize(): Error at offset while save base64 image

I'm trying to upload base64 image to server.
I've already try many answers, but i always get the same errors.
Links that i tried
How to save a PNG image server-side, from a base64 data string
https://www.reddit.com/r/laravel/comments/39wclp/how_to_convert_an_base64_image_string_to_an_image/
Convert Base64 string to an image file?
This code below should work.
$image = base64_decode(Input::get('image_cropped'));
$image_name= 'file_name.png';
$path = public_path() . "/images/" . $image_name;
file_put_contents($path, $image);
If you inspect the form sent from request the image encoded starts with data:image/png;base64, so try with:
$img = explode(',', Input::get('image_cropped'));
$img_name = 'file_name.png';
file_put_contents(public_path().'/images/'.$img_name, base64_decode($img[1]));
This worked for me.

how to create a base64encoded string from image resource

I have sent a base64 encoded string via AJAX to PHP and created an image resource with imagecreatefromstring - all is fine.
Now I want to get the base64 encoded string after resizing te image, but i CANT find a function to get the base64encoded string.
Taken from http://www.php.net/manual/en/book.image.php#93393
$image = imagecreatefromstring($file);
// start buffering
ob_start();
imagepng($image);
$contents = ob_get_clean();
echo "<img src='data:image/png;base64,".base64_encode($contents)."' />";
imagedestroy($image);

Categories