У меня есть строка base64 изображения, которую я получаю с помощью Javascript и затем отправляю в сценарий PHP.
Это работает, я также могу отобразить строку в моем сценарии, но теперь я пытаюсь создатьизображение из него и сохранить его на моем сервере.Однако я не получаю ошибок, но также ничего не сохраняется ..
Что я делаю не так?
Вот как я создаю строку:
window.onload = function() {
var fileInput = document.getElementById('fileInput');
var fileDisplayArea = document.getElementById('fileDisplayArea');
fileInput.addEventListener('change', function(e) {
var file = fileInput.files[0];
var imageType = /image.*/;
if (file.type.match(imageType)) {
var reader = new FileReader();
reader.onload = function(e) {
fileDisplayArea.innerHTML = "";
var img = new Image();
img.src = reader.result;
fileDisplayArea.appendChild(img);
}
reader.readAsDataURL(file);
} else {
fileDisplayArea.innerHTML = "File not supported!"
}
});
}
Строка base64затем добавляется к <img src
, который я получаю и отправляю с помощью ajax:
// Add/edit companies script
$( "#companywrap" ).on("click", "#savecompany", function( event ) {
// Stop normal form behaviour
event.preventDefault();
var $form = $("#companyform"),
$logo = $form.find( "#fileDisplayArea" ).children('img').attr('src');
url = $form.attr( "action" );
var posting = $.post( url, {
logo: $logo,
});
// Show result in a div
posting.done(function( data ) {
$( ".resultmessage" ).empty().slideDown('fast').append( data );
console.log($logo);
});
});
Затем в своем скрипте PHP я делаю следующее:
$logo = $_POST['logo'];
$imageData = base64_decode($logo);
$source = imagecreatefromstring($imageData);
$angle = 90;
$rotate = imagerotate($source, $angle, 0);
$imageName = "myfolder/testfile.png";
$imageSave = imagejpeg($rotate,$imageName,100);
imagedestroy($source);
Но это несделайте что-нибудь.
Это строка, которую я получаю, когда я повторяю $logo
(я не буду публиковать всю статью, потому что она слишком длинная):
