У меня возникают трудности с использованием данных, созданных с помощью метода todataurl () canvas. В настоящее время мой код отправляет полученные данные на мой php-сервер, который использует метод file_put_contents () для создания файла для хранения этих данных. Теперь, если я вырезаю и вставляю полученную тарабарщину из файла в тег изображения src, он отлично работает и отображается правильно, поэтому я предполагаю, что до сих пор все персиковое.
Но я продолжаю сталкиваться с проблемами, когда пытаюсь использовать код в JS. Я пробовал базовый метод php base64_decode, но продолжал получать файлы currupt. Я нашел этот код:
<?php $encodedData = str_replace(' ','+',$encodedData); $decocedData = base64_decode($encodedData);
и все еще получал обновленные файлы. В идеале я хотел бы создать с ним файл .png, но я решил бы просто обработать файл данных снова в JS. Любая помощь очень ценится.
Кажется, вам нужно избавиться от заголовка, который добавляется к данным изображения с помощью функции 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