HTML5 canvas toDataURL возвращает пустое изображение

Начиная с чистого холста:

<canvas id='myCanvas' width='800' height='600'></canvas>

Затем инициализируем этот холст:

  function init_canvas(){
    var canvas = document.getElementById('myCanvas');
    context = canvas.getContext('2d');
    context.lineCap = 'round';
    // fill it with white background
    context.save();
    context.fillStyle = '#fff';
    context.fillRect(0, 0, context.canvas.width, context.canvas.height);
    context.restore();
    return;
  }

Затем сделайте кучу рисунков на холсте.

Затем попробуйте сохранить его на сервере, используя ajax и PHP на сервере.

На клиенте:

var img = canvas.toDataURL('image/png');
// strip the leading garbage.
img.substr(img.indexOf(',')+1).toString();

Возьмем результирующую строку, которая закодирована в формате base64 png, непосредственно в PHP и и base64_decode() в строку... Изображение всегда имеет правильный размер, но на нем нет рисунка - только прозрачное изображение. Похоже, что это не проблема с base64_decode() в PHP, это похоже на проблему безопасности или что-то в этом роде. Это терпит неудачу и в Firefox 4 и в последнем Chrome.

Вывод полученного png-изображения в firefox с заголовками "image/png" выдает это в консоли ошибок:

Error: Image corrupt or truncated: http://somewhere.com/showimage.php
Source file: http://somewhere.com/showimage.php

Но... Изображение не повреждено и не усечено, что я могу сказать, если только toDataURL() не нарушен везде, потому что php просто base64_decode() является результатом toDataURL().

Есть идеи?

Спасибо!

3 ответа

Решение

Вы видели этот комментарий в PHP документах для base64_decode?

Если вы хотите сохранить данные, полученные из функции Javascript canvas.toDataURL(), вы должны конвертировать пробелы в плюсы. Если вы этого не сделаете, декодированные данные будут повреждены:

<?php
  $encodedData = str_replace(' ','+',$encodedData);
  $decocedData = base64_decode($encodedData);
?>

Это как моя проблема раньше?

может быть, вы можете проверить на

jQuery и Canvas.toDataURL

а также

Ошибка безопасности " code: "1000 в Firefox с Canvas.toDataURL

Это отлично работает без возврата пустого изображения.

saveImage.php

 <?php 
        $result = array();  
        $encodedData = explode("," , $_POST['imgData'])[1];
        $encodedData = str_replace(' ','+',$encodedData);
        $decocedData = base64_decode($encodedData); 
        //Location to where you want to save image
        $NewFileName = './photos/'.$_POST['imgName'].'.jpg';
        file_put_contents($NewFileName,$decocedData);
        $result['status'] = 1;
        $result['saveImage'] = $NewFileName;
        echo json_encode($result);
    ?>

script.js

<script>
//This post the data to server on fly

function saveImage(canvasData,FileName) {
  var xmlHttpReq = false;

  if (window.XMLHttpRequest) {
    ajax = new XMLHttpRequest();
  }
  else if (window.ActiveXObject) {
    ajax = new ActiveXObject("Microsoft.XMLHTTP");
  }

  ajax.open("POST", "saveImage.php", false);
  ajax.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
  ajax.onreadystatechange = function() {

    if (this.readyState == 4 && this.status == 200) {
        var rawArr = JSON.parse(this.responseText);
        var ImagePreviewer= document.getElementById("ImagePreviewer");
    ImagePreviewer.src=rawArr.saveImage;
    //console.log(rawArr.saveImage);
    }

  }
  ajax.send("imgData=" + canvasData+"&imgName=" + FileName);
}
// Call this with button click or whatever you want 
function saveJPG(filename) {
//do other logic here
var dataURL = TheCanvas.toDataURL("image/jpg");
    saveImage(dataURL,filename);
}
<script>

В JavaScript пришлите результат из canvas.toDataURL() в тех браузерах, которые поддерживают этот метод с типом по умолчанию "image/png".

var imageInfo = canvas.toDataURL();

Прямой способ создать файл png:

<?php
$imageInfo = imageInfoFromBrowser(); // Your method to get the data
$image = fopen($imageInfo, 'r');
file_put_contents("fileName.png", $image);
fclose($image);
?>

У меня это работает в PHP 5.3, для другой версии, пожалуйста, проверьте.

Образец данных изображения для тестирования на PHP.

$imageDataInfoSample = ""
Другие вопросы по тегам