解码画布todataURL

时间:2011-09-03 04:31:49

标签: php javascript canvas

我在使用canvas的todataurl()方法创建的数据时遇到了困难。目前我的代码将结果数据发送到我的php服务器,该服务器使用file_put_contents()方法创建一个文件来存储该数据。现在,如果我将文件中产生的乱码剪切并粘贴到图像标签src中,它可以正常工作并正确显示,所以我假设到目前为止一切都很好。

但是当我尝试在JS中使用代码时,我一直遇到问题。我已经尝试过php的base64_decode方法,但不断收到破坏的文件。我找到了这段代码:

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

仍然有被破坏的文件。理想情况下,我想用它创建一个.png文件,但我决定只在JS中再次处理数据文件。任何帮助非常感谢。

4 个答案:

答案 0 :(得分:13)

似乎你必须摆脱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);
?>

答案 1 :(得分:3)

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

答案 2 :(得分:2)

另一个重要的注意事项是你必须将空白转换为加号。如果不这样做,则解码数据已损坏:

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

您可以在http://www.php.net/manual/en/function.base64-decode.php

了解更多信息

答案 3 :(得分:0)

其他解决方案对我不起作用。

这有效:

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