Расшифровка холста todataURL - PullRequest
       4

Расшифровка холста todataURL

5 голосов
/ 03 сентября 2011

У меня проблемы с использованием данных, созданных методом canvas todataurl ().В настоящее время мой код отправляет полученные данные на мой php-сервер, который использует метод file_put_contents () для создания файла для хранения этих данных.Теперь, если я вырежу и вставлю полученную тарабарщину из файла в тег изображения src, она будет работать нормально и будет отображаться правильно, так что я предполагаю, что пока все хорошо.

Но я продолжаю сталкиваться с проблемами, когда пытаюсь использовать код в JS.Я пробовал php метод base64_decode, но продолжал получать файлы с прерываниями.Я нашел этот код:

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

и все еще получил зарезанные файлы.В идеале я хотел бы создать файл .png с ним, но я бы согласился просто снова обработать файл данных в JS.Любая помощь с благодарностью.

Ответы [ 4 ]

13 голосов
/ 03 сентября 2011

Кажется, вам нужно избавиться от заголовка, который добавляется к данным изображения функцией toDataURL().На стороне клиента вы можете удалить заголовок следующим образом:

..
var data=canvas.toDataURL();
var output=data.replace(/^data:image\/(png|jpg);base64,/, "");
// now send "output" to the server
..

На стороне сервера используйте это:

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

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

var imageInfo = canvas.toDataURL();
// now send "imageInfo" to the server

Прямой способ создания файла 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 / Windows, для другой версии, пожалуйста, проверьте.

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

$imageInfo = ""
2 голосов
/ 09 апреля 2012

Еще одно важное замечание: вы должны конвертировать заготовки в плюсы. Если вы этого не сделаете, декодированные данные будут повреждены:

$encodedData = str_replace(' ','+',$encodedData);
$decocedData = base64_decode($encodedData);

Вы можете прочитать больше на http://www.php.net/manual/en/function.base64-decode.php

0 голосов
/ 15 января 2018

Другие решения у меня не сработали.

Это работает:

//image sample
$baseFromJavascript = "";

// remove the part that we don't need from the provided image and decode it
$data = base64_decode(preg_replace('#^data:image/\w+;base64,#i', '', $baseFromJavascript));
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...