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 ().

Есть идеи?

Благодаря!

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

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

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

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

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

jQuery и Canvas.toDataURL

а также

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

В 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 = ""