2011-09-03 509 views
5

我很难用canvas的todataurl()方法创建数据。目前我的代码将结果数据发送到我的php服务器,该服务器使用file_put_contents()方法创建一个文件来存储该数据。现在,如果我从文件中剪切并粘贴得到的乱码到一个图像标签src中,它可以正常工作并正常显示,因此我认为一切都很好。解码画布todataURL

但是当我尝试在JS中使用代码时,我一直遇到问题。我试过php的base64_decode方法,但不断得到中断文件。我发现这个代码:

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

仍然有被破坏的文件。理想情况下,我想创建一个.png文件,但我会解决只是在JS中处理数据文件。任何帮助不胜感激。

+0

您只需读取MIME类型(可能是固定/已知的)和编码(可能没有)来解释数据,这是标准的Base64。如果您先前对URL进行了URL编码,则不会有任何空间被替换。 [PHP-FileUpload](https://github.com/delight-im/PHP-FileUpload)有一个['DataUriUpload'](https://github.com/delight-im/PHP-FileUpload/blob/023f812226673ac9e0696d8a3579bb7380606dda/ src/DataUriUpload.php)组件,它自动完成所有这些。它记录在[这里](https://github.com/delight-im/PHP-FileUpload/tree/023f812226673ac9e0696d8a3579bb7380606dda#data-uri-uploads)。 – caw

回答

12

看来你必须摆脱由toDataURL()函数预先图像数据的头。 在客户端就可以剥离这样的标题:)这些浏览器

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

这很有帮助,这是我最终做的事情,如果有人需要在将来也这样做:\t $ backGround = substr($ backGround,22); \t $ backGround = str_replace('','+',$ backGround); \t $ backGround = base64_decode($ backGround); \t file_put_contents(“currentBG1。png“,$ backGround); – joel

+0

需要将jpeg添加到正则表达式中:var output = data.replace(/^data:image \ /(png | jpg | jpeg); base64,/,”“); – dickyj

3

在Java脚本从canvas.toDataURL(发送结果:

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

在服务器端使用此比默认类型的“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 = "" 
+0

如果这样做失败,请发布你的PHP环境。谢谢。 –

+0

canvas.toDataUrl()...这是什么? – realtebo

+1

'canvas.toDataUrl()'用于例如[fabric.js](http://您可以通过JavaScript获取画布var imageInfo = document.getElementById(“yourid”)。toDataURL();'或者通过JQuery' var imageInfo = $(“#yourid”)。toDataURL() ;' @DanielDeLeón发布的解决方案非常有用,谢谢 – ptCoder

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