2011-09-03 1 views
5

Sto avendo difficoltà a utilizzare i dati creati con il metodo() todataurl di tela. Attualmente il mio codice invia i dati risultanti al mio server php che utilizza il metodo file_put_contents() per creare un file per archiviare tali dati. Ora se taglio e incolla il linguaggio senza senso risultante dal file in un tag di immagine src, funziona bene e viene visualizzato correttamente, quindi presumo che tutto sia peachy.decodifica di un todataURL tela

ma continuo a correre in problemi quando si tenta di utilizzare il codice JS. Ho provato il metodo base64_decode di php ma ho continuato a ricevere file currupt. Ho trovato questo codice:

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

e ancora file curriculum. Idealmente mi piacerebbe creare un file .png con esso ma mi accontenterei solo di elaborare nuovamente il file di dati in JS. Qualsiasi aiuto molto apprezzato.

+0

È sufficiente leggere il tipo MIME (probabilmente fissa/nota) e la codifica (probabilmente nessuno) per interpretare i dati, che è standard Base64. Non ci saranno spazi da sostituire se hai codificato in precedenza l'input dell'URL. [PHP-FileUpload] (https://github.com/delight-im/PHP-FileUpload) ha un [ 'DataUriUpload'] (https://github.com/delight-im/PHP-FileUpload/blob/023f812226673ac9e0696d8a3579bb7380606dda/ src/DataUriUpload.php) componente che fa tutto questo automaticamente. È documentato [qui] (https://github.com/delight-im/PHP-FileUpload/tree/023f812226673ac9e0696d8a3579bb7380606dda#data-uri-uploads). – caw

risposta

12

Sembra bisogna sbarazzarsi della testata che viene anteposto ai dati di immagine dalla funzione toDataURL(). Sul lato client è possibile togliere l'intestazione come questo:

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

In caso di utilizzo lato server in questo modo:

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

È stato utile, ecco cosa ho fatto se qualcuno dovesse fare lo stesso in futuro: \t $ backGround = substr ($ backGround, 22); \t $ backGround = str_replace ('', '+', $ backGround); \t $ backGround = base64_decode ($ backGround); \t file_put_contents ("currentBG1.png ", $ backGround); – joel

+0

necessario aggiungere anche jpeg all'espressione regolare: var output = data.replace (/^data: image \/(png | jpg | jpeg); base64, /," "); – dickyj

3

In java script inviare il risultato da canvas.toDataURL() su quei browser di supportare questo metodo con il tipo predefinito di "immagine/png".

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

modo diretto per creare il file PNG:

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

Ho questo lavoro in PHP 5.3/Windows, per altra versione, si prega di controllare.

Esempio di dati immagine per test su PHP.

$imageInfo = "" 
+0

Se questo non funziona, per favore pubblica il tuo ambiente PHP Grazie –

+0

canvas.toDataUrl() ... che cos'è questo? – realtebo

+1

'canvas.toDataUrl()' è usato per esempio su [fabric.js] (http: // fabricjs.com/). Puoi ottenere il tuo canvas tramite JavaScript 'var imageInfo = document.getElementById (" yourid "). aDataURL();' oppure tramite JQuery 'var imageInfo = $ (" # yourid "). aDataURL() ; ' Questa soluzione inviata da @ DanielDeLeón funziona come un incantesimo. Grazie, – ptCoder

0

Altre soluzioni non ha funzionato per me.

Questo funziona:

//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));