transformar jpg img imagen decodificar data php image codeigniter save base64

decodificar - PHP: obtenga la decodificación de cadena de base64 img y guárdela como jpg(imagen vacía resultante)



svg to base64 (5)

hola, estoy enviando una cadena de imagen base64 a través de ajax a un script php que simplemente decodifica cadena y guarda contenido como archivo .jpg.

Pero el resultado es una imagen vacía.

como puede ser esto posible?

script php:

$uploadedPhotos = array(''photo_1'',''photo_2'',''photo_3'',''photo_4''); foreach ($uploadedPhotos as $file) { if($this->input->post(''photo_1'')){ $photoTemp = base64_decode($this->input->post(''photo_1'')); /*Set name of the photo for show in the form*/ $this->session->set_userdata(''upload_''.$file,''ant''); /*set time of the upload*/ if(!$this->session->userdata(''uploading_on_datetime'')){ $this->session->set_userdata(''uploading_on_datetime'',time()); } $datetime_upload = $this->session->userdata(''uploading_on_datetime'',true); /*create temp dir with time and user id*/ $new_dir = ''temp/user_''.$this->session->userdata(''user_id'',true).''_on_''.$datetime_upload.''/''; @mkdir($new_dir); /*move uploaded file with new name*/ @file_put_contents( $new_dir.$file.''.jpg'',$photoTemp); }

Para ajax está bien porque, echo $ photoTemp devuelve la cadena.

intenté var_dump(@file_put_contents( $new_dir.$file.''.jpg'',$photoTemp)); y devuelve bool(true) ya que la imagen se guarda pero no hay contenido en la imagen :( imagen vacía

para la imagen vacía quiero decir, el archivo se crea y se nombra, y tiene el mismo tamaño del contenido que paso a php, pero cuando trato de abrir esa imagen para obtener una vista previa dice: el archivo no se puede abrir porque el archivo está corrupto o dañado tipo de formato

de todos modos, este es el JS que toma la foto como base64 y la envía a php:

<script type="text/javascript"> var _min_width = 470; var _min_height = 330; var _which; var _fyle_type; var io; var allowed_types = new Array(''image/png'',''image/jpg'',''image/jpeg''); if (typeof(FileReader) === ''function''){ $(''input[type="file"]'').on(''change'', function(e) { var _file_name = $(this).val(); $(''.''+_which+''_holder'').text(_file_name); var file = e.target.files[0]; if (!in_array(file.type,allowed_types) || file.length === 0){ notify("You must select a valid image file!",false,false); return; } if(file.size > 3145728 /*3MB*/){ notify("<?php echo lang(''each-photo-1MB''); ?>",false,false); return; } notify_destroy(); var reader = new FileReader(); reader.onload = fileOnload; reader.readAsDataURL(file); }); function fileOnload(e) { var img = document.createElement(''img''); img.src = e.target.result; img.addEventListener(''load'', function() { if(img.width < _min_width || img.height < _min_height ){ notify("<?php echo lang(''each-photo-1MB''); ?>",false,false); return; } $.ajax({ type:''post'', dataType:''script'', data:{photo_1:e.target.result}, url:_config_base_url+''/upload/upload_photos'', progress:function(e){ console.log(e); }, success:function(d){ $(''body'').append(''<img src="''+d+''"/>''); } }); }); } } </script>


AFAIK, debe usar la función de imagen imagecreatefromstring, imagejpeg para crear las imágenes.

$imageData = base64_decode($imageData); $source = imagecreatefromstring($imageData); $rotate = imagerotate($source, $angle, 0); // if want to rotate the image $imageSave = imagejpeg($rotate,$imageName,100); imagedestroy($source);

Espero que esto ayude

PHP CODE WITH IMAGE DATA

$imageDataEncoded = base64_encode(file_get_contents(''sample.png'')); $imageData = base64_decode($imageDataEncoded); $source = imagecreatefromstring($imageData); $angle = 90; $rotate = imagerotate($source, $angle, 0); // if want to rotate the image $imageName = "hello1.png"; $imageSave = imagejpeg($rotate,$imageName,100); imagedestroy($source);

Entonces siguiente es la parte php de tu programa. NOTE EN NOTE el cambio con el comentario El Change is here

$uploadedPhotos = array(''photo_1'',''photo_2'',''photo_3'',''photo_4''); foreach ($uploadedPhotos as $file) { if($this->input->post($file)){ $imageData = base64_decode($this->input->post($file)); // <-- **Change is here for variable name only** $photo = imagecreatefromstring($imageData); // <-- **Change is here** /* Set name of the photo for show in the form */ $this->session->set_userdata(''upload_''.$file,''ant''); /*set time of the upload*/ if(!$this->session->userdata(''uploading_on_datetime'')){ $this->session->set_userdata(''uploading_on_datetime'',time()); } $datetime_upload = $this->session->userdata(''uploading_on_datetime'',true); /* create temp dir with time and user id */ $new_dir = ''temp/user_''.$this->session->userdata(''user_id'',true).''_on_''.$datetime_upload.''/''; if(!is_dir($new_dir)){ @mkdir($new_dir); } /* move uploaded file with new name */ // @file_put_contents( $new_dir.$file.''.jpg'',imagejpeg($photo)); imagejpeg($photo,$new_dir.$file.''.jpg'',100); // <-- **Change is here** } }


Decodifica y guarda la imagen como PNG

header(''content-type: image/png''); ob_start(); $ret = fopen($fullurl, ''r'', true, $context); $contents = stream_get_contents($ret); $base64 = ''data:image/PNG;base64,'' . base64_encode($contents); echo "<img src=$base64 />" ; ob_end_flush();


El cliente necesita enviar base64 al servidor.

Y por encima de la respuesta, el código descrito funciona a la perfección:

$imageData = base64_decode($imageData); $source = imagecreatefromstring($imageData); $rotate = imagerotate($source, $angle, 0); // if want to rotate the image $imageSave = imagejpeg($rotate,$imageName,100); imagedestroy($source);

Gracias


Esto es lo que finalmente funcionó para mí. Tendrá que convertir el código para satisfacer sus propias necesidades, pero esto lo hará.

$fname = filter_input(INPUT_POST, "name"); $img = filter_input(INPUT_POST, "image"); $img = str_replace(''data:image/png;base64,'', '''', $img); $img = str_replace('' '', ''+'', $img); $img = base64_decode($img); file_put_contents($fname, $img); print "Image has been saved!";


$data = ''''; $data = str_replace(''data:image/png;base64,'', '''', $data); $data = str_replace('' '', ''+'', $data); $data = base64_decode($data); $file = ''images/''.rand() . ''.png''; $success = file_put_contents($file, $data); $data = base64_decode($data); $source_img = imagecreatefromstring($data); $rotated_img = imagerotate($source_img, 90, 0); $file = ''images/''. rand(). ''.png''; $imageSave = imagejpeg($rotated_img, $file, 10); imagedestroy($source_img);