HTML5 canvas toDataURL возвращает пустое изображение - PullRequest
4 голосов
/ 03 августа 2011

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

<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 ]

7 голосов
/ 04 августа 2011

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

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

<?php
  $encodedData = str_replace(' ','+',$encodedData);
  $decocedData = base64_decode($encodedData);
?>
0 голосов
/ 13 января 2012

В 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 = ""
0 голосов
/ 03 августа 2011

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

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

jQuery и Canvas.toDataURL

и

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

...