Привет, я действительно отправляю строку образа 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);
благодаря