如何将base64字符串解码为图像并使用PHP将其保存在服务器上

时间:2018-06-25 08:36:01

标签: javascript php ajax file upload

我有一个使用Javascript获得的图像的base64字符串,然后将其发送到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时得到的字符串(由于太长,我不会发布全部内容):



2 个答案:

答案 0 :(得分:0)

要获取有效的base64编码字符串,您必须从字符串中删除前缀。在这种情况下,base64字符串在data:image/png;base64,之后开始。

简单的解决方案-只需跳过前22个字符。

$logo = substr($logo, 22);

如果您需要更通用的解决方案-请使用这样的正则表达式

$logo = preg_replace('~^data:[^;]+;base64,~', '', $logo);

答案 1 :(得分:0)

要获取图像的特定base 64内容,请删除data:image/png;base64,并用+替换空格,如以下代码所示:

$imageData = base64_decode(str_replace(['data:image/png;base64,', ' '], ['', '+'], $logo));