Декодирование холста todataURL

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

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

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

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

Solutions Collecting From Web of "Декодирование холста todataURL"

Кажется, вам нужно избавиться от заголовка, который добавляется к данным изображения с помощью функции 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); ?> 

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

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

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

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