从空白画布开始:
<canvas id='myCanvas' width='800' height='600'></canvas>
然后初始化该画布:
function init_canvas(){
var canvas = document.getElementById('myCanvas');
context = canvas.getContext('2d');
context.lineCap = 'round';
// fill it with white background
context.save();
context.fillStyle = '#fff';
context.fillRect(0, 0, context.canvas.width, context.canvas.height);
context.restore();
return;
}
然后在画布上做一堆绘画。
然后尝试使用后端的ajax和PHP将其保存到服务器。
在客户端:
var img = canvas.toDataURL('image/png');
// strip the leading garbage.
img.substr(img.indexOf(',')+1).toString();
将生成的字符串(base64编码的png)直接输入到PHP和base64_decode()字符串...图像总是正确的大小,但它没有任何绘图 - 只是一个透明的图像。这似乎不是PHP中的base64_decode()的问题,它似乎是一个安全的事情。它在Firefox 4和最新的Chrome中都失败了。
使用“image / png”标题将生成的png图像转储到firefox会在错误控制台中生成:
Error: Image corrupt or truncated: http://somewhere.com/showimage.php
Source file: http://somewhere.com/showimage.php
但是......除非toDataURL()在任何地方都被破坏,否则图像不会被破坏或被截断,因为php的东西只是base64_decode()toDataURL()的结果。
有什么想法吗?
谢谢!
答案 0 :(得分:7)
您是否在base64_decode
的PHP文档中看到了this comment?
如果要保存从Javascript派生的数据 canvas.toDataURL()函数,你必须将空格转换为加号。 如果不这样做,则解码数据已损坏:
<?php $encodedData = str_replace(' ','+',$encodedData); $decocedData = base64_decode($encodedData); ?>
答案 1 :(得分:0)
答案 2 :(得分:0)
此方法可以正常工作,而不会返回空白图像。
saveImage.php
<?php
$result = array();
$encodedData = explode("," , $_POST['imgData'])[1];
$encodedData = str_replace(' ','+',$encodedData);
$decocedData = base64_decode($encodedData);
//Location to where you want to save image
$NewFileName = './photos/'.$_POST['imgName'].'.jpg';
file_put_contents($NewFileName,$decocedData);
$result['status'] = 1;
$result['saveImage'] = $NewFileName;
echo json_encode($result);
?>
script.js
<script>
//This post the data to server on fly
function saveImage(canvasData,FileName) {
var xmlHttpReq = false;
if (window.XMLHttpRequest) {
ajax = new XMLHttpRequest();
}
else if (window.ActiveXObject) {
ajax = new ActiveXObject("Microsoft.XMLHTTP");
}
ajax.open("POST", "saveImage.php", false);
ajax.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
ajax.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
var rawArr = JSON.parse(this.responseText);
var ImagePreviewer= document.getElementById("ImagePreviewer");
ImagePreviewer.src=rawArr.saveImage;
//console.log(rawArr.saveImage);
}
}
ajax.send("imgData=" + canvasData+"&imgName=" + FileName);
}
// Call this with button click or whatever you want
function saveJPG(filename) {
//do other logic here
var dataURL = TheCanvas.toDataURL("image/jpg");
saveImage(dataURL,filename);
}
<script>
答案 3 :(得分:-1)
在JavaScript中,将canvas.toDataURL()
上的结果发送到支持此方法的浏览器上,默认类型为“image / png”。
var imageInfo = canvas.toDataURL();
创建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中使用它,对于其他版本,请检查。
用于在PHP上测试的图像数据样本。
$imageDataInfoSample = ""