2011-09-03 14 views
5

Mam problemy z używaniem danych utworzonych za pomocą metody todataurl() canvas. Obecnie mój kod wysyła uzyskane dane do mojego serwera php, który wykorzystuje metodę file_put_contents() do utworzenia pliku do przechowywania tych danych. Teraz, jeśli wycinam wynikowy bełkot z pliku do src tagu graficznego, działa on poprawnie i wyświetla się poprawnie, więc zakładam, że do tej pory wszystko jest brzoskwiniowe.Dekodowanie obszaru roboczego todataURL

Ale wciąż napotykam na problemy, gdy próbuję użyć kodu w JS. Próbowałem już metody base64_decode php, ale ciągle dostaję się uciążliwe pliki. Znalazłem ten kod:

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

i wciąż mam pliki currupted. Idealnie chciałbym utworzyć z nim plik .png, ale zdecydowałbym się na ponowne przetwarzanie pliku danych w JS. Każda pomoc bardzo doceniona.

+0

Po prostu trzeba czytać typ MIME (prawdopodobnie stały/znany) i kodowania (prawdopodobnie brak) do interpretacji danych, który jest standardem Base64. Nie będzie żadnych spacji do zastąpienia, jeśli wcześniej zakodowano dane wejściowe. [PHP-FileUpload] (https://github.com/delight-im/PHP-FileUpload) ma ['DataUriUpload'] (https://github.com/delight-im/PHP-FileUpload/blob/023f812226673ac9e0696d8a3579bb7380606dda/ src/DataUriUpload.php), który wykonuje to wszystko automatycznie. Jest to udokumentowane [tutaj] (https://github.com/delight-im/PHP-FileUpload/tree/023f812226673ac9e0696d8a3579bb7380606dda#data-uri-uploads). – caw

Odpowiedz

12

Wygląda na to, że musisz pozbyć się nagłówka dodanego do danych obrazu za pomocą funkcji toDataURL(). Po stronie klienta można zdejmować nagłówek tak:

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

Na użycia po stronie serwera to:

<?php 
    $decocedData = base64_decode($encodedData); 
?> 
+3

To było pomocne, oto, co zrobiłem, jeśli ktoś musi zrobić to samo w przyszłości: \t $ backGround = substr ($ backGround, 22); \t $ backGround = str_replace ('', '+', $ backGround); \t $ backGround = base64_decode ($ backGround); \t file_put_contents ("currentBG1.png ", $ backGround); – joel

+0

trzeba dodać jpeg do wyrażenia regularnego: var output = data.replace (/^dane: image \/(png | jpg | jpeg); base64, /," "); – dickyj

3

w Java Script wysłać wynik z canvas.toDataURL() na tych przeglądarek niż obsługuje tę metodę z domyślnym typem "image/png".

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

bezpośredni sposób do utworzenia pliku png:

<?php 
$imageInfo = imageInfoFromBrowser(); // Your method to get the data 
$image = fopen($imageInfo, 'r'); 
file_put_contents("fileName.png", $image); 
fclose($image); 
?> 

mam ten pracujący w PHP 5.3/Windows, dla pozostałych wersji, proszę sprawdzić.

Próbka danych obrazu do testowania w PHP.

$imageInfo = "" 
+0

Jeśli to Ci nie pomoże, opublikuj swoje środowisko PHP. –

+0

canvas.toDataUrl() ... co to jest? – realtebo

+1

'canvas.toDataUrl()' jest używane na przykład w [fabric.js] (http: // fabricjs.com/).) Możesz dostać swoje płótno przez JavaScript 'var imageInfo = document.getElementById (" yourid "). toDataURL();' lub przez JQuery 'var imageInfo = $ (" # yourid ") .DataURL() ; ' To rozwiązanie opublikowane przez @ DanielDeLeón działa jak urok.Dziękuję, – ptCoder

0

Inne rozwiązania nie działa dla mnie.

to działa:

//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)); 
Powiązane problemy