2011-09-03 11 views
5

Tengo dificultades para usar los datos creados con el método lona de toda la lona(). Actualmente mi código envía los datos resultantes a mi servidor php que utiliza el método file_put_contents() para crear un archivo para almacenar esos datos. Ahora si corté y pegué el galimatías resultante del archivo en una etiqueta de imagen src, funciona bien y se muestra correctamente así que supongo que hasta ahora todo es color de rosa.Descifrando un lienzo todataURL

Pero sigo teniendo problemas cuando trato de usar el código en JS. Probé con el método base64_decode de php, pero seguí obteniendo archivos no deseados. Encontré este código:

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

y todavía tengo archivos descompuestos. Idealmente, me gustaría crear un archivo .png con él, pero me conformaría con simplemente procesar el archivo de datos de nuevo en JS. Cualquier ayuda muy apreciada.

+0

Usted simplemente tiene que leer el tipo MIME (probablemente fijo/conocido) y la codificación (probablemente ninguno) para interpretar los datos, que es estándar Base64. No habrá espacios para reemplazar si codificó URL la entrada antes. [PHP-FileUpload] (https://github.com/delight-im/PHP-FileUpload) tiene un ['DataUriUpload'] (https://github.com/delight-im/PHP-FileUpload/blob/023f812226673ac9e0696d8a3579bb7380606dda/ src/DataUriUpload.php) componente que hace todo esto automáticamente. Está documentado [aquí] (https://github.com/delight-im/PHP-FileUpload/tree/023f812226673ac9e0696d8a3579bb7380606dda#data-uri-uploads). – caw

Respuesta

12

Parece que tiene que deshacerse del encabezado que se antepone a los datos de imagen mediante la función toDataURL(). En el cliente puede quitarse la cabecera de la siguiente manera:

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

En cuanto al uso de este lado del servidor:

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

Eso fue útil, esto es lo que terminé haciendo si alguien necesita hacer lo mismo en el futuro: \t $ backGround = substr ($ backGround, 22); \t $ backGround = str_replace ('', '+', $ backGround); \t $ backGround = base64_decode ($ backGround); \t file_put_contents ("currentBG1.png", $ fondo); – joel

+0

necesita agregar jpeg a la expresión regular, así: var = data.replace de salida (/^datos: Imagen \/(png | jpg | jpeg); base64, /, ""); – dickyj

3

En java script enviar el resultado de canvas.toDataURL() en los navegadores que admite este método con el tipo predeterminado de "image/png".

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

manera directa para crear el archivo PNG:

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

que tiene este trabajo en PHP 5.3/Windows, por otra versión, por favor, compruebe.

Muestra de datos de imagen para probar en PHP.

$imageInfo = "" 
+0

Si esto falla para usted, por favor, puesto que su entorno PHP Gracias –

+0

canvas.toDataURL() ... ¿qué es esto – realtebo

+1

'canvas.toDataURL()' se utiliza por ejemplo en [fabric.js] (http:..? // . fabricjs.com/) Usted puede obtener su lienzo a través de JavaScript 'var ImageInfo = document.getElementById ("yourid") toDataURL (.),' 'oa través de jQuery var ImageInfo = $ ("# yourid") toDataURL(). ; ' Esta solución publicada por @ DanielDeLeón funciona como un amuleto. Gracias, – ptCoder

0

Otras soluciones no funcionaron para mí.

Esto funciona:

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