Intereting Posts
Вход в систему Системный дизайн, позволяющий каждому пользователю регистрироваться на одной машине за раз php xpath получает узел, где атрибут равен Подчеркивание в php-функции Как получить данные из Paypal, чтобы я мог соответствующим образом изменить свою базу данных MySQL? Как передавать данные во все виды в Laravel 5? URL-адрес контроллера URL-адреса N-граммы: Объяснение + 2 приложения предотвращение прямого доступа к php-странице, доступ только при перенаправлении XML-анализ синтаксического анализа данных SOAP: зарезервированное имя XML загружать индикатор выполнения Добавление трех месяцев к дате в PHP PHP – определение пробелов между строками Существуют ли ограничения размера для ключей массива PHP? Каковы ограничения в общем случае для массивов PHP? Почему PHP считает, что 0 равно строке? Получение серийного номера жесткого диска, предоставляемого производителем через PHP

PHP – получить base64 img строку декодировать и сохранить как jpg (в результате пустого изображения)

Привет, я действительно отправляю строку образа base64 через ajax в php-скрипт, который просто декодирует строку и сохраняет содержимое как .jpg файл.

Но результатом является пустой образ.

Как это может быть возможным?

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); } 

Для ajax это нормально, потому что echo $ photoTemp возвращает строку.

Я попробовал var_dump(@file_put_contents( $new_dir.$file.'.jpg',$photoTemp)); и он возвращает bool(true) поскольку изображение сохраняется, но на изображении нет содержимого 🙁 пустое изображение

для пустого изображения я имею в виду, файл создается именован, и он имеет тот же размер содержимого, который я передаю php, но когда я пытаюсь открыть это изображение для предварительного просмотра, он не может быть открыт, потому что поврежденный или плохой файл тип формата

в любом случае это JS, который снимает фото как base64 и отправляет его в 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> , <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, вы должны использовать функцию изображения imagecreatefromstring, imagejpeg для создания изображений.

 $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); 

Надеюсь, это поможет.

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); 

Итак, следующая php-часть вашей программы. NOTE Изменение с комментарием. 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** } } 

Вот что, наконец, помогло мне. Вам придется конвертировать код в соответствии с вашими потребностями, но это будет сделано.

 $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); 

Декодировать и сохранять изображение как 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(); 

Клиент должен отправить base64 на сервер.

И выше ответ описанный код работает отлично:

 $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); 

благодаря